

# **Synthesis Variables and Attributes**

---

Version S-2021.06-SP2, October 2021

**SYNOPSYS®**

## Copyright Notice and Proprietary Information

© 2021 Synopsys, Inc. All rights reserved. This Synopsys software and all associated documentation are proprietary to Synopsys, Inc. and may only be used pursuant to the terms and conditions of a written license agreement with Synopsys, Inc. All other use, reproduction, or distribution of the Synopsys software or the associated documentation is strictly prohibited.

### Destination Control Statement

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

### Disclaimer

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

### Trademarks

Synopsys and certain Synopsys product names are trademarks of Synopsys, as set forth at <http://www.synopsys.com/company/legal/trademarks-brands.html>.

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

### Free and Open-Source Software Licensing Notices

If applicable, Free and Open-Source Software (FOSS) licensing notices are available in the product installation.

### Third-Party Links

Any links to third-party websites included in this document are for your convenience only. Synopsys does not endorse and is not responsible for such websites and their practices, including privacy practices, availability, and content.

[www.synopsys.com](http://www.synopsys.com)

---

## Contents

|                                                   |    |
|---------------------------------------------------|----|
| DW_lp_op_iso_mode . . . . .                       | 24 |
| MasterInstance . . . . .                          | 25 |
| abstraction_enable_power_calculation . . . . .    | 26 |
| abstraction_ignore_percentage . . . . .           | 27 |
| access_internal_pins . . . . .                    | 28 |
| acs_area_report_suffix . . . . .                  | 29 |
| acs_budgeted_cstr_suffix . . . . .                | 30 |
| acs_compile_attributes . . . . .                  | 31 |
| acs_compile_script_suffix . . . . .               | 33 |
| acs_constraint_file_suffix . . . . .              | 34 |
| acs_cstr_report_suffix . . . . .                  | 35 |
| acs_db_suffix . . . . .                           | 36 |
| acs_global_user_compile_strategy_script . . . . . | 37 |
| acs_log_file_suffix . . . . .                     | 38 |
| acs_makefile_name . . . . .                       | 39 |
| acs_override_script_suffix . . . . .              | 40 |
| acs_qor_report_suffix . . . . .                   | 41 |
| acs_timing_report_suffix . . . . .                | 42 |
| acs_user_compile_strategy_script_suffix . . . . . | 43 |
| acs_work_dir . . . . .                            | 44 |
| alib_library_analysis_path . . . . .              | 45 |
| all_registers_include_icg . . . . .               | 46 |
| attributes . . . . .                              | 47 |
| auto_insert_level_shifters . . . . .              | 65 |
| auto_insert_level_shifters_on_clocks . . . . .    | 66 |
| auto_link_disable . . . . .                       | 67 |
| auto_link_options . . . . .                       | 68 |
| auto_ungroup_preserve_constraints . . . . .       | 69 |
| auto_wire_load_selection . . . . .                | 71 |
| banking_enable_concatenate_name . . . . .         | 72 |
| bind_unused_hierarchical_pins . . . . .           | 74 |
| bit_blasted_bus_linking_naming_styles . . . . .   | 76 |
| bit_blasted_bus_linking_order . . . . .           | 78 |
| block_abstraction_compute_area_as_macro . . . . . | 79 |
| bound_attributes . . . . .                        | 80 |
| bsd_max_in_switching_limit . . . . .              | 84 |
| bsd_max_out_switching_limit . . . . .             | 85 |
| bsd_physical_effort . . . . .                     | 86 |
| budget_generate_critical_range . . . . .          | 87 |
| budget_map_clock_gating_cells . . . . .           | 88 |

|                                                                         |     |
|-------------------------------------------------------------------------|-----|
| bus_inference_descending_sort . . . . .                                 | 89  |
| bus_inference_style . . . . .                                           | 90  |
| bus_minus_style . . . . .                                               | 92  |
| bus_multiple_name_separator_style . . . . .                             | 93  |
| bus_multiple_separator_style . . . . .                                  | 94  |
| bus_naming_style . . . . .                                              | 95  |
| bus_range_separator_style . . . . .                                     | 97  |
| case_analysis_log_file . . . . .                                        | 98  |
| case_analysis_propagate_through_icg . . . . .                           | 99  |
| case_analysis_sequential_propagation . . . . .                          | 100 |
| case_analysis_with_logic_constants . . . . .                            | 101 |
| ccd_hold_control_effort . . . . .                                       | 102 |
| ccd_ignore_ports_for_boundary_identification . . . . .                  | 103 |
| ccd_ignore_scan_reset_for_boundary_identification . . . . .             | 105 |
| ccd_max_postpone . . . . .                                              | 106 |
| ccd_max_prepone . . . . .                                               | 107 |
| ccd_optimize_boundary_timing . . . . .                                  | 108 |
| ccd_respect_cts_fixed_balance_pins . . . . .                            | 110 |
| ccd_skip_path_groups . . . . .                                          | 112 |
| ccd_write_script_sdc_add_offset_to_latency . . . . .                    | 113 |
| cell_attributes . . . . .                                               | 115 |
| change_names_bit_blast_negative_index . . . . .                         | 119 |
| change_names_dont_change_bus_members . . . . .                          | 120 |
| check_design_allow_inconsistent_input_port . . . . .                    | 121 |
| check_design_allow_inconsistent_output_port . . . . .                   | 122 |
| check_design_allow_multiply_driven_nets_by_inputs_and_outputs . . . . . | 123 |
| check_design_allow_non_tri_drivers_on_tri_bus . . . . .                 | 124 |
| check_design_allow_unknown_wired_logic_type . . . . .                   | 125 |
| check_design_check_for_wire_loop . . . . .                              | 126 |
| check_design_check_multidriven_output_ports . . . . .                   | 127 |
| check_error_list . . . . .                                              | 128 |
| clock_attributes . . . . .                                              | 129 |
| collection_result_display_limit . . . . .                               | 131 |
| command_log_file . . . . .                                              | 132 |
| company . . . . .                                                       | 133 |
| compatibility_version . . . . .                                         | 134 |
| compile_adjust_max_processes_used . . . . .                             | 135 |
| compile_advanced_fix_multiple_port_nets . . . . .                       | 136 |
| compile_allow_dw_hierarchical_inverter_opt . . . . .                    | 137 |
| compile_assume_fully_decoded_three_state_busses . . . . .               | 138 |
| compile_auto_ungroup_area_num_cells . . . . .                           | 139 |
| compile_auto_ungroup_count_leaf_cells . . . . .                         | 140 |
| compile_auto_ungroup_override_wlm . . . . .                             | 142 |
| compile_automatic_clock_phase_inference . . . . .                       | 143 |
| compile_cell_density_aware_optimization . . . . .                       | 144 |

|                                                                            |     |
|----------------------------------------------------------------------------|-----|
| compile_cell_density_aware_optimization_threshold . . . . .                | 145 |
| compile_checkpoint_phases . . . . .                                        | 146 |
| compile_clock_gating_through_hierarchy . . . . .                           | 147 |
| compile_create_wire_load_table . . . . .                                   | 148 |
| compile_delete_unloaded_sequential_cells . . . . .                         | 149 |
| compile_dft_log_print_mis_info . . . . .                                   | 150 |
| compile_disable_hierarchical_inverter_opt . . . . .                        | 151 |
| compile_dont_touch_annotated_cell_during_inplace_opt . . . . .             | 152 |
| compile_dont_use_dedicated_scanout . . . . .                               | 153 |
| compile_enable_async_mux_mapping . . . . .                                 | 154 |
| compile_enable_ccd . . . . .                                               | 155 |
| compile_enable_constant_propagation_with_no_boundary_opt . . . . .         | 156 |
| compile_enable_enhanced_leakage_optimization . . . . .                     | 157 |
| compile_enable_min_delay_fixing . . . . .                                  | 158 |
| compile_enable_mis_cells_decomposition . . . . .                           | 159 |
| compile_enable_multibit_rewiring_in_incremental . . . . .                  | 160 |
| compile_enable_physical_multibit_banking . . . . .                         | 161 |
| compile_enable_register_merging . . . . .                                  | 162 |
| compile_enable_register_merging_with_exceptions . . . . .                  | 163 |
| compile_enable_total_power_optimization . . . . .                          | 164 |
| compile_enhanced_tns_optimization . . . . .                                | 165 |
| compile_enhanced_tns_optimization_effort_level . . . . .                   | 167 |
| compile_enhanced_tns_optimization_in_incremental . . . . .                 | 168 |
| compile_final_drc_fix . . . . .                                            | 170 |
| compile_fix_cell_degradation . . . . .                                     | 171 |
| compile_high_effort_area . . . . .                                         | 172 |
| compile_high_effort_area_in_incremental . . . . .                          | 173 |
| compile_high_pin_density_cell_optimization . . . . .                       | 174 |
| compile_high_pin_density_cell_optimization_utilization_threshold . . . . . | 176 |
| compile_high_pin_density_cell_spreading . . . . .                          | 178 |
| compile_high_pin_density_cell_spreading_threshold . . . . .                | 179 |
| compile_hold_reduce_cell_count . . . . .                                   | 181 |
| compile_implementation_selection . . . . .                                 | 182 |
| compile_inbound_cell_optimization . . . . .                                | 183 |
| compile_inbound_max_cell_percentage . . . . .                              | 184 |
| compile_inbound_sitedef_name . . . . .                                     | 185 |
| compile_instance_name_prefix . . . . .                                     | 186 |
| compile_instance_name_suffix . . . . .                                     | 187 |
| compile_keep_original_for_external_references . . . . .                    | 188 |
| compile_log_format . . . . .                                               | 189 |
| compile_log_print_pathgroups_in_delayopt . . . . .                         | 194 |
| compile_negative_logic_methodology . . . . .                               | 195 |
| compile_no_new_cells_at_top_level . . . . .                                | 196 |
| compile_optimize_netlist_area . . . . .                                    | 197 |
| compile_optimize_netlist_area_in_incremental . . . . .                     | 198 |

|                                                                            |     |
|----------------------------------------------------------------------------|-----|
| compile_optimize_unloaded_seq_logic_with_no_bound_opt .....                | 199 |
| compile_power_domain_boundary_optimization .....                           | 200 |
| compile_prefer_mux .....                                                   | 201 |
| compile_preserve_subdesign_interfaces .....                                | 203 |
| compile_print_crossprobe_info_with_seqmap_messages .....                   | 205 |
| compile_register_replication .....                                         | 206 |
| compile_register_replication_across_hierarchy .....                        | 207 |
| compile_register_replication_do_size_only .....                            | 208 |
| compile_report_on_unmapped_cells .....                                     | 209 |
| compile_restructure_sync_set_reset .....                                   | 210 |
| compile_retime_exception_registers .....                                   | 211 |
| compile_retime_license_behavior .....                                      | 212 |
| compile_seqmap_disable_qn_pin_connections .....                            | 213 |
| compile_seqmap_enable_output_inversion .....                               | 214 |
| compile_seqmap_honor_sync_set_reset .....                                  | 215 |
| compile_seqmap_identify_shift_registers .....                              | 216 |
| compile_seqmap_identify_shift_registers_with_synchronous_logic .....       | 218 |
| compile_seqmap_identify_shift_registers_with_synchronous_logic_ascii ..... | 220 |
| compile_seqmap_propagate_constant_clocks .....                             | 222 |
| compile_seqmap_propagate_constants .....                                   | 223 |
| compile_seqmap_propagate_constants_size_only .....                         | 224 |
| compile_seqmap_propagate_high_effort .....                                 | 225 |
| compile_seqmap_report_non_scan_mapping .....                               | 226 |
| compile_shift_register_max_length .....                                    | 227 |
| compile_state_reachability_high_effort_merge .....                         | 228 |
| compile_timing_high_effort .....                                           | 229 |
| compile_timing_high_effort_tns .....                                       | 230 |
| compile_top_all_paths .....                                                | 231 |
| compile_ultra_ungroup_dw .....                                             | 232 |
| compile_ultra_ungroup_small hierarchies .....                              | 233 |
| compile_update_annotated_delays_during_inplace_opt .....                   | 234 |
| complete_mixed_mode_extraction .....                                       | 236 |
| core_area_attributes .....                                                 | 238 |
| cts_clock_source_is_exclude_pin .....                                      | 241 |
| db_load_ccs_data .....                                                     | 242 |
| dc_allow_rtl_pg .....                                                      | 243 |
| dc_allow_rtl_pg_to_analog_pins .....                                       | 244 |
| dc_allow_rtl_pg_to_signal_pins .....                                       | 245 |
| dc_shell_mode .....                                                        | 246 |
| dct_enable_track_auto_fill .....                                           | 247 |
| dct_enable_va_aware_ao_synthesis .....                                     | 248 |
| dct_maskshift_consistency_check .....                                      | 249 |
| dct_placement_ignore_scan .....                                            | 250 |
| dct_port_dont_snap_onto_tracks .....                                       | 251 |
| dct_preserve_all_preroutes .....                                           | 252 |

|                                                 |     |
|-------------------------------------------------|-----|
| dct_remove_invalid_bounds .....                 | 253 |
| ddc_allow_unknown_packed_commands .....         | 254 |
| de_enable_physical_flow .....                   | 255 |
| de_enable_upf_exploration .....                 | 256 |
| de_log_html_filename .....                      | 257 |
| de_log_redirect_enable .....                    | 258 |
| de_log_show_derived_ideal_nets .....            | 259 |
| de_rename_shell_name_to_dc_shell .....          | 260 |
| default_input_delay .....                       | 261 |
| default_name_rules .....                        | 262 |
| default_output_delay .....                      | 263 |
| default_port_connection_class .....             | 264 |
| default_schematic_options .....                 | 265 |
| design_attributes .....                         | 266 |
| designer .....                                  | 271 |
| dft_enable_mis_cells_decomposition .....        | 272 |
| die_area_attributes .....                       | 273 |
| disable_auto_time_borrow .....                  | 275 |
| disable_case_analysis .....                     | 276 |
| disable_library_transition_degradation .....    | 277 |
| disable_mdb_stop_points .....                   | 278 |
| disable_multicore_resource_checks .....         | 279 |
| do_operand_isolation .....                      | 280 |
| dont_bind_unused_pins_to_logic_constant .....   | 281 |
| dont_touch_nets_with_size_only_cells .....      | 282 |
| duplicate_ports .....                           | 284 |
| echo_include_commands .....                     | 285 |
| enable_bit_blasted_bus_linking .....            | 286 |
| enable_cell_based_verilog_reader .....          | 288 |
| enable_clock_to_data_analysis .....             | 289 |
| enable_enhanced_physical_multibit_banking ..... | 290 |
| enable_golden_upf .....                         | 291 |
| enable_instances_in_report_net .....            | 293 |
| enable_keep_signal .....                        | 294 |
| enable_keep_signal_dt_net .....                 | 296 |
| enable_nldm_timing_noise_signoff .....          | 298 |
| enable_page_mode .....                          | 300 |
| enable_phys_lib_during_elab .....               | 301 |
| enable_presynthesis_floorplanning .....         | 302 |
| enable_recovery_removal_arcs .....              | 303 |
| enable_rule_based_query .....                   | 304 |
| enable_slew_degradation .....                   | 305 |
| enable_special_level_shifter_naming .....       | 306 |
| estimate_io_latency .....                       | 307 |
| exit_delete_command_log_file .....              | 309 |

|                                                     |     |
|-----------------------------------------------------|-----|
| exit_delete_filename_log_file . . . . .             | 310 |
| extract_max_parallel_computations . . . . .         | 311 |
| fanin_fanout_trace_arcs . . . . .                   | 313 |
| filename_log_file . . . . .                         | 314 |
| find_allow_only_non_hier_ports . . . . .            | 315 |
| find Converts_name_lists . . . . .                  | 317 |
| find_ignore_case . . . . .                          | 318 |
| floorplan_data_attributes . . . . .                 | 319 |
| focalopt_power_critical_range . . . . .             | 321 |
| fsm_auto_inferring . . . . .                        | 323 |
| fsm_enable_state_minimization . . . . .             | 324 |
| fsm_export_formality_state_info . . . . .           | 325 |
| gen_bussing_exact_implicit . . . . .                | 326 |
| gen_cell_pin_name_separator . . . . .               | 327 |
| gen_create_netlist_busses . . . . .                 | 328 |
| gen_dont_show_single_bit_busses . . . . .           | 329 |
| gen_match_ripper_wire_widths . . . . .              | 330 |
| gen_max_compound_name_length . . . . .              | 331 |
| gen_max_ports_on_symbol_side . . . . .              | 332 |
| gen_open_name_postfix . . . . .                     | 333 |
| gen_open_name_prefix . . . . .                      | 334 |
| gen_show_created_busses . . . . .                   | 335 |
| gen_show_created_symbols . . . . .                  | 336 |
| gen_single_osc_per_name . . . . .                   | 337 |
| generic_symbol_library . . . . .                    | 338 |
| golden_upf_report_missing_objects . . . . .         | 339 |
| gui_analyze_rtl_logic_level_threshold . . . . .     | 341 |
| gui_analyze_rtl_paths . . . . .                     | 342 |
| gui_online_browser . . . . .                        | 343 |
| hdl_keep_licenses . . . . .                         | 344 |
| hdl_preferred_license . . . . .                     | 345 |
| hdlin_allow_unpacked_array_concat_on_port . . . . . | 346 |
| hdlin_always_fsm_complete . . . . .                 | 348 |
| hdlin_analyze_verbose_mode . . . . .                | 349 |
| hdlin_auto_save_templates . . . . .                 | 350 |
| hdlin_autoread_exclude_extensions . . . . .         | 351 |
| hdlin_autoread_sverilog_extensions . . . . .        | 352 |
| hdlin_autoread_verilog_extensions . . . . .         | 353 |
| hdlin_autoread_vhdl_extensions . . . . .            | 354 |
| hdlin_check_no_latch . . . . .                      | 355 |
| hdlin_elab_errors_deep . . . . .                    | 357 |
| hdlin_elaborate_black_box . . . . .                 | 359 |
| hdlin_elaborate_black_box_all_except . . . . .      | 360 |
| hdlin_enable_assertions . . . . .                   | 361 |
| hdlin_enable_configurations . . . . .               | 363 |

|                                                     |     |
|-----------------------------------------------------|-----|
| hdlin_enable_elaborate_ref_linking . . . . .        | 365 |
| hdlin_enable_elaborate_update . . . . .             | 366 |
| hdlin_enable_hier_map . . . . .                     | 367 |
| hdlin_enable_hier_naming . . . . .                  | 369 |
| hdlin_enable_ieee_1735_support . . . . .            | 370 |
| hdlin_enable_persistent_macros . . . . .            | 371 |
| hdlin_enable_relative_placement . . . . .           | 373 |
| hdlin_enable_rtldrc_info . . . . .                  | 374 |
| hdlin_enable_upf_compatible_naming . . . . .        | 375 |
| hdlin_failsafe_fsm . . . . .                        | 376 |
| hdlin_ff_always_async_set_reset . . . . .           | 377 |
| hdlin_ff_always_sync_set_reset . . . . .            | 378 |
| hdlin_field_naming_style . . . . .                  | 379 |
| hdlin_generate_naming_style . . . . .               | 380 |
| hdlin_generate_separator_style . . . . .            | 381 |
| hdlin_ignore_ghm_errors . . . . .                   | 382 |
| hdlin_infer_function_local_latches . . . . .        | 383 |
| hdlin_infer_local_sync_enable_only . . . . .        | 384 |
| hdlin_infer_multibit . . . . .                      | 385 |
| hdlin_infer_mux . . . . .                           | 386 |
| hdlin_interface_port_ABI . . . . .                  | 387 |
| hdlin_interface_port_downto . . . . .               | 389 |
| hdlin_intermediate_file_method . . . . .            | 390 |
| hdlin_keep_signal_name . . . . .                    | 392 |
| hdlin_latch_always_async_set_reset . . . . .        | 396 |
| hdlin_legacy_naming . . . . .                       | 397 |
| hdlin_module_arch_name_splitting . . . . .          | 398 |
| hdlin_module_name_limit . . . . .                   | 399 |
| hdlin_mux_for_array_read_sparseness_limit . . . . . | 400 |
| hdlin_mux_oversize_ratio . . . . .                  | 402 |
| hdlin_mux_rp_limit . . . . .                        | 404 |
| hdlin_mux_size_limit . . . . .                      | 405 |
| hdlin_mux_size_min . . . . .                        | 406 |
| hdlin_mux_size_only . . . . .                       | 407 |
| hdlin_netlist_unloaded_signals . . . . .            | 409 |
| hdlin_persistent_macros_filename . . . . .          | 410 |
| hdlin_preserve_sequential . . . . .                 | 412 |
| hdlin_presto_cell_name_prefix . . . . .             | 415 |
| hdlin_presto_net_name_prefix . . . . .              | 416 |
| hdlin_prohibit_nontri_multiple_drivers . . . . .    | 417 |
| hdlin_report_sequential_pruning . . . . .           | 418 |
| hdlin_reporting_level . . . . .                     | 419 |
| hdlin_shorten_long_module_name . . . . .            | 421 |
| hdlin_strict_verilog_reader . . . . .               | 422 |
| hdlin_subprogram_default_values . . . . .           | 423 |

|                                                            |     |
|------------------------------------------------------------|-----|
| hdlin_sv_blackbox_modules . . . . .                        | 424 |
| hdlin_sv_enable_rtl_attributes . . . . .                   | 426 |
| hdlin_sv_enforce_standalone_generate_blocks . . . . .      | 427 |
| hdlin_sv_interface_only_modules . . . . .                  | 428 |
| hdlin_sv_packages . . . . .                                | 429 |
| hdlin_sv_tokens . . . . .                                  | 431 |
| hdlin_sv_union_member_naming . . . . .                     | 432 |
| hdlin_sverilog_std . . . . .                               | 434 |
| hdlin_tic_tic_discards_whitespace . . . . .                | 435 |
| hdlin_unified_rtl_read . . . . .                           | 436 |
| hdlin_upcase_names . . . . .                               | 437 |
| hdlin_v2005_replication_semantics . . . . .                | 438 |
| hdlin_vcs_home . . . . .                                   | 440 |
| hdlin_verification_priority . . . . .                      | 441 |
| hdlin_vhdl93_concat . . . . .                              | 442 |
| hdlin_vhdl_mixed_language_instantiation . . . . .          | 443 |
| hdlin_vhdl_std . . . . .                                   | 444 |
| hdlin_vhdl_syntax_extensions . . . . .                     | 445 |
| hdlin_vrlg_std . . . . .                                   | 446 |
| hdlin_while_loop_iterations . . . . .                      | 447 |
| hdlout_internal_busses . . . . .                           | 448 |
| hier_dont_trace_ungroup . . . . .                          | 449 |
| high_fanout_net_pin_capacitance . . . . .                  | 450 |
| high_fanout_net_threshold . . . . .                        | 451 |
| hlo_resource_allocation . . . . .                          | 452 |
| html_log_enable . . . . .                                  | 454 |
| html_log_filename . . . . .                                | 455 |
| icc2_link_ddc_transfer . . . . .                           | 456 |
| icc2_link_processes_inherit_parent_process_group . . . . . | 457 |
| ignore_clock_input_delay_for_skew . . . . .                | 458 |
| ignore_tf_error . . . . .                                  | 459 |
| in_gui_session . . . . .                                   | 460 |
| initial_target_library . . . . .                           | 461 |
| insert_test_design_naming_style . . . . .                  | 462 |
| layer_attributes . . . . .                                 | 463 |
| lbo_cells_in_regions . . . . .                             | 468 |
| level_shifter_naming_prefix . . . . .                      | 469 |
| lib_cell_using_delay_from_ccs . . . . .                    | 470 |
| lib_pin_using_cap_from_ccs . . . . .                       | 471 |
| lib_use_thresholds_per_pin . . . . .                       | 472 |
| libgen_max_differences . . . . .                           | 474 |
| library_attributes . . . . .                               | 475 |
| library_cell_attributes . . . . .                          | 479 |
| libsetup_max_auto_opcond_message . . . . .                 | 481 |
| link_allow_design_mismatch . . . . .                       | 483 |

|                                                              |     |
|--------------------------------------------------------------|-----|
| link_allow_physical_variant_cells .....                      | 484 |
| link_allow_pin_name_synonym .....                            | 485 |
| link_allow_upf_design_mismatch .....                         | 486 |
| link_force_case .....                                        | 488 |
| link_library .....                                           | 489 |
| link_portname_allow_period_to_match_underscore .....         | 490 |
| link_portname_allow_square_bracket_to_match_underscore ..... | 492 |
| link_preserve_dangling_pins .....                            | 494 |
| logic_level_report_group_format .....                        | 495 |
| logic_level_report_summary_format .....                      | 497 |
| ltx_obstruction_type .....                                   | 499 |
| magnet_placement_disable_overlap .....                       | 500 |
| magnet_placement_fanout_limit .....                          | 501 |
| magnet_placement_stop_after_seq_cell .....                   | 502 |
| mcmm_high_capacity_effort_level .....                        | 503 |
| mux_auto_inferring_effort .....                              | 505 |
| mv_align_library_pg_pins .....                               | 506 |
| mv_allow_force_ls_with_iso_violations .....                  | 507 |
| mv_allow_ls_on_leaf_pin_boundary .....                       | 508 |
| mv_allow_ls_per_macro_fanout .....                           | 509 |
| mv_allow_pg_pin_reconnection .....                           | 510 |
| mv_allow_upf_cells_without_upf .....                         | 511 |
| mv_allow_va_beyond_core_area .....                           | 512 |
| mv_disable_voltage_area_aware_detour_routing .....           | 513 |
| mv_input_enforce_simple_names .....                          | 514 |
| mv_insert_level_shifters_on_ideal_nets .....                 | 515 |
| mv_make_primary_supply_available_for_always_on .....         | 516 |
| mv_mtcmos_detour_obstruction .....                           | 517 |
| mv_no_always_on_buffer_for_redundant_isolation .....         | 518 |
| mv_no_cells_at_default_va .....                              | 519 |
| mv_no_main_power_violations .....                            | 520 |
| mv_output_enforce_simple_names .....                         | 521 |
| mv_output_upf_line_indent .....                              | 522 |
| mv_output_upf_line_width .....                               | 523 |
| mv_skip_opcond_checking_for_unloaded_level_shifter .....     | 524 |
| mv_upf_enable_forward_bias_check .....                       | 525 |
| mv_upf_enable_forward_reverse_bias_check .....               | 526 |
| mv_upf_enable_reverse_bias_check .....                       | 527 |
| mv_upf_tracking .....                                        | 528 |
| mv_use_std_cell_for_isolation .....                          | 529 |
| mw_cell_name .....                                           | 530 |
| mw_design_library .....                                      | 531 |
| mw_disable_escape_char .....                                 | 532 |
| mw_hdl_bus_dir_for_undef_cell .....                          | 533 |
| mw_hdl_expand_cell_with_no_instance .....                    | 534 |

|                                                   |     |
|---------------------------------------------------|-----|
| mw_reference_library .....                        | 535 |
| mw_site_name_mapping .....                        | 536 |
| ndm_load_mol_routing_layers .....                 | 538 |
| net_attributes .....                              | 539 |
| net_auto_layer_promotion_max_utilization .....    | 541 |
| optimize_area_ignore_path_group_weights .....     | 542 |
| optimize_ndr_critical_range .....                 | 543 |
| optimize_ndr_max_nets .....                       | 544 |
| optimize_ndr_user_rule_names .....                | 545 |
| optimize_netlist_enable_state_reachability .....  | 546 |
| optimize_reg_add_path_groups .....                | 547 |
| optimize_via_ladder_critical_range .....          | 549 |
| optimize_via_ladder_net_length_threshold .....    | 550 |
| pdefout_diff_original .....                       | 551 |
| physical_bus_attributes .....                     | 552 |
| physical_lib_pin_attributes .....                 | 553 |
| physopt_area_critical_range .....                 | 555 |
| physopt_create_missing_physical_libcells .....    | 556 |
| physopt_enable_root_via_res_support .....         | 557 |
| physopt_enable_via_res_support .....              | 558 |
| physopt_hard_keepout_distance .....               | 559 |
| physopt_ignore_lpin_fanout .....                  | 560 |
| physopt_power_critical_range .....                | 561 |
| pin_attributes .....                              | 562 |
| placement_blockage_attributes .....               | 565 |
| placer_auto_timing_control .....                  | 568 |
| placer_buffering_aware .....                      | 569 |
| placer_channel_detect_mode .....                  | 570 |
| placer_cong_restruct .....                        | 571 |
| placer_congestion_effort .....                    | 572 |
| placer_disable_auto_bound_for_gated_clock .....   | 573 |
| placer_disable_macro_placement_timeout .....      | 574 |
| placer_dont_error_out_on_conflicting_bounds ..... | 575 |
| placer_enable_enhanced_router .....               | 576 |
| placer_enable_enhanced_soft_blockages .....       | 577 |
| placer_enable_redefined_blockage_behavior .....   | 578 |
| placer_enhanced_low_power_effort .....            | 579 |
| placer_gated_register_area_multiplier .....       | 580 |
| placer_max_allowed_timing_depth .....             | 581 |
| placer_max_cell_density_threshold .....           | 582 |
| placer_max_parallel_computations .....            | 583 |
| placer_reduce_high_density_regions .....          | 585 |
| placer_show_zrouteigr_output .....                | 586 |
| placer_tns_driven .....                           | 587 |
| placer_tns_driven_in_incremental_compile .....    | 588 |

|                                                            |     |
|------------------------------------------------------------|-----|
| placer_wide_cell_pg_strap_distance .....                   | 589 |
| placer_wide_cell_use_model .....                           | 590 |
| plan_group_attributes .....                                | 591 |
| port_attributes .....                                      | 597 |
| port_complement_naming_style .....                         | 602 |
| power_attributes .....                                     | 603 |
| power_cg_all_registers .....                               | 606 |
| power_cg_auto_identify .....                               | 607 |
| power_cg_balance_stages .....                              | 608 |
| power_cg_cell_naming_style .....                           | 609 |
| power_cg_derive_related_clock .....                        | 611 |
| power_cg_enable_alternative_algorithm .....                | 612 |
| power_cg_ext_feedback_loop .....                           | 613 |
| power_cg_flatten .....                                     | 614 |
| power_cg_gated_clock_net_naming_style .....                | 615 |
| power_cg_high_effort_enable_fanin_analysis .....           | 617 |
| power_cg_ignore_setup_condition .....                      | 618 |
| power_cg_inherit_timing_exceptions .....                   | 619 |
| power_cg_iscgs_enable .....                                | 620 |
| power_cg_module_naming_style .....                         | 621 |
| power_cg_permit_opposite_edge_icg .....                    | 623 |
| power_cg_physically_aware_cg .....                         | 624 |
| power_cg_print_enable_conditions .....                     | 626 |
| power_cg_print_enable_conditions_max_terms .....           | 627 |
| power_cg_reconfig_stages .....                             | 628 |
| power_clock_network_include_register_clock_pin_power ..... | 630 |
| power_default_static_probability .....                     | 631 |
| power_default_toggle_rate .....                            | 633 |
| power_default_toggle_rate_type .....                       | 635 |
| power_do_not_size_icg_cells .....                          | 637 |
| power_domain_attributes .....                              | 638 |
| power_enable_clock_scaling .....                           | 640 |
| power_enable_datapath_gating .....                         | 641 |
| power_enable_minpower .....                                | 642 |
| power_enable_one_pass_power_gating .....                   | 643 |
| power_enable_power_gating .....                            | 645 |
| power_fix_sdpd_annotation .....                            | 647 |
| power_fix_sdpd_annotation_verbose .....                    | 649 |
| power_hdlc_do_not_split_cg_cells .....                     | 650 |
| power_keep_license_after_power_commands .....              | 651 |
| power_lib2saif_rise_fall_pd .....                          | 652 |
| power_low_power_placement .....                            | 653 |
| power_min_internal_power_threshold .....                   | 654 |
| power_model_preference .....                               | 655 |
| power_opto_extra_high_dynamic_power_effort .....           | 656 |

|                                                              |     |
|--------------------------------------------------------------|-----|
| power_rclock_inputs_use_clocks_fanout . . . . .              | 657 |
| power_rclock_unrelated_use_fastest . . . . .                 | 658 |
| power_rclock_use_asynch_inputs . . . . .                     | 659 |
| power_remove_redundant_clock_gates . . . . .                 | 660 |
| power_report_separate_switching_power . . . . .              | 661 |
| power_same_switching_activity_on_connected_objects . . . . . | 662 |
| power_scale_internal_arc . . . . .                           | 663 |
| power_sdpd_message_tolerance . . . . .                       | 664 |
| power_switch_attributes . . . . .                            | 665 |
| preroute_opt_verbose . . . . .                               | 667 |
| preserve_collections_in_compile . . . . .                    | 669 |
| psynopt_density_limit . . . . .                              | 670 |
| psynopt_tns_high_effort . . . . .                            | 671 |
| query_objects_format . . . . .                               | 672 |
| rc_degrade_min_slew_when_rd_less_than_rnet . . . . .         | 673 |
| rc_driver_model_mode . . . . .                               | 674 |
| rc_input_threshold_pct_fall . . . . .                        | 675 |
| rc_input_threshold_pct_rise . . . . .                        | 677 |
| rc_noise_model_mode . . . . .                                | 679 |
| rc_output_threshold_pct_fall . . . . .                       | 680 |
| rc_output_threshold_pct_rise . . . . .                       | 682 |
| rc_receiver_model_mode . . . . .                             | 684 |
| rc_slew_derate_from_library . . . . .                        | 686 |
| rc_slew_lower_threshold_pct_fall . . . . .                   | 688 |
| rc_slew_lower_threshold_pct_rise . . . . .                   | 690 |
| rc_slew_upper_threshold_pct_fall . . . . .                   | 692 |
| rc_slew_upper_threshold_pct_rise . . . . .                   | 694 |
| read_db_lib_warnings . . . . .                               | 696 |
| read_only_attributes . . . . .                               | 697 |
| read_translate_msff . . . . .                                | 699 |
| reference_attributes . . . . .                               | 700 |
| register_duplicate . . . . .                                 | 702 |
| register_replication_naming_style . . . . .                  | 704 |
| remove_constant_register . . . . .                           | 705 |
| remove_unloaded_register . . . . .                           | 706 |
| report_capacitance_use_ccs_receiver_model . . . . .          | 707 |
| report_default_significant_digits . . . . .                  | 708 |
| report_timing_use_accurate_delay_symbol . . . . .            | 710 |
| rom_auto_inferring . . . . .                                 | 711 |
| route_guide_attributes . . . . .                             | 712 |
| route_guide_naming_style . . . . .                           | 716 |
| routing_corridor_attributes . . . . .                        | 717 |
| routing_corridor_shape_attributes . . . . .                  | 718 |
| rp_group_attributes . . . . .                                | 720 |
| rtl_load_resistance_factor . . . . .                         | 724 |

|                                                                       |     |
|-----------------------------------------------------------------------|-----|
| sdc_runtime_analysis_enable . . . . .                                 | 725 |
| sdc_runtime_analysis_log_file . . . . .                               | 727 |
| sdc_runtime_fixing_enable . . . . .                                   | 728 |
| sdc_runtime_hier_block_pins_timing_path_threshold . . . . .           | 729 |
| sdc_runtime_hier_block_pins_top_timing_paths . . . . .                | 730 |
| sdc_runtime_nets_missing_exceptions_fanout_threshold . . . . .        | 731 |
| sdc_runtime_paths_missing_inter_clock_constraints . . . . .           | 732 |
| sdc_runtime_port_clock_constraint_threshold . . . . .                 | 733 |
| sdc_runtime_tightly_constrained_path_group_slack_percentage . . . . . | 734 |
| sdc_runtime_tightly_constrained_same_clock_path_groups . . . . .      | 735 |
| sdc_runtime_top_fanout_nets_missing_exceptions . . . . .              | 736 |
| sdc_runtime_unused_clocks_threshold . . . . .                         | 737 |
| sdc_write_unambiguous_names . . . . .                                 | 738 |
| sdfout_allow_non_positive_constraints . . . . .                       | 739 |
| sdfout_min_fall_cell_delay . . . . .                                  | 740 |
| sdfout_min_fall_net_delay . . . . .                                   | 741 |
| sdfout_min_rise_cell_delay . . . . .                                  | 742 |
| sdfout_min_rise_net_delay . . . . .                                   | 743 |
| sdfout_time_scale . . . . .                                           | 744 |
| sdfout_top_instance_name . . . . .                                    | 745 |
| sdfout_write_to_output . . . . .                                      | 747 |
| search_path . . . . .                                                 | 748 |
| seqmap_prefer_registers_with_multibit_equivalent . . . . .            | 749 |
| sh_allow_tcl_with_set_app_var . . . . .                               | 750 |
| sh_allow_tcl_with_set_app_var_no_message_list . . . . .               | 751 |
| sh_arch . . . . .                                                     | 752 |
| sh_command_abbrev_mode . . . . .                                      | 753 |
| sh_command_abbrev_options . . . . .                                   | 754 |
| sh_command_log_file . . . . .                                         | 755 |
| sh_continue_on_error . . . . .                                        | 756 |
| sh_DEPRECATED_is_error . . . . .                                      | 757 |
| sh_dev_null . . . . .                                                 | 758 |
| sh_enable_stdout_redirect . . . . .                                   | 759 |
| sh_help_shows_group_overview . . . . .                                | 760 |
| sh_new_variable_message . . . . .                                     | 761 |
| sh_new_variable_message_in_proc . . . . .                             | 762 |
| sh_new_variable_message_in_script . . . . .                           | 763 |
| sh_OBSOLETE_is_error . . . . .                                        | 765 |
| sh_output_log_file . . . . .                                          | 766 |
| sh_product_version . . . . .                                          | 767 |
| sh_script_stop_severity . . . . .                                     | 768 |
| sh_source_emits_line_numbers . . . . .                                | 769 |
| sh_source_logging . . . . .                                           | 770 |
| sh_source_uses_search_path . . . . .                                  | 771 |
| sh_tcllib_app dirname . . . . .                                       | 772 |

|                                                           |     |
|-----------------------------------------------------------|-----|
| sh_user_man_path . . . . .                                | 773 |
| shape_attributes . . . . .                                | 774 |
| si_ccs_use_gate_level_simulation . . . . .                | 780 |
| si_max_parallel_computations . . . . .                    | 781 |
| si_xtalk_composite_aggr_noise_peak_ratio . . . . .        | 782 |
| si_xtalk_composite_aggr_quantile_high_pct . . . . .       | 783 |
| simplified_verification_mode . . . . .                    | 784 |
| simplified_verification_mode_allow_retiming . . . . .     | 786 |
| single_group_per_sheet . . . . .                          | 787 |
| site_info_file . . . . .                                  | 788 |
| site_row_attributes . . . . .                             | 789 |
| sort_outputs . . . . .                                    | 792 |
| spg_auto_ndr_net_length_threshold . . . . .               | 793 |
| spg_congestion_placement_in_incremental_compile . . . . . | 794 |
| spg_enable_multithreaded_zroute . . . . .                 | 795 |
| spg_enable_via_ladder_opto . . . . .                      | 796 |
| spg_enable_zroute_layer_promotion . . . . .               | 797 |
| spg_enhanced_timing_model . . . . .                       | 798 |
| spg_high_effort_mux_area_structuring . . . . .            | 799 |
| spg_icc2_rc_correlation . . . . .                         | 800 |
| spg_place_enable_precluster . . . . .                     | 801 |
| ssf_current_version . . . . .                             | 802 |
| ssf_supported_versions . . . . .                          | 803 |
| supply_net_attributes . . . . .                           | 804 |
| supply_port_attributes . . . . .                          | 806 |
| suppress_errors . . . . .                                 | 808 |
| symbol_library . . . . .                                  | 809 |
| synlib_abort_wo_dw_license . . . . .                      | 810 |
| synlib_dont_get_license . . . . .                         | 811 |
| synlib_enable_analyze_dw_power . . . . .                  | 812 |
| synlib_hiis_force_on_cells . . . . .                      | 813 |
| synlib_iis_use_netlist . . . . .                          | 815 |
| synlib_preferred_ff_chains . . . . .                      | 816 |
| synlib_preferred_ffs . . . . .                            | 818 |
| synlib_wait_for_design_license . . . . .                  | 819 |
| synopsys_program_name . . . . .                           | 820 |
| synopsys_root . . . . .                                   | 821 |
| synthetic_library . . . . .                               | 822 |
| target_library . . . . .                                  | 823 |
| template_naming_style . . . . .                           | 824 |
| template_parameter_style . . . . .                        | 825 |
| template_separator_style . . . . .                        | 827 |
| terminal_attributes . . . . .                             | 829 |
| test_allow_internal_pins_in_hierarchical_flow . . . . .   | 835 |
| test_ate_sync_cycles . . . . .                            | 836 |

|                                                                     |     |
|---------------------------------------------------------------------|-----|
| test_avoid_control_register_of_icg_in_scan_chain_head .....         | 837 |
| test_bsd_dead_cycle_after_update_dr .....                           | 838 |
| test_bsd_default_bidir_delay .....                                  | 839 |
| test_bsd_default_delay .....                                        | 841 |
| test_bsd_default_strobe .....                                       | 842 |
| test_bsd_default_strobe_width .....                                 | 843 |
| test_bsd_input_ac_parametrics .....                                 | 844 |
| test_bsd_make_private_instructions_public .....                     | 845 |
| test_bsd_manufacturer_id .....                                      | 847 |
| test_bsd_new_output_parametrics .....                               | 848 |
| test_bsd_optimize_control_cell .....                                | 850 |
| test_bsd_part_number .....                                          | 851 |
| test_bsd_synthesis_gated_tck .....                                  | 852 |
| test_bsd_version_number .....                                       | 854 |
| test_bsdl_default_suffix_name .....                                 | 855 |
| test_bsdl_max_line_length .....                                     | 856 |
| test_cc_ir_masked_bits .....                                        | 857 |
| test_cc_ir_value_of_masked_bits .....                               | 858 |
| test_clock_port_naming_style .....                                  | 859 |
| test_core_wrap_sync_ctl_segment_length .....                        | 860 |
| test_core_wrap_use_sync_ctl_segment_length_for_fanout_check .....   | 862 |
| test_count_occ_chain_in_chain_count .....                           | 863 |
| test_dedicated_clock_chain_clock .....                              | 864 |
| test_dedicated_subdesign_scan_outs .....                            | 865 |
| test_default_bidir_delay .....                                      | 866 |
| test_default_delay .....                                            | 868 |
| test_default_period .....                                           | 869 |
| test_default_strobe .....                                           | 870 |
| test_default_strobe_width .....                                     | 871 |
| test_disable_enhanced_dft_drc_reporting .....                       | 872 |
| test_disable_find_best_scan_out .....                               | 873 |
| test_dont_fix_constraint_violations .....                           | 874 |
| test_enable_capture_checks .....                                    | 875 |
| test_enable_codec_sharing .....                                     | 876 |
| test_enable_retiming_flops_driven_by_direct_scan_clock_driver ..... | 877 |
| test_enable_scan_reordering_in_compile_incremental .....            | 878 |
| test_fast_feedthrough_analysis .....                                | 880 |
| test_icg_n_ref_for_dft .....                                        | 882 |
| test_icg_p_ref_for_dft .....                                        | 883 |
| test_infer_slave_clock_pulse_after_capture .....                    | 884 |
| test_input_wrapper_chain_naming_style .....                         | 885 |
| test_isolate_hier_scan_out .....                                    | 886 |
| test_keep_connected_scan_en .....                                   | 887 |
| test_mode_port_inverted_naming_style .....                          | 889 |
| test_mode_port_naming_style .....                                   | 890 |

|                                                                   |     |
|-------------------------------------------------------------------|-----|
| test_mux_constant_si . . . . .                                    | 891 |
| test_mux_constant_so . . . . .                                    | 892 |
| test_non_scan_clock_port_naming_style . . . . .                   | 893 |
| test_occ_insert_clock_gating_cells . . . . .                      | 894 |
| test_output_wrapper_chain_naming_style . . . . .                  | 895 |
| test_preview_scan_shows_cell_types . . . . .                      | 896 |
| test_rtldrc_latch_check_style . . . . .                           | 897 |
| test_scan_chain_naming_style . . . . .                            | 898 |
| test_scan_clock_a_port_naming_style . . . . .                     | 899 |
| test_scan_clock_b_port_naming_style . . . . .                     | 900 |
| test_scan_clock_port_naming_style . . . . .                       | 901 |
| test_scan_enable_inverted_port_naming_style . . . . .             | 902 |
| test_scan_enable_port_naming_style . . . . .                      | 903 |
| test_scan_in_port_naming_style . . . . .                          | 904 |
| test_scan_link_so_lockup_key . . . . .                            | 905 |
| test_scan_link_wire_key . . . . .                                 | 906 |
| test_scan_out_port_naming_style . . . . .                         | 907 |
| test_scan_segment_key . . . . .                                   | 908 |
| test_scan_true_key . . . . .                                      | 909 |
| test_scandef_stop_skip_last_segment_with_scanout_lockup . . . . . | 910 |
| test_serialize_put_fsm_clock_output . . . . .                     | 911 |
| test_set_svf_print_exclude_existing_dft_se_alike . . . . .        | 912 |
| test_setup_additional_clock_pulse . . . . .                       | 913 |
| test_shared_codec_io_architecture . . . . .                       | 914 |
| test_simulation_library . . . . .                                 | 915 |
| test_soc_core_wrap_allow_multibit_ioregs . . . . .                | 917 |
| test_stil_max_line_length . . . . .                               | 918 |
| test_suppress_toggling_instance_name_prefix . . . . .             | 919 |
| test_sync_occ_1x_period . . . . .                                 | 920 |
| test_tp_enable_logic_type . . . . .                               | 921 |
| test_user_defined_instruction_naming_style . . . . .              | 923 |
| test_user_test_data_register_naming_style . . . . .               | 924 |
| test_validate_test_model_connectivity . . . . .                   | 925 |
| test_wrapper_chain_naming_style . . . . .                         | 926 |
| test_wrapper_new_wrp_clock_timing . . . . .                       | 927 |
| test_wrp_new_power_domain_aware_dw_insertion_flow . . . . .       | 928 |
| text_attributes . . . . .                                         | 929 |
| text_editor_command . . . . .                                     | 933 |
| text_print_command . . . . .                                      | 934 |
| tieoff_hierarchy_opt . . . . .                                    | 935 |
| tieoff_hierarchy_opt_keep_driver . . . . .                        | 936 |
| timing_check_defaults . . . . .                                   | 937 |
| timing_clock_gating_propagate_enable . . . . .                    | 939 |
| timing_clock_reconvergence_pessimism . . . . .                    | 940 |
| timing_consider_internal_startpoints . . . . .                    | 941 |

|                                                         |     |
|---------------------------------------------------------|-----|
| timing_crpr_remove_clock_to_data_crp .....              | 942 |
| timing_crpr_remove_muxed_clock_crp .....                | 943 |
| timing_crpr_threshold_ps .....                          | 944 |
| timing_disable_cond_default_arcs .....                  | 945 |
| timing_disable_recovery_removal_checks .....            | 946 |
| timing_dont_traverse_pg_net .....                       | 947 |
| timing_early_launch_at_borrowing_latches .....          | 948 |
| timing_edge_specific_source_latency .....               | 950 |
| timing_enable_constraint_variation .....                | 951 |
| timing_enable_multiple_clocks_per_reg .....             | 952 |
| timing_enable_non_sequential_checks .....               | 953 |
| timing_enable_normalized_slack .....                    | 954 |
| timing_enable_slack_distribution .....                  | 955 |
| timing_enable_through_paths .....                       | 956 |
| timing_gclock_source_network_num_master_registers ..... | 958 |
| timing_ignore_paths_within_block_abstraction .....      | 959 |
| timing_input_port_default_clock .....                   | 960 |
| timing_library_derate_is_scenario_specific .....        | 961 |
| timing_library_max_cap_from_lookup_table .....          | 965 |
| timing_max_normalization_cycles .....                   | 966 |
| timing_max_parallel_computations .....                  | 967 |
| timing_ocvm_precedence_compatibility .....              | 969 |
| timing_pocvm_corner_sigma .....                         | 971 |
| timing_pocvm_enable_analysis .....                      | 972 |
| timing_remove_clock_reconvergence_pessimism .....       | 973 |
| timing_report_attributes .....                          | 974 |
| timing_report_fast_mode .....                           | 975 |
| timing_report_union_tns .....                           | 976 |
| timing_save_library_derate .....                        | 977 |
| timing_scgc_override_library_setup_hold .....           | 978 |
| timing_self_loops_no_skew .....                         | 980 |
| timing_separate_clock_gating_group .....                | 981 |
| timing_through_path_max_segments .....                  | 982 |
| timing_use_ceff_for_drc .....                           | 983 |
| timing_use_clock_specific_transition .....              | 984 |
| timing_use_driver_arc_transition_at_clock_source .....  | 985 |
| timing_use_enhanced_capacitance_modeling .....          | 986 |
| tio_allow_mim_optimization .....                        | 987 |
| tio_preload_block_site_rows .....                       | 988 |
| tio_preserve_routes_for_block .....                     | 989 |
| track_attributes .....                                  | 990 |
| ungroup_keep_original_design .....                      | 993 |
| uniquify_keep_original_design .....                     | 994 |
| uniquify_naming_style .....                             | 995 |
| upf_add_power_state_21_syntax .....                     | 996 |

|                                                                |      |
|----------------------------------------------------------------|------|
| upf_allow_DD_primary_with_supply_sets . . . . .                | 997  |
| upf_allow_is_isolated_output_check . . . . .                   | 998  |
| upf_allow_iso_on_dont_touch_nets . . . . .                     | 999  |
| upf_allow_power_gating_cell_for_retention . . . . .            | 1000 |
| upf_allow_refer_before_define . . . . .                        | 1001 |
| upf_apply_retention_attribute_on_non_retention_macro . . . . . | 1003 |
| upf_auto_iso_clamp_value . . . . .                             | 1005 |
| upf_auto_iso_enable_source . . . . .                           | 1006 |
| upf_auto_iso_isolation_sense . . . . .                         | 1007 |
| upf_block_partition . . . . .                                  | 1008 |
| upf_charz_allow_port_punch . . . . .                           | 1009 |
| upf_charz_enable_domain_rescoping . . . . .                    | 1010 |
| upf_charz_enable_supply_port_punching . . . . .                | 1012 |
| upf_charz_max_srsn_messages . . . . .                          | 1013 |
| upf_check_bias_supply_connections . . . . .                    | 1014 |
| upf_create_implicit_supply_sets . . . . .                      | 1015 |
| upf_derive_ao_supply_on_exception_conns . . . . .              | 1016 |
| upf_disable_b2b_iso_nor_optimization_strategies . . . . .      | 1017 |
| upf_drop_conflict_retention_constraint . . . . .               | 1019 |
| upf_enable_legacy_block . . . . .                              | 1021 |
| upf_enable_relaxed_charz . . . . .                             | 1022 |
| upf_extension . . . . .                                        | 1023 |
| upf_generate_pm_cell_html . . . . .                            | 1024 |
| upf_imvc_no_remap_iso . . . . .                                | 1025 |
| upf_infer_complex_retention_cells . . . . .                    | 1026 |
| upf_iso_filter_elements_with_applies_to . . . . .              | 1028 |
| upf_iso_map_exclude_zpr_clamp_lib_cells . . . . .              | 1029 |
| upf_isolation_enable_relax_self_dependency_check . . . . .     | 1030 |
| upf_isols_allow_instances_in_elements . . . . .                | 1031 |
| upf_levshi_on_constraint_only . . . . .                        | 1032 |
| upf_ls_strategy_in_inst_name . . . . .                         | 1033 |
| upf_name_map . . . . .                                         | 1034 |
| upf_nor_iso_macro_allow_enable_supply_check . . . . .          | 1036 |
| upf_pm_data_net_force_scalar . . . . .                         | 1037 |
| upf_power_model_library . . . . .                              | 1038 |
| upf_power_model_search_path . . . . .                          | 1039 |
| upf_preserve_logic_in_boolean_expr . . . . .                   | 1040 |
| upf_print_voltages_with_states . . . . .                       | 1041 |
| upf_proceed_on_bias_rail_order_error . . . . .                 | 1042 |
| upf_relax_target_library_subset_for_pm_cells . . . . .         | 1043 |
| upf_report_isolation_matching . . . . .                        | 1045 |
| upf_skip_ao_check_for_els_input . . . . .                      | 1046 |
| upf_skip_retention_on_dft_cells . . . . .                      | 1047 |
| upf_suppress_etm_model_checking . . . . .                      | 1049 |
| upf_suppress_message_in_black_box . . . . .                    | 1050 |

|                                                   |      |
|---------------------------------------------------|------|
| upf_suppress_message_in_etm . . . . .             | 1052 |
| upf_use_driver_receiver_for_io_voltages . . . . . | 1054 |
| upf_write_only_rtlpg_to_pg_netlist . . . . .      | 1055 |
| use_port_name_for_osc8 . . . . .                  | 1056 |
| vao_feedthrough_module_name_prefix . . . . .      | 1057 |
| verbose_messages . . . . .                        | 1058 |
| verilogout_equation . . . . .                     | 1059 |
| verilogout_higher_designs_first . . . . .         | 1060 |
| verilogout_ignore_case . . . . .                  | 1061 |
| verilogout_include_files . . . . .                | 1062 |
| verilogout_indirect inout_connection . . . . .    | 1063 |
| verilogout_inout_is_in . . . . .                  | 1064 |
| verilogout_no_tri . . . . .                       | 1065 |
| verilogout_show_unconnected_pins . . . . .        | 1066 |
| verilogout_single_bit . . . . .                   | 1067 |
| verilogout_unconnected_prefix . . . . .           | 1068 |
| vhdlout_bit_type . . . . .                        | 1069 |
| vhdlout_bit_vector_type . . . . .                 | 1070 |
| vhdlout_dont_create_dummy_nets . . . . .          | 1071 |
| vhdlout_equations . . . . .                       | 1072 |
| vhdlout_follow_vector_direction . . . . .         | 1073 |
| vhdlout_local_attributes . . . . .                | 1074 |
| vhdlout_lower_design_vector . . . . .             | 1075 |
| vhdlout_one_name . . . . .                        | 1076 |
| vhdlout_package_naming_style . . . . .            | 1077 |
| vhdlout_preserve_hierarchical_types . . . . .     | 1078 |
| vhdlout_separate_scan_in . . . . .                | 1080 |
| vhdlout_single_bit . . . . .                      | 1081 |
| vhdlout_target_simulator . . . . .                | 1083 |
| vhdlout_three_state_name . . . . .                | 1084 |
| vhdlout_three_state_res_func . . . . .            | 1085 |
| vhdlout_top_configuration_arch_name . . . . .     | 1086 |
| vhdlout_top_configuration_entity_name . . . . .   | 1087 |
| vhdlout_top_configuration_name . . . . .          | 1088 |
| vhdlout_top_design_vector . . . . .               | 1089 |
| vhdlout_unconnected_pin_prefix . . . . .          | 1090 |
| vhdlout_unknown_name . . . . .                    | 1091 |
| vhdlout_upcase . . . . .                          | 1092 |
| vhdlout_use_packages . . . . .                    | 1093 |
| vhdlout_wired_and_res_func . . . . .              | 1095 |
| vhdlout_wired_or_res_func . . . . .               | 1096 |
| vhdlout_write_architecture . . . . .              | 1097 |
| vhdlout_write_components . . . . .                | 1098 |
| vhdlout_write_entity . . . . .                    | 1099 |
| vhdlout_write_top_configuration . . . . .         | 1100 |

|                                                  |      |
|--------------------------------------------------|------|
| vhdlout_zero_name . . . . .                      | 1102 |
| via_attributes . . . . .                         | 1103 |
| via_region_attributes . . . . .                  | 1110 |
| view_analyze_file_suffix . . . . .               | 1113 |
| view_arch_types . . . . .                        | 1114 |
| view_background . . . . .                        | 1115 |
| view_cache_images . . . . .                      | 1116 |
| view_command_log_file . . . . .                  | 1117 |
| view_command_win_max_lines . . . . .             | 1118 |
| view_dialogs_modal . . . . .                     | 1119 |
| view_disable_cursor_warping . . . . .            | 1120 |
| view_disable_error_windows . . . . .             | 1121 |
| view_disable_output . . . . .                    | 1122 |
| view_error_window_count . . . . .                | 1123 |
| view_execute_script_suffix . . . . .             | 1124 |
| view_info_search_cmd . . . . .                   | 1125 |
| view_log_file . . . . .                          | 1126 |
| view_on_line_doc_cmd . . . . .                   | 1127 |
| view_read_file_suffix . . . . .                  | 1128 |
| view_script_submenu_items . . . . .              | 1129 |
| view_set_selecting_color . . . . .               | 1130 |
| view_tools_menu_items . . . . .                  | 1131 |
| view_use_small_cursor . . . . .                  | 1132 |
| view_use_x_routines . . . . .                    | 1133 |
| view_write_file_suffix . . . . .                 | 1134 |
| voltage_area_attributes . . . . .                | 1135 |
| wildcards . . . . .                              | 1139 |
| writeConverted_tf_syntax . . . . .               | 1141 |
| writeName_nets_same_as_ports . . . . .           | 1142 |
| writeSdc_output_lumped_net_capacitance . . . . . | 1143 |
| writeSdc_output_net_resistance . . . . .         | 1144 |
| writeTest_formats . . . . .                      | 1145 |
| writeTest_include_scan_cell_info . . . . .       | 1146 |
| writeTest_input_dont_care_value . . . . .        | 1147 |
| writeTest_max_cycles . . . . .                   | 1148 |
| writeTest_max_scan_patterns . . . . .            | 1149 |
| writeTest_pattern_set_naming_style . . . . .     | 1150 |
| writeTest_round_timing_values . . . . .          | 1151 |
| writeTest_scan_check_file_naming_style . . . . . | 1152 |
| writeTest_vector_file_naming_style . . . . .     | 1153 |
| writeTest_vhdlout . . . . .                      | 1154 |
| x11_set_cursor_background . . . . .              | 1155 |
| x11_set_cursor_foreground . . . . .              | 1156 |
| x11_set_cursor_number . . . . .                  | 1157 |
| xt_filter_logic_constant_aggressors . . . . .    | 1158 |

|                                     |      |
|-------------------------------------|------|
| xterm_executable .....              | 1159 |
| zrt_max_parallel_computations ..... | 1160 |

---

## DW\_lp\_op\_iso\_mode

Specify the datapath gating style for instances of DesignWare low power components that have op\_iso\_mode parameters.

---

### TYPE

list

---

### DEFAULT

NONE

---

### DESCRIPTION

This variable specifies the datapath gating style inside a low power DesignWare component that has 'op\_iso\_mode' parameter.

By default, components that have a 'op\_iso\_mode' parameter have its value set to '0' which allows the 'DW\_lp\_op\_iso\_mode' variable to control the datapath gating style.

There are 4 possible values for DW\_lp\_op\_iso\_mode: NONE, adaptive, AND, OR. When the value is set to 'NONE', there is no datapath gating happening in the design; When the value is set to 'adaptive', preferred gating style. 'and' or 'or' depending on component. When the value is set to 'AND', gating style is 'and'; When the value is set to 'OR', gating style is 'or';

Setting the 'op\_iso\_mode' parameter to a value other than the default value of '0' (zero) on an instance allows the RTL source code to override the the value set by the 'DW\_lp\_op\_iso\_mode' variable.

The op\_iso\_mode parameter inside a DesignWare component has 5 possible values: 0: apply Design Compiler variable 'DW\_lp\_op\_iso\_mode' (default value) 1: 'none' (overrides 'DW\_lp\_op\_iso\_mode' setting) 2: 'and' (overrides 'DW\_lp\_op\_iso\_mode' setting) 3: 'or' (overrides 'DW\_lp\_op\_iso\_mode' setting) 4: preferred gating style. 'and' or 'or' depending on component (overrides 'DW\_lp\_op\_iso\_mode' setting)

Use the following command to determine the current value of the variable:

```
prompt> printvar DW_lp_op_iso_mode\f>
```

---

### SEE ALSO

---

# MasterInstance

---

## TYPE

string

---

## DESCRIPTION

If a design has multiple instances, one way to resolve the multiple instances before compiling (when using Automated Chip Synthesis) is to select a master instance. Selecting a master instance is similar to using the **compile-dont\_touch** method of resolving instances. The master instance is compiled and used for all of the instances referencing that design.

Use the **sub\_designs\_of** command to determine if your design contains multiple instances of any subdesign. Use the **sub\_instances\_of** command to identify the multiple instances.

Use the **set\_attribute** command to set the **MasterInstance** attribute on the instance you want to use as the master instance.

You can also resolve multiple instances by uniquifying or ungrouping.

---

## SEE ALSO

**sub\_designs\_of(2)**  
**sub\_instances\_of(2)**  
**ungroup(2)**  
**uniquify(2)**

---

## abstraction\_enable\_power\_calculation

Perform power calculations on a design that is to be used as an abstract block.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

The **create\_block\_abstraction** command processes the block, creates the abstraction information and annotates it on the design in memory. By default, **create\_block\_abstraction** command invoke the power calculation during its operation. Subsequent power reporting commands at top level can report power consumption correctly.

Power consumption of the block is calculated during block abstraction. The power data are stored as attributes on the abstract block and they are used by the **report\_power** command during the final assembly step of the entire chip. Thus, the **report\_power** command is able to report more accurate power consumption for the designs with abstract blocks.

The **abstraction\_enable\_power\_calculation** variable instructs the **create\_block\_abstraction** command to enable or disable the power calculation.

The **abstraction\_enable\_power\_calculation** variable is on (**true**) by default. If a power license is not available, the power calculation step is disrupted.

Setting this variable as false does not check for power license availability and power calculation step is not invoked.

---

### SEE ALSO

`create_block_abstraction(2)`  
`report_power(2)`

---

## abstraction\_ignore\_percentage

Specifies a threshold for the percentage of total registers in the transitive fanout of an input port, beyond which the port is to be ignored when identifying interface logic.

---

### TYPE

float

---

### DEFAULT

25

---

### DESCRIPTION

The value you specify for the **abstraction\_ignore\_percentage** variable defines a minimum threshold for the percentage of the total registers in the transitive fanout of an input port, beyond which the tool is to ignore the port when identifying interface logic. The default is 25.

The tool automatically ignores ports if the ports fan out to a percentage of total registers in the design that is greater than or equal to the value you specify for this variable.

For a discussion about creating block abstractions and related commands, see the man page for the **create\_block\_abstraction** command.

To see the current value of this variable, type

```
prompt> printvar abstraction_ignore_percentage
```

---

### SEE ALSO

[create\\_block\\_abstraction\(2\)](#)

---

## access\_internal\_pins

Controls access of internal pins.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

system\_variables

---

### DESCRIPTION

The **access\_internal\_pins** variable controls your access to internal pins. Internal pins are related to the internal design inside a library cell.

When the **access\_internal\_pins** variable is set to true, you can query internal pins using the **get\_pins** command and set attributes or constraints on the internal pins.

---

### SEE ALSO

[get\\_pins\(2\)](#)

---

## acs\_area\_report\_suffix

Specifies the suffix for area reports generated during the automated compile process.

---

### TYPE

string

---

### DEFAULT

area in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

Specifies the suffix for area reports generated during the automated compile process. For use in dc\_shell-t (Tcl mode of dc\_shell) only. The default is *area*.

Unless you specify the **-no\_reports** option, the compile scripts generated by the **write\_compile\_script** command include a command to generate an area report. The area report is placed in a file called *passn/reports/design.suffix*, where *suffix* is the value of the **acs\_area\_report\_suffix** variable.

To determine the current value of this variable, type **printvar acs\_area\_report\_suffix**.

---

### SEE ALSO

[write\\_compile\\_script\(2\)](#)

---

## acs\_budgeted\_cstr\_suffix

Specifies the suffix for constraint files generated by the **derive\_partition\_budgets** command.

---

### TYPE

string

---

### DEFAULT

con in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

Specifies the suffix for constraint files generated by the **derive\_partition\_budgets** command. For use in dc\_shell-t (Tcl mode of dc\_shell) only.

The **derive\_partition\_budgets** command generates a constraint file for each compile partition. The generated constraint files are named *passn/constraints/design.suffix*, where *suffix* is the value of the **acs\_budgeted\_cstr\_suffix** variable.

To determine the current value of this variable, type **printvar acs\_budgeted\_cstr\_suffix**.

---

### SEE ALSO

# acs\_compile\_attributes

Customizes the Automated Chip Synthesis compile strategy.

## DESCRIPTION

Automated Chip Synthesis provides attributes that can customize the compile strategy. To set these attributes, use the **set\_attribute** command to set the attribute on the reference design for the compile partition (or on the top-level design).

Each chip-level compile command (acs\_compile\_design, acs\_refine\_design, and acs\_recompile\_design) performs a two-step compile. The acs\_compile\_design and acs\_recompile\_design commands perform a full compile followed by a boundary compile. The acs\_refine\_design command performs an incremental compile followed by a boundary compile. The Automated Chip Synthesis compile attributes control both the effort and the strategy used in each of the steps.

These attributes affect the compile scripts generated by the **write\_compile\_script** command (and therefore the compile scripts generated by the chip-level compile commands). Some attributes add commands to the script before the compile command; others modify the compile command options.

Automated Chip Synthesis ignores these compile attributes if a custom compile strategy or custom compile script exists in the directory defined for the user\_compile\_strategy\_script or user\_override\_script directories (default directory is \$acs\_work\_dir/scripts/dest\_dir).

The following attributes control the effort used in each compile step (full, incremental, and boundary):

- FullCompile  
Valid values are none, low, medium, and high.  
Default value is medium.
- IncrementalCompile  
Valid values are none, low, medium, and high.  
Default value is high.
- BoundaryCompile  
Valid values are none, low, medium, high, and top.  
Default value is top.

The following attributes modify the compile strategy for each compile step:

- OptimizationPriorities (all modes) Valid values are area, area\_timing, timing, and timing\_area. Default value is timing\_area.
- CanFlatten (full compile mode only) Valid values are true and false. Default value is false.
- CompileVerify (full and incremental compile modes only) Valid values are true and false. Default value is false.
- HasArithmetic (full compile mode only) Valid values are true and false. Default value is false. (Deprecated: You will get better QoR for datapathes with just UltraOptimization enabled.)
- PartitionDP (full compile mode only) Valid values are duplicate, dont\_split and false. Default value is false. (Deprecated: You will get better QoR for datapathes with just UltraOptimization enabled.)
- AutoUngroup (full compile mode only) This is a composite attribute with one string value with the syntax: <mode> [<numCells>] Valid values for the required mode are area, delay and false. Default value is false. Valid values for the optional numCells are integer numbers >0. Default value is unset.
- MaxArea (full and incremental compile modes only) Valid values are floating point numbers greater than or equal to 0.0. Default value is 0.0.

- `PreserveBoundaries` (full and incremental compile modes only) Valid values are true and false. Default value is true.
- `TestReadyCompile` (full and incremental compile modes only) Valid values are true and false. Default value is false.
- `UltraOptimization` (all compile modes) Valid values are true and false. Default value is false. For details about the impact of each attribute on the compile script, see the *Automated Chip Synthesis User Guide*.

---

## SEE ALSO

`compile(2)`  
`get_license(2)`  
`remove_license(2)`  
`set_cost_priority(2)`  
`set_flatten(2)`  
`set_max_area(2)`  
`set_minimize_tree_delay(2)`  
`set_resource_allocation(2)`  
`set_resource_implementation(2)`  
`set_structure(2)`  
`transform_csa(2)`  
`uniquify(2)`  
`write_compile_script(2)`  
`compile_auto_ungroup_area_num_cells(3)`  
`compile_auto_ungroup_delay_num_cells(3)`  
`compile_auto_ungroup_override_wlm(3)`  
`compile_implementation_selection(3)`  
`compile_limit_down_sizing(3)`  
`compile_map_low_drive(3)`  
`compile_new_Boolean_structure(3)`  
`compile_top_all_paths(3)`  
`current_design(3)`

---

## acs\_compile\_script\_suffix

Specifies the default suffix for script files generated by the **write\_compile\_script** command, sourced in the makefile generated by the **write\_makefile** command, and located by the **report\_pass\_data** command.

---

### TYPE

string

---

### DEFAULT

autoscr

---

### DESCRIPTION

Specifies the default suffix for script files generated by the **write\_compile\_script** command, sourced in the makefile generated by the **write\_makefile** command, and located by the **report\_pass\_data** command. For use in dc\_shell-t (Tcl mode of dc\_shell) only.

The script is placed in a file called *passn/scripts/design.suffix*, where *suffix* is the value of the **acs\_compile\_script\_suffix** variable.

To determine the current value of this variable, type **printvar acs\_compile\_script\_suffix**.

---

### SEE ALSO

[report\\_pass\\_data\(2\)](#)  
[write\\_compile\\_script\(2\)](#)  
[write\\_makefile\(2\)](#)

---

## acs\_constraint\_file\_suffix

Specifies the default suffix for constraint files generated by **write\_partition\_constraints** during the automated compile process.

---

### TYPE

string

---

### DEFAULT

con in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

Specifies the default suffix for constraint files generated by **write\_partition\_constraints** during the automated compile process. For use in dc\_shell-t (Tcl mode of dc\_shell) only.

The constraints are placed in a file called *passn/constraints/design.suffix*, where *suffix* is the value of the **acs\_constraint\_file\_suffix** variable.

To determine the current value of this variable, type **printvar acs\_constraint\_file\_suffix**.

---

### SEE ALSO

[write\\_partition\\_constraints\(2\)](#)

---

## acs\_cstr\_report\_suffix

Specifies the default suffix for constraint reports generated during the automated compile process.

---

### TYPE

string

---

### DEFAULT

cstr in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Specifies the default suffix for constraint reports generated during the automated compile process. For use in dc\_shell-t (Tcl mode of dc\_shell) only.

The constraint report is placed in a file called *passn/reports/design.suffix*, where *suffix* is the value of the **acs\_cstr\_report\_suffix** variable.

To determine the current value of this variable, type **printvar acs\_cstr\_report\_suffix**.

---

### SEE ALSO

[compile\(2\)](#)

---

## acs\_db\_suffix

Specifies the default suffix for .db files that are read or written during the automated compile process.

---

### TYPE

string

---

### DEFAULT

db in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Specifies the default suffix for .db files that are read or written during the automated compile process. For use in dc\_shell-t (Tcl mode) of dc\_shell only.

The .db is placed in files called passn/db/pre\_compile/*design.suffix* and passn/db/post\_compile/*design.suffix*, where *suffix* is the value of the **acs\_db\_suffix** variable.

To determine the current value of this variable, type **printvar acs\_db\_suffix**.

---

### SEE ALSO

[read\\_partition\(2\)](#)  
[report\\_pass\\_data\(2\)](#)  
[write\\_compile\\_script\(2\)](#)  
[write\\_makefile\(2\)](#)  
[write\\_partition\(2\)](#)

---

## acs\_global\_user\_compile\_strategy\_script

Specifies the base file name for the user-defined default compile strategy.

---

### TYPE

string

---

### DEFAULT

default.compile in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Specifies the base file name for the user-defined default compile strategy. For use in dc\_shell-t (Tcl mode of dc\_shell) only. A compile strategy is a script that includes commands to set the **compile** variables, set the **compile** attributes, and run the **compile** command.

Before generating a partition compile script, Automated Chip Synthesis looks for a user-defined partition compile strategy in the file scripts/passn/partition\_name.suffix. If a partition-specific compile strategy does not exist, Automated Chip Synthesis looks for a user-defined default compile strategy in the file scripts/passn/\$acs\_global\_user\_compile\_strategy\_script.suffix. If a user-defined compile strategy exists, Automated Chip Synthesis uses it instead of the default compile strategy when generating the compile script.

To determine the current value of this variable, type **printvar acs\_global\_user\_compile\_strategy\_script**.

---

### SEE ALSO

[acs\\_compile\\_design\(2\)](#)  
[acs\\_refine\\_design\(2\)](#)  
[acs\\_recompile\\_design\(2\)](#)  
[write\\_compile\\_script\(2\)](#)  
[acs\\_user\\_compile\\_strategy\\_script\\_suffix\(3\)](#)

---

## acs\_log\_file\_suffix

Specifies the default suffix for log files generated during the automated compile process.

---

### TYPE

string

---

### DEFAULT

log in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Specifies the default suffix for log files generated during the automated compile process. For use in dc\_shell-t (Tcl mode of dc\_shell) only.

The log is placed in a file called *passn/logs/design.suffix*, where *suffix* is the value of the **acs\_log\_file\_suffix** variable.

To determine the current value of this variable, type **printvar acs\_log\_file\_suffix**.

---

### SEE ALSO

[write\\_makefile\(2\)](#)

---

## acs\_makefile\_name

Specifies the file name for the makefile generated by the **write\_makefile** command and run by the **compile\_partitions** command.

---

### TYPE

string

---

### DEFAULT

Makefile

---

### DESCRIPTION

Specifies the filename for the makefile generated by the **write\_makefile** command and run by the **compile\_partitions** command. For use in dc\_shell-t (Tcl mode of dc\_shell) only.

To determine the current value of this variable, type **printvar acs\_makefile\_name**.

---

### SEE ALSO

[compile\\_partitions\(2\)](#)  
[write\\_makefile\(2\)](#)

---

## acs\_override\_script\_suffix

Specifies the suffix for user-defined partition compile scripts.

---

### TYPE

string

---

### DEFAULT

uscr in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Specifies the suffix for user-defined partition compile scripts. For use in dc\_shell-t (Tcl mode of dc\_shell) only.

Before generating a partition compile script, Automated Chip Synthesis looks for a user-defined partition compile script in scripts/passn/partition\_name.suffix. If a user-defined script exists, Automated Chip Synthesis uses it instead of generating a default script.

To determine the current value of this variable, type **printvar acs\_override\_script\_suffix**.

---

### SEE ALSO

[acs\\_compile\\_design\(2\)](#)  
[acs\\_refine\\_design\(2\)](#)  
[acs\\_recompile\\_design\(2\)](#)  
[write\\_compile\\_script\(2\)](#)

---

## acs\_qor\_report\_suffix

Specifies the suffix for QOR reports generated during the automated compile process; the default is *qor*.

---

### TYPE

string

---

### DEFAULT

*qor* in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Specifies the suffix for QOR reports generated during the automated compile process; the default is *qor*. For use in dc\_shell-t (Tcl mode of dc\_shell) only.

Unless you specify the **-no\_reports option**, the compile scripts generated by the **write\_compile\_script** command includes a command to generate a QOR report. The QOR report is placed in a file called *passn/reports/design.suffix*, where *suffix* is the value of the **acs\_qor\_report\_suffix** variable.

To determine the current value of this variable, type **printvar acs\_qor\_report\_suffix**.

---

### SEE ALSO

[write\\_compile\\_script\(2\)](#)

---

## acs\_timing\_report\_suffix

Specifies the suffix for timing reports generated during the automated compile process.

---

### TYPE

string

---

### DEFAULT

tim in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Specifies the suffix for timing reports generated during the automated compile process. For use in dc\_shell-t (Tcl mode of dc\_shell) only.

Unless you specify the **-no\_reports** option, the compile scripts generated by the **write\_compile\_script** command include a command to generate a timing report. The timing report is placed in a file called passn/reports/design.*suffix*, where *suffix* is the value of the **acs\_timing\_report\_suffix** variable.

To determine the current value of this variable, type **printvar acs\_timing\_report\_suffix**.

---

### SEE ALSO

[write\\_compile\\_script\(2\)](#)

---

## acs\_user\_compile\_strategy\_script\_suffix

Specifies the suffix for user-defined partition compile strategies.

---

### TYPE

string

---

### DEFAULT

compile

---

### DESCRIPTION

Specifies the suffix for user-defined partition compile strategies. For use in dc\_shell-t (Tcl mode of dc\_shell) only.

A compile strategy is a script that includes commands to set the **compile** variables, set the **compile** attributes, and run the **compile** command.

Before generating a partition compile script, Automated Chip Synthesis looks for a user-defined partition compile strategy in scripts/passn/partition\_name.suffix. If a user-defined compile strategy exists, Automated Chip Synthesis uses it when generating the compile script, instead of using the default compile strategy.

To determine the current value of this variable, type **printvar acs\_user\_compile\_strategy\_script\_suffix**.

---

### SEE ALSO

[acs\\_compile\\_design\(2\)](#)  
[acs\\_refine\\_design\(2\)](#)  
[acs\\_recompile\\_design\(2\)](#)  
[write\\_compile\\_script\(2\)](#)

---

## acs\_work\_dir

Specifies the root of the Automated Chip Synthesis project directory.

---

### TYPE

string

---

### DEFAULT

the current working directory

---

### DESCRIPTION

Specifies the root of the Automated Chip Synthesis project directory. During startup, this variable is set to the current working directory. For use in dc\_shell-t (Tcl mode of dc\_shell) only.

This value is used when locating input files for Automated Chip Synthesis commands and when generating absolute path names.

To determine the current value of this variable, type **printvar acs\_work\_dir**.

**Note:** Character @ is reserved to specify pass dependent directory names. Its use as a literal character in ACS directory paths is not allowed.

---

### SEE ALSO

[create\\_pass\\_directories\(2\)](#)  
[read\\_partition\(2\)](#)  
[remove\\_pass\\_directories\(2\)](#)  
[report\\_pass\\_data\(2\)](#)  
[write\\_compile\\_script\(2\)](#)  
[write\\_makefile\(2\)](#)  
[write\\_partition\(2\)](#)  
[write\\_partition\\_constraints\(2\)](#)

---

## alib\_library\_analysis\_path

Specifies a single path, similar to a search path, for reading and writing the alib files that correspond to the target libraries.

---

### TYPE

string

---

### DEFAULT

"./"

---

### DESCRIPTION

This variable specifies the path from which the tool loads alibs during compile. The tool stores alibs to this path when the **alib\_analyze\_libs** command is issued.

---

### SEE ALSO

[alib\\_analyze\\_libs\(2\)](#)

---

## all\_registers\_include\_icg

Enables command all\_registers to include integrated clock-gating cells.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When set to *true*, this variable enables command all\_registers to include integrated clock-gating cells.

To determine the current setting, use the following command:

```
get_app_var all_registers_include_icg
```

---

### SEE ALSO

[all\\_registers\(2\)](#)

---

# attributes

Lists the predefined Synopsys attributes.

---

## DESCRIPTION

Attributes are properties assigned to objects such as nets, cells, and clocks, and describe design features to be considered during optimization.

Attributes are grouped into the following categories:

- cell
- clock
- design
- library cell
- net
- pin
- port
- read-only
- reference

Definitions for these attributes are provided in the subsections that follow.

There are several commands used to set attributes; however, most attributes can be set with the **set\_attribute** command. If the attribute definition specifies a set command, use it to set the attribute. Otherwise, use the **set\_attribute** command.

Some attributes are informational, or read-only. You cannot set the value of these attributes. Most attribute groups contain read-only attributes; however, a complete list of these attributes is provided in the "Read Only" subsection.

Some attributes are instance-specific, which means they can be applied to specified objects in the design hierarchy. The following attributes are instance-specific:

- disable\_timing
- load
- test\_assume

Certain attributes are specific to Power Compiler objects. For information about the Power Compiler attributes, see the **power\_attributes** man page.

To determine the value of an attribute, use the **get\_attribute** command. To remove attributes, use the **remove\_attribute** command.

For a more detailed explanation of the attributes, see the man pages of the appropriate set command.

Note that path groups, cell delay, net delay, external delay, point-to-point timing specification, and arrival information are not represented as attributes, and therefore cannot be manipulated with attribute commands.

### Cell Attributes

**async\_set\_reset\_q**

Establishes the value (0 or 1) that should be assigned to the q output of an inferred register if set and reset are both active at the same time. To be used with the **async\_set\_reset\_qn** attribute. Use these attributes if one of the following condition sets apply:

- You have used the **one\_hot** or **one\_cold** attribute or directive in your HDL description and your logic library is written using pre-V3.0a syntax
- Your logic library does not use a consistent convention for q and qn when set and reset are both active

By default, if set and reset are both active at the same time, Design Compiler uses the convention of the selected logic library, as set with the **target\_library** variable. Set this attribute with the **set\_attribute** command.

**async\_set\_reset\_qn**

Establishes the value (0 or 1) that should be assigned to the qn output of an inferred register if set and reset are both active at the same time. To be used with the **async\_set\_reset\_q** attribute. Use these attributes if one of the following condition sets apply:

- You have used the **one\_hot** or **one\_cold** attribute or directive in your HDL description and your logic library is written using pre-V3.0a syntax
- Your logic library does not use a consistent convention for q and qn when set and reset are both active

If a V3.0a or later syntax logic library is used, then by default, if set and reset are both active at the same time, Design Compiler will use the convention of the selected logic library (**target\_library**). Set with **set\_attribute**.

If you are unsure whether or not your logic library uses V3.0a syntax, ask your ASIC vendor.

**combinational\_type\_exact**

Specifies the replacement gate to use for cells specified in the cell list. Compile attempts to convert combinational gates tagged with **set\_compile\_type** to the specified replacement combinational gate. Set with **set\_combinational\_type**.

**disable\_timing**

Disables the timing arcs of a cell. This has the same effect on timing as not having the arc in the library. Set with **set\_disable\_timing**.

**dont\_touch**

Identifies cells to be excluded from optimization. Values are true (the default) or false. Cells with the **dont\_touch** attribute set to true are not modified or replaced during compile. Setting **dont\_touch** on a hierarchical cell sets the attribute on all cells below the hierarchical cell. Set with the **set\_dont\_touch command**.

**flip\_flop\_type**

Stores the name of the specified flip-flop to be converted from the **target\_library**. The **compile** command automatically converts all tagged flip-flops to the specified (or one similar) type. Set with **set\_register\_type -flip\_flop flip\_flop\_name [cell\_list]**.

**flip\_flop\_type\_exact**

Stores the name of the specified flip-flop to be converted from the **target\_library**. The **compile** command automatically converts all tagged flip-flops to the exact flip-flop type. Set with **set\_register\_type -exact -flip\_flop flip\_flop\_name [cell\_list]**.

**is\_black\_box**

Sets to true if the cell's reference is not linked to a design or is linked to a design that does not have a functionality.

This attribute is read-only and cannot be set by the user.

**is\_combinational**

Sets to true if all cells of a design and all designs in its hierarchy are combinational. A cell is combinational if it is non-sequential or non-tristate and all of its outputs compute a combinational logic function. The **report\_lib** command reports such a cell as not a black-box.

This attribute is read-only and cannot be set by the user.

**is\_dw\_subblock**

Sets to true if the object (a cell, a reference, or a design) is a DW subblock that was automatically elaborated.

This attribute is read-only and cannot be set by the user.

Note that DW subblocks that are manually elaborated do not have this attribute.

**is\_hierarchical**

Sets to true if the design is not a leaf design; for example, not from a logic library.

This attribute is read-only and cannot be set by the user.

**is\_mapped**

Sets to true if the cell is not generic logic.

This attribute is read-only and cannot be set by the user.

**is\_sequential**

Sets to true if the cell is sequential. A cell is sequential if it is not combinational.

This attribute is read-only and cannot be set by the user.

**is\_synlib\_module**

Sets to true if the object (a cell, a reference, or a design) refers to an unmapped module reference, or if the object is (or refers to) a design that was automatically elaborated from a synlib module or a synlib operator.

This attribute is read-only and cannot be set by the user.

Note that synlib modules that are manually elaborated do not have this attribute.

**is\_synlib\_operator**

Sets to true if the object (a cell or a reference) is a synthetic library operator reference.

This attribute is read-only and cannot be set by the user.

**is\_test\_circuitry**

Sets by **insert\_dft** on the scan cells and nets added to a design during the addition of test circuitry.

This attribute is read-only and cannot be set by the user.

**is\_unmapped**

Sets to true if the cell is generic logic.

This attribute is read-only and cannot be set by the user.

**latch\_type\_exact**

Stores the name of the specified latch to be converted from the **target\_library**. The **compile** command automatically converts all tagged latches to the exact latch type. Set with **set\_register\_type -latch latch\_name [cell\_list]**.

**map\_only**

Specifies that **compile** attempts to map the object exactly in the target library, and exclude the object from logic-level optimization (flattening and structuring) when set to true. The default is false. Set with **set\_map\_only**.

**max\_fall\_delay**

Specifies a floating-point value that establishes the maximum falling delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_max\_delay**.

**max\_rise\_delay**

Specifies a floating-point value that establishes the maximum rising delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_max\_delay**.

#### max\_time\_borrow

Specifies a floating-point number that establishes an upper limit for time borrowing; that is, it prevents the use of the entire pulse width for level-sensitive latches. Units are those used in the logic library. Set with **set\_max\_time\_borrow**.

#### min\_fall\_delay

Specifies a floating-point value that establishes the minimum falling delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_min\_delay**.

#### min\_rise\_delay

Specifies a floating-point value that establishes the minimum rising delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_min\_delay**.

#### ref\_name

Specifies the reference name of a cell.

This attribute is read-only and cannot be set by the user.

#### full\_name

Specifies the hierarchical name of cell, pin or net.

This attribute is read-only and cannot be set by the user.

#### scan

Specifies that the cell is always replaced by an equivalent scan cell during **insert\_dft** when set to true. When set to false, the cell is not replaced. Set with **set\_scan**.

#### scan\_chain

Includes the specified cells of the referenced design in the scan-chain whose index is the value of this attribute. Set with **set\_scan\_chain**.

#### scan\_element

Determines if sequential cells in the specified designs are replaced by equivalent scan cells during **insert\_scan**. When true, the default, **insert\_scan** replaces cell\_design\_ref\_list with equivalent scan cells. The scan cells are not replaced when set to false. Set with **set\_scan\_element**.

#### scan\_latch\_transparent

Makes specified cells transparent during ATPG when set to true. For hierarchical cells, the effects apply hierarchically to level-sensitive leave cells. Set with **set\_scan\_transparent**. Remove with **remove\_attribute**.

#### test\_isolate

Indicates that the specified sequential cells, pins, or ports are to be logically isolated and considered untestable during test design rule checking by **check\_test**. When this attribute is set on a cell, it is also placed on all pins of that cell. Do not set this attribute on a hierarchical cell. Use **report\_test -assertions** for a report on isolated objects. Set with **set\_test\_isolate**.

Note that setting this attribute suppresses the warning messages associated with the isolated objects.

#### test\_routing\_position

Specifies the preferred routing order of the scan-test signals of the identified cells. Set with **set\_test\_routing\_order**.

#### ungroup

Removes a level of hierarchy by exploding the contents of the specified cell in the current design. If specified on a reference object, cells using that reference are ungrouped during **compile**. Set with **set\_ungroup**.

**register\_list**

Specifies the single-bit cells that are remapped to the multibit cell. This attribute can be set when the `compile_ultra` or the `create_register_bank` commands remap single-bit registers to multibit registers.

## Clock Attributes

**clock\_fall\_transition**

Sets the falling transition value on the specified clock list. The `clock_fall_transition` overrides the calculated transition times on clock pins of registers and associated nets. Set using `set_clock_transition`.

**clock\_rise\_transition**

Sets the rising transition value on the specified clock list. The `clock_rise_transition` overrides the calculated transition times on clock pins of registers and associated nets. Set using `set_clock_transition`.

**dont\_touch\_network**

When a design is optimized, `compile` assigns `dont_touch` attributes to all cells and nets in the transitive fanout of `dont_touch_network` ports. The `dont_touch` assignment stops at the boundary of storage elements. An element is recognized as storage only if it has setup or hold constraints. Set with `set_dont_touch_network`.

**fix\_hold**

Specifies that `compile` should attempt to fix hold violations for timing endpoints related to this clock. Set with `set_fix_hold`.

**hold\_uncertainty**

Specifies a negative uncertainty from the edges of the ideal clock waveform. Set with `set_clock_uncertainty -hold`.

**max\_fall\_delay**

A floating point value that specifies the maximum falling delay on ports, clocks, pins, cells, or on paths between such objects. Set with `set_max_delay`.

**max\_rise\_delay**

A floating point value that specifies the maximum rising delay on ports, clocks, pins, cells, or on paths between such objects. Set with `set_max_delay`.

**max\_time\_borrow**

A floating point number that establishes an upper limit for time borrowing; that is, it prevents the use of the entire pulse width for level-sensitive latches. Units are those used in the logic library. Set with `set_max_time_borrow`.

**min\_fall\_delay**

A floating point value that specifies the minimum falling delay on ports, clocks, pins, cells, or on paths between such objects. Set with `set_min_delay`.

**min\_rise\_delay**

A floating point value that specifies the minimum rising delay on ports, clocks, pins, cells, or on paths between such objects. Set with `set_min_delay`.

**period**

Assigns a value to the clock period. The clock period (or cycle time) is the shortest time during which the clock waveform repeats. For a simple waveform with one rising and one falling edge, the period is the difference between successive rising edges. Set with `create_clock -period_value`.

**propagated\_clock**

Specifies that the clock edge times be delayed by propagating the values through the clock network. If this attribute is not present, ideal clocking is assumed. Set with `set_propagated_clock`.

**setup\_uncertainty**

Specifies a positive uncertainty from the edges of the ideal clock waveform. Set with **set\_clock\_uncertainty -setup**.

## Design Attributes

### async\_set\_reset\_q

Establishes the value (0 or 1) that should be assigned to the q output of an inferred register if set and reset are both active at the same time. To be used with **async\_set\_reset\_qn**. Use these attributes only if you have used the **one\_hot** or **one\_cold** attributes/directives in your HDL description *and* your logic library is written using pre-V3.0a syntax; *or* if your logic library does not use a consistent convention for q and qn when set and reset are both active. If a V3.0a or later syntax logic library is used, then by default if set and reset are both active at the same time Design Compiler will use the convention of the selected logic library (**target\_library**). Set with **set\_attribute**.

**Note:** If you are unsure whether or not your logic library uses V3.0a syntax, ask your ASIC vendor.

### async\_set\_reset\_qn

Establishes the value (0 or 1) that should be assigned to the qn output of an inferred register if set and reset are both active at the same time. To be used with **async\_set\_reset\_q**. Use these attributes only if you have used the **one\_hot** or **one\_cold** attributes/directives in your HDL description *and* your logic library is written using pre-V3.0a syntax; *or* if your logic library does not use a consistent convention for q and qn when set and reset are both active. If a V3.0a or later syntax logic library is used, then by default if set and reset are both active at the same time Design Compiler will use the convention of the selected logic library (**target\_library**). Set with **set\_attribute**.

If you are unsure whether or not your logic library uses V3.0a syntax, ask your ASIC vendor.

### balance\_registers

Determines whether the registers in a design are retimed during **compile**. When **true** (the default value), **compile** invokes the **balance\_registers** command, which moves registers to minimize the maximum register-to-register delay. Set this attribute to **false**, or remove it, to disable this behavior.

Set with **set\_balance\_registers**.

If your design contains generic logic, you should ensure that all components are mapped to cells from the library before setting the **balance\_registers** attribute.

### boundary\_optimization

Enables **compile** to optimize across hierarchical boundaries. Hierarchy is ignored during optimization for designs with this attribute set to **true**. Set with **set\_boundary\_optimization**.

### default\_flip\_flop\_type

Specifies the default flip-flop type for the current design. During the mapping process, **compile** tries to convert all unmapped flip-flops to this type. If **compile** is unable to use this flip-flop, it maps these cells into the smallest flip-flop possible. Set with **set\_register\_type -flip\_flop flip\_flop\_name**.

### default\_flip\_flop\_type\_exact

During the mapping process, **compile** converts unmapped flip-flops to the exact flip-flop type specified here. Set with **set\_register\_type -exact -flip\_flop flip\_flop\_name**

### default\_latch\_type\_exact

Specifies the exact default latch type for the **current\_design**. During the mapping process, **compile** converts unmapped latches to the exact latch type specified here. Set with **set\_register\_type -exact -latch latch\_name**.

### design\_type

Indicates the current state of the design and has the value **fsm** (finite state machine), **pla** (programmable logic array), **equation** (Boolean logic), or **netlist** (gates). This attribute is "read-only" and cannot be set by the user.

### dont\_touch

Identifies designs that are to be excluded from optimization. Values are **true** (the default) or **false**. Designs with the **dont\_touch**

attribute set to **true** are not modified or replaced during **compile**. Setting **dont\_touch** on a design has an effect only when the design is instantiated within another design as a level of hierarchy; setting **dont\_touch** on the top-level design has no effect. Set with the **set\_dont\_touch** command.

#### flatten

When set to **true**, determines that a design is to be flattened during **compile**. By default, a design is not flattened. Set with the **set\_flatten** command.

#### flatten\_effort

Defines the level of CPU effort that **compile** uses to flatten a design. Allowed values are **low** (the default), **medium**, or **high**. Set with the **set\_flatten** command.

#### flatten\_minimize

Defines the minimization strategy used for logic equations. Allowed values are **single\_output**, **multiple\_output**, or **none**. Set with the **set\_flatten** command.

#### flatten\_phase

When **true**, allows logic flattening to invert the phase of outputs during **compile**. By default, logic flattening does not invert the phase of outputs. Used only if the **flatten** attribute is set. Set with **set\_flatten**.

#### implementation

The implementation for each specified instance of the specified component\_type. Specifying the **-default** option removes this attribute from all instances of the component type in the current design. Set with **set\_jtag\_implementation**.

#### is\_combinational

**true** if all cells of a design and all designs in its hierarchy are combinational. A cell is combinational if it is non-sequential or nonthree-state and all of its outputs compute a combinational logic function. The **report\_lib** command will report such a cell as not a black-box. This attribute is read-only; you cannot set it.

#### is\_dw\_subblock

**true** if the object (a cell, a reference, or a design) is a DW subblock that was automatically elaborated. This attribute is "read-only" and cannot be set by the user.

**NOTE:** DW subblocks that are manually elaborated will not have this attribute.

#### is\_hierarchical

**true** if any of the cells of a design are not leaf cells (for example, not from a logic library). This attribute is read-only and cannot be set by the user.

#### is\_mapped

**true** if all the non-hierarchical cells of a design are mapped to cells in a logic library. This attribute is "read-only" and cannot be set by the user.

#### is\_sequential

**true** if any cells of a design or designs in its hierarchy are sequential. A cell is sequential if it is not combinational (if any of its outputs depend on previous inputs). This attribute is read-only and cannot be set by the user.

#### is\_synlib\_module

**true** if the object (a cell, a reference, or a design) refers to an unmapped module reference or if the object is (or refers to) a design that was automatically elaborated from a synlib module or a synlib operator. This attribute is "read-only" and cannot be set by the user.

**NOTE:** synlib modules that are manually elaborated will not have this attribute.

#### is\_unmapped

**true** if any of the cells are not linked to a design or mapped to a logic library. This attribute is read-only and cannot be set by the

user.

#### local\_link\_library

A string that contains a list of design files and libraries to be added to the beginning of the **link\_library** whenever a **link** operation is performed. Set with **set\_local\_link\_library**.

#### map\_only

When set to **true**, **compile** will attempt to map the object exactly in the target library, and will exclude the object from logic-level optimization (flattening and structuring). The default is **false**. Set with **set\_map\_only**.

#### max\_area

A floating point number that represents the target area of the design. **compile** uses it to calculate the area cost of the design. The units must be consistent with the units used from the logic library during optimization. Set with **set\_max\_area**.

#### max\_capacitance

A floating point number that sets the maximum capacitance value for input, output, or bidirectional ports, or designs. The units must be consistent with those of the logic library used during optimization. Set with **set\_max\_capacitance**.

#### max\_total\_power

A floating point number that specifies the maximum target total power for the **current\_design**. Total power is defined as the sum of dynamic and leakage power. If this attribute is specified more than once for a design, the latest value is used. Set with **set\_max\_total\_power**.

#### minimize\_tree\_delay

When **true** (the default value), **compile** restructures expression trees in the **current\_design** or in a list of specified designs, to minimize tree delay. The value of this attribute overrides the value of **hlo\_minimize\_tree\_delay**. Set this attribute to **false** for any designs that you do not wish to be restructured. Set with **set\_minimize\_tree\_delay**.

#### model\_map\_effort

Specifies the relative amount of CPU time to be used by **compile** during modeling, typically for synthetic library implementations. Values are **low**, **medium**, and **high**, or 1, 2, and 3. If **model\_map\_effort** is not set, the value of **synlib\_model\_map\_effort** is used. Set with the **set\_model\_map\_effort** command.

#### model\_scale

A floating point number that sets the model scale factor for the **current\_design**. Set with **set\_model\_scale**.

#### optimize\_registers

When **true** (the default value), **compile** automatically invokes the Behavioral Compiler **optimize\_registers** command to retime the design during optimization. Setting the attribute to **false** disables this behavior. Your design cannot contain generic logic at the instant **optimize\_registers** is invoked during **compile**.

Set with **set\_optimize\_registers**.

#### part

A string value that specifies the Xilinx part type for a design. For valid part types, refer to the Xilinx *XC4000 Databook*. Set with **set\_attribute**.

#### port\_is\_pad

Indicates specified ports are to have I/O pads attached. The I/O pads are added during **insert\_pads** and automatically added during **compile**. Set using **set\_port\_is\_pad**.

#### resource\_allocation

Indicates the type of resource allocation to be used by **compile** for the **current\_design**. Allowed values are **none**, indicating no resource sharing; **area\_only**, indicating resource sharing with tree balancing without considering timing constraints; **area\_no\_tree\_balancing**, indicating resource sharing without tree balancing and without considering timing constraints; and **constraint\_driven** (the default), indicating resource sharing so that timing constraints are met or not worsened. The value of this

attribute overrides the value of the variable **hlo\_resource\_allocation** for the **current\_design**. Set with **set\_resource\_allocation**.

#### resource\_implementation

Indicates the type of resource implementation to be used by **compile** for the **current\_design**. Allowed values are **area\_only**, indicating resource implementation without considering timing constraints; **constraint\_driven**, indicating resource implementation so that timing constraints are met or not worsened; and **use\_fastest**, indicating resource implementation using the fastest implementation initially, unless all timing constraints are met. If the fastest implementation has been selected initially later steps of the compile command will select components with smaller area later in uncritical parts of the design. The value of this attribute overrides the value of the variable **hlo\_resource\_implementation** for the **current\_design**. Set with **set\_resource\_implementation**.

#### scan\_element

Determines if sequential cells in the specified designs are replaced by equivalent scan cells or designs during **insert\_scan**. Default is set to **true**. When set to **false**, sequential cells are not replaced by equivalent scan cells. Set with **set\_scan\_element**.

#### scan\_latch\_transparent

When set to **true**, makes specified designs transparent during ATPG. For hierarchical cells, the effects apply hierarchically to level-sensitive leaf cells. The **set\_scan\_transparent** command sets the attribute; the **remove\_attribute** command removes it.

#### share\_cse

When **true**, the value of the environment variable **hlo\_share\_common\_subexpressions** is used. The value of this attribute determines whether common subexpressions are shared during compile, to reduce the cost of the design. Setting the attribute to **false** overrides the **hlo\_share\_common\_subexpressions**. Set with **set\_share\_cse**.

#### structure

Determines if a design is to be structured during **compile**. If **true**, adds logic structure to a design by adding intermediate variables that are factored out of the design's equations. Set with **set\_structure**.

#### structure\_boolean

Enables the use of Boolean (non-algebraic) techniques during the structuring phase of optimization. This attribute is ignored if the **structure** attribute is **false**. Set with **set\_structure**.

#### structure\_timing

Enables timing constraints to be considered during the structuring phase of optimization. This attribute is ignored if the **structure** attribute is **false**. Set with **set\_structure**.

#### ungroup

Removes a level of hierarchy from the current design by exploding the contents of the specified cell in the current design. Set with **set\_ungroup**.

#### wired\_logic\_disable

When **true**, disables creation of wired OR logic during **compile**. The default is **false**; if this attribute is not set, wired OR logic will be created if appropriate. Set with **set\_wired\_logic\_disable**.

#### wire\_load\_model\_mode

Determines which wire load model to use to compute wire capacitance, resistance, and area for nets in a hierarchical design that has different wire load models at different hierarchical levels. Allowed values are **top**, which indicates to use the wire load model at the top hierarchical level; **enclosed**, which indicates to use the wire load model on the smallest design that encloses a net completely; and **segmented**, which indicates to break the net into segments, one within each hierarchical level. In the **segmented** mode, each net segment is estimated using the wire load model on the design that encloses that segment. The **segmented** mode is not supported for wire load models on clusters. If a value is not specified for this attribute, **compile** searches for a default in the first library in the link path. If none is found, **top** is the default. Set with **set\_wire\_load**.

#### xnfout\_use\_blknames

When **true**, the Synopsys XNF writer writes BLKNM XNF parameters into the XNF netlist for your design when **write -f xnf** is invoked. The default is **false**. The BLKNM XNF parameters convey to the Xilinx place and route tools information, previously placed

on the **db\_design** by **replace\_fpga**, that indicates which groupings of function generators are to be packed into CLB cells. Set with **set\_attribute**.

## Library Cell Attributes

### dont\_touch

Identifies library cells to be excluded from optimization. Values are **true** (the default) or **false**. Library cells with the **dont\_touch** attribute set to **true** are not modified or replaced during **compile**. Setting **dont\_touch** on a hierarchical cell sets the attribute on all cells below it. Set with **set\_dont\_touch**.

### dont\_use

Disables the specified library cells so that they are not added to a design during **compile**. Set with **set\_dont\_use**.

### formula

The attribute of the priority parameter for implementations in synthetic libraries. The formula should evaluate to an integer between 0 and 10. Set with **set\_impl\_priority**.

### implementation

Specifies the implementation for the synthetic library cell instances to use. When **compile** is run, the implementation you specified is used if you set this attribute. The cells instances must be defined in the synthetic library for this attribute to work. Set with **set\_implementation**.

### no\_sequential\_degenerates

When **true**, disables mapping to versions of this latch or flip flop that have some input pins connected to 0 or to 1. Set with **set\_attribute**. This attribute may also be set on the library itself, and that value will apply as the default for all registers in the library which don't have the attribute set individually.

### preferred

Specifies the preferred library gate to use during technology translation when there are other gates with the same function in the target library. Set with the **set\_prefer** command.

### scan

When **true**, specifies that the instances of the library cell are always replaced by equivalent scan cells during **insert\_dft**. When false, instances are not replaced. Set with **set\_scan**.

### scan\_group

A user-defined string variable that allows you to specify to DFT Compiler a preferred scan equivalent for a non-scan storage element, when a library contains multiple scan equivalents. Typical values are **low**, **medium**, and **high**, for low, medium, and high drive strengths. However, you can define any string variable, and it need not describe drive strength. The default behavior is for DFT Compiler to attempt to choose a scan element that best matches the electrical characteristics of the nonscan element; for a more detailed explanation, refer to the *DFT Compiler Scan Synthesis User Guide*. The matching of electrical characteristics works well with the standard CMOS delay model, but is not accurate with other delay models; **scan\_group** provides a means for you to specify an appropriate scan equivalent. Normally, **scan\_group** would be set by the ASIC vendor or library developer, but can also be set by you. Consult your ASIC vendor before attempting to set **scan\_group** with **set\_attribute**. For more information about **scan\_group**, refer to the *DFT Compiler Scan Synthesis User Guide*.

### set\_id

Allows for the value for the implementations in synthetic libraries. Set with **set\_impl\_priorities**.

### scan\_element

Determines if specified designs are scan replaced by **insert\_scan**. Set using **set\_scan\_element**.

### scan\_latch\_transparent

When **true**, makes the specified library cells transparent in ATPG. For hierarchical cells, the effects apply hierarchically to level-sensitive leaf cells. The **set\_scan\_transparent** command sets the attribute; the **remove\_attribute** command removes it.

### sequential\_bridging

When **true**, enables **Design Compiler** to take a multiplexed flip-flop and bridge (that is, connect) the output to the input to get a desired functionality. The default is **false**, so this attribute must be set in order to enable the functionality. Bridging is required for mapping in cases where there is no flip-flop with internal feedback in the target library but one is desired in the HDL. Set with **set\_attribute**. This attribute may also be set on the library itself, and that value will apply as the default for all registers in the library which don't have the attribute set individually.

NOTE: Setting this attribute to **true** can result in an increase in run times and memory consumption for Design Compiler. The increased run times depend on the number of flip-flops in the target library or libraries for which this attribute has been set.

## Pin Attributes

### actual\_max\_net\_capacitance

### actual\_min\_net\_capacitance

A floating point number that specified the total calculated capacitance of the net that is connected to the given pin. The attributes are defined only for pins of leaf cell. The value of these attributes is calculated upon request. These are "read-only" attributes and they cannot be set by the user.

### disable\_timing

Disables timing arcs. This has the same effect on timing as not having the arc in the library. Set with **set\_disable\_timing**.

### max\_slack

A floating point value representing the worst slack of **max\_rise\_slack** and **max\_fall\_slack**.

### max\_fall\_slack

A floating point value representing the worst slack at a pin for falling maximum path delays. This attribute is valid for any pin that appears in a constrained path after timing has been updated.

### max\_rise\_slack

A floating point value representing the worst slack at a pin for rising maximum path delays. This attribute is valid for any pin that appears in a constrained path after timing has been updated.

### min\_slack

A floating point value representing the worst slack of **min\_rise\_slack** and **min\_fall\_slack**.

### min\_fall\_slack

A floating point value representing the worst slack at a pin for falling minimum path delays. This attribute is valid for any pin that appears in a constrained path after timing has been updated..

### min\_rise\_slack

A floating point value representing the worst slack at a pin for rising minimum path delays. This attribute is valid for any pin that appears in a constrained path after timing has been updated.

### max\_fall\_delay

A floating point value that specifies the maximum falling delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_max\_delay**.

### max\_rise\_delay

A floating point value that specifies the maximum rising delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_max\_delay**.

### min\_fall\_delay

A floating point value that specifies the minimum falling delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_min\_delay**.

**min\_rise\_delay**

A floating point value that specifies the minimum rising delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_min\_delay**.

**hold\_uncertainty**

Specifies a negative uncertainty from the edges of the ideal clock waveform. Affects all sequential cells in the transitive fanout of this pin. Set with **set\_clock\_uncertainty -hold**.

**observe\_pin**

Specifies the (internal) observe pin name of an LSI Logic scan macrocell (LSI CTV only). This attribute is used by the **write\_test** command. Set with **set\_attribute**.

**pin\_direction**

Specifies the direction of a pin. Allowed values are **in**, **out**, **inout**, or **unknown**. This attribute is **read-only** and cannot be set by the user.

**pin\_properties**

Lists valid EDIF property values to be attached to different versions of the output pin. The EDIF property values correspond to different output emitter-follower resistance values on the output pin. For details about the use of this attribute, refer to the *Library Compiler Reference Manual*, Chapter 6, "Defining Cells." Set with **set\_attribute**.

**setup\_uncertainty**

Specifies a positive uncertainty from the edges of the ideal clock waveform. Affects all sequential cells in the transitive fanout of this pin. Set with **set\_clock\_uncertainty -setup**.

**set\_pin**

Specifies the (internal) set pin name of an LSI Logic scan macrocell (LSI CTV only). This attribute is used by the **write\_test** command. Set with **set\_attribute**.

**signal\_type**

Used to indicate that a pin or port is of a special type, such as a **clocked\_on\_also** port in a master/slave clocking scheme, or a **test\_scan\_in** pin for scan-test circuitry. Set with **set\_signal\_type**.

**static\_probability**

A floating point number that specifies the percentage of time that the signal is in the logic 1 state; this information is used by **report\_power**. If this attribute is not set, **report\_power** will use the default value of 0.5, indicating that the signal is in the logic 1 state half the time. Set with **set\_switching\_activity**.

**test\_assume**

A string that represents a constant logic value to be assumed for specified pins throughout test design rule checking by **check\_test**. "1", "one", or "ONE" specifies a constant value of logic one; "0", "zero", or "ZERO" specifies a constant value of logic zero. Use **report\_test -assertions** for a report on objects that have the **test\_assume** attribute set. Set with **set\_test\_assume**.

**test\_initial**

A string that represents an initial logic value to be assumed for specified pins at the start of test design rule checking and fault simulation by **check\_test**. "1", "one", or "ONE" specifies an initial value of logic one; "0", "zero", or "ZERO" specifies an initial value of logic zero. Use **report\_test -assertions** for a report on objects that have the **test\_initial** attribute set. Set with **set\_test\_initial**.

**test\_isolate**

Indicates that the specified sequential cells, pins, or ports are to be logically isolated and considered untestable during test design rule checking by **check\_test**. When this attribute is set on a cell, it is also placed on all pins of that cell. Do not set this attribute on a hierarchical cell. Use **report\_test -assertions** for a report on isolated objects. Set with **set\_test\_isolate**.

**Note:** Setting this attribute suppresses the warning messages associated with the isolated objects.

**test\_routing\_position**

Specifies the preferred routing order of the scan-test signals of the identified cells. Set with **set\_test\_routing\_order**.

#### toggle\_rate

A positive floating point number that specifies the toggle rate; that is, the number of zero-to-one and one-to-zero transitions within a library time unit period. This information is used by **report\_power**; if this attribute is not set, **report\_power** will use the default value of  $2 * (\text{static\_probability})(1 - \text{static\_probability})$ . The default will be scaled by any associated clock signal (if one is available). Set with **set\_switching\_activity**.

#### true\_delay\_case\_analysis

Specifies a value to set all or part of an input vector for **report\_timing -true** and **report\_timing -justify**. Allowed values are 0, 1, r (rise, X to 1), and f (fall, X to 0). Set with the **set\_true\_delay\_case\_analysis** command.

### Port Attributes

#### actual\_max\_net\_capacitance

#### actual\_min\_net\_capacitance

A floating point number that specified the total calculated capacitance of the net connected to the given port. The value of these attributes is calculated upon request. These are "read-only" attributes and they cannot be set by the user.

#### connection\_class

A string that specifies the connection class label to be attached to a port or to a list of ports. **compile**, **insert\_pads**, and **insert\_dft** will connect only those loads and drivers that have the same connection class label. The labels must match those in the library of components for the design, and must be separated by a space. The labels **universal** and **default** are reserved; **universal** indicates that the port can connect with any other load or driver, and **default** is assigned to any ports that do not have a connection class already assigned. Set with **set\_connection\_class**.

#### dont\_touch\_network

When a design is optimized, **compile** assigns **dont\_touch** attributes to all cells and nets in the transitive fanout of **dont\_touch\_network** clock objects. The **dont\_touch** assignment stops at the boundary of storage elements. An element is recognized as storage only if it has setup or hold constraints. Set with **set\_dont\_touch\_network**.

#### driven\_by\_dont\_care

Specifies that input port are driven by dont\_care. Compile uses this information to create smaller designs. After optimization, the port connected to dont\_care does not drive anything inside the optimized design. Set with **set\_logic\_dc**.

#### driven\_by\_logic\_one

Specifies that input ports are driven by logic one. **compile** uses this information to create smaller designs. After optimization, a port connected to logic one usually does not drive anything inside the optimized design. Set with **set\_logic\_one**.

#### driven\_by\_logic\_zero

Specifies that input ports are driven by logic zero. **compile** uses this information to create smaller designs. After optimization, a port connected to logic zero usually does not drive anything inside the optimized design. Set with **set\_logic\_zero**.

#### driving\_cell\_dont\_scale

When **true**, indicates not to scale the transition time on the port using the driving cell. Otherwise the transition time will be scaled by operating condition factors. Set with **set\_driving\_cell**.

#### driving\_cell\_fall

A string that names a library cell from which to copy fall drive capability to be used in fall transition calculation for the port. Set with **set\_driving\_cell**.

#### driving\_cell\_from\_pin\_fall

A string that names the driving\_cell\_fall input pin to be used to find timing arc fall drive capability. Set with **set\_driving\_cell**.

#### driving\_cell\_from\_pin\_rise

A string that names the driving\_cell\_rise input pin to be used to find timing arc rise capability. Set with **set\_driving\_cell**.

driving\_cell\_library\_fall

A string that names the library in which to find the **driving\_cell\_fall**. Set with **set\_driving\_cell**.

driving\_cell\_library\_rise

A string that names the library in which to find the **driving\_cell\_rise**. Set with **set\_driving\_cell**.

driving\_cell\_multiply\_by

A floating point value by which to multiply the transition time of the port marked with this attribute. Set with **set\_driving\_cell**.

driving\_cell\_pin\_fall

A string that names the driving\_cell\_fall output pin to be used to find timing arc fall drive capability. Set with **set\_driving\_cell**.

driving\_cell\_pin\_rise

A string that names the driving\_cell\_rise output pin to be used to find timing arc rise drive capability. Set with **set\_driving\_cell**.

driving\_cell\_rise

A string that names a library cell from which to copy rise drive capability to be used in rise transition calculation for the port. Set with **set\_driving\_cell**.

fall\_drive

Specifies the drive value of high to low transition on input or inout ports. Set with **set\_drive**.

fanout\_load

Specifies the fanout load on output ports. Set with **set\_fanout\_load**.

load

Specifies the load value on ports. The total load on a net is the sum of all the loads on pins, ports, and wires associated with that net. Set with **set\_load**.

max\_capacitance

A floating point number that sets the maximum capacitance value for input, output, or bidirectional ports, and/or designs. The units must be consistent with those of the logic library used during optimization. Set with **set\_max\_capacitance**.

max\_fall\_delay

A floating point value that specifies the maximum falling delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_max\_delay**.

max\_fanout

Specifies the maximum fanout load for the net connected to this port. **compile** ensures that the fanout load on this net is less than the specified value. Set with **set\_max\_fanout**.

max\_rise\_delay

A floating point value that specifies the maximum rising delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_max\_delay**.

max\_slack

A floating point value representing the worst slack of **max\_rise\_slack** and **max\_fall\_slack**.

max\_fall\_slack

A floating point value representing the worst slack at a pin for falling maximum path delays. This attribute is valid for any pin that appears in a constrained path after timing has been updated.

**max\_rise\_slack**

A floating point value representing the worst slack at a pin for rising maximum path delays. This attribute is valid for any pin that appears in a constrained path after timing has been updated.

**min\_slack**

A floating point value representing the worst slack of **min\_rise\_slack** and **min\_fall\_slack**.

**min\_fall\_slack**

A floating point value representing the worst slack at a pin for falling minimum path delays. This attribute is valid for any pin that appears in a constrained path after timing has been updated.

**min\_rise\_slack**

A floating point value representing the worst slack at a pin for rising minimum path delays. This attribute is valid for any pin that appears in a constrained path after timing has been updated.

**max\_time\_borrow**

A floating point number that establishes an upper limit for time borrowing; that is, it prevents the use of the entire pulse width for level-sensitive latches. Units are those used in the logic library. Set with **set\_max\_time\_borrow**.

**max\_transition**

Specifies the maximum transition time for the net connected to this port. **compile** ensures that value. Set with **set\_max\_transition**.

**min\_capacitance**

A floating point number that sets the minimum capacitance value for input and/or bidirectional ports. The units must be consistent with those of the logic library used during optimization. Set with **set\_min\_capacitance**.

**min\_fall\_delay**

A floating point value that specifies the minimum falling delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_min\_delay**.

**min\_rise\_delay**

A floating point value that specifies the minimum rising delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_min\_delay**.

**setup\_uncertainty**

Specifies a positive uncertainty from the edges of the ideal clock waveform. Affects all sequential cells in the transitive fanout of this port. Set with **set\_clock\_uncertainty -setup**.

**hold\_uncertainty**

Specifies a negative uncertainty from the edges of the ideal clock waveform. Affects all sequential cells in the transitive fanout of this port. Set with **set\_clock\_uncertainty -hold**.

**model\_drive**

A non-negative floating point number that specifies the estimated drive value on ports in terms of standard drives of the current logic library. Set with **set\_model\_drive**.

**model\_load**

A non-negative floating point number that specifies the estimated load value on ports in terms of standard loads of the current logic library. Set with **set\_model\_load**.

**op\_used\_in\_normal\_op**

Specifies that a scan-out port is also used in normal operation (system mode). This attribute is used by the **insert\_dft** command. Set with **set\_attribute**.

## Read-Only Attributes

### design\_type

Indicates the current state of the design and has the value **fsm** (finite state machine), **pla** (programmable logic array), **equation** (Boolean logic), or **netlist** (gates). This attribute cannot be set by the user.

### is\_black\_box

**true** if the reference is not yet linked to a design or is linked to a design that doesn't have a functionality. This attribute cannot be set by the user.

### is\_combinational

**true** if all cells of a design and all designs in its hierarchy are combinational. A cell is combinational if it is non-sequential or non-tristate and all of its outputs compute a combinational logic function. The **report\_lib** command will report such a cell as not a black-box. This attribute is read-only and cannot be set by the user.

### is\_dw\_subblock

**true** if the object (a cell, a reference, or a design) is a DW subblock that was automatically elaborated. This attribute is "read-only" and cannot be set by the user.

### is\_hierarchical

**true** if any of the cells of a design are not leaf cells (for example, not from a logic library). This attribute cannot be set by the user.

### is\_mapped

**true** if all the non-hierarchical cells of a design are mapped to cells in a logic library. This attribute cannot be set by the user.

### is\_sequential

**true** if any cells of a design or designs in its hierarchy are sequential. A cell is sequential if it is not combinational. This attribute cannot be set by the user.

### is\_synlib\_module

**true** if the object (a cell, a reference, or a design) refers to an unmapped module reference or if the object is (or refers to) a design that was automatically elaborated from a synlib module or a synlib operator. This attribute is "read-only" and cannot be set by the user.

**NOTE:** synlib modules that are manually elaborated will not have this attribute.

### is\_synlib\_operator

**true** if the object (a cell or a reference) is a synthetic library operator reference. This attribute is "read-only" and cannot be set by the user.

### is\_test\_circuitry

Set by **insert\_dft** on the scan cells and nets added to a design during the addition of test circuitry. This attribute cannot be set by the user.

### is\_unmapped

**true** if any of the cells are not linked to a design or mapped to a logic library. This attribute cannot be set by the user.

### direction

Returns the direction of a pin or port. The value can be **in**, **out**, **inout**, or **unknown**. For backward compatibility, the attribute also supports an integer value, **1** for **in**, **2** for **out**, or **3** for **inout**. This attribute cannot be set by the user.

### pin\_direction

Returns the direction of a pin. The value can be **in**, **out**, **inout**, or **unknown**. This attribute cannot be set by the user. You can also use the **direction** attribute to get the direction of the pin.

**port\_direction**

Returns the direction of a port. The value can be **in**, **out**, **inout**, or **unknown**. This attribute cannot be set by the user. You can also use the **direction** attribute to get the direction of the port.

**ref\_name**

The reference name of a cell. This attribute cannot be set by the user.

## Reference Attributes

**dont\_touch**

Specifies that designs linked to a reference with this attribute are excluded from optimization. Values are **true** (the default) or **false**. Designs linked to a reference with the **dont\_touch** attribute set to **true** are not modified or replaced during **compile**. Set with **set\_dont\_touch**.

**is\_black\_box**

**true** if the reference is not yet linked to a design or is linked to a design that doesn't have a functionality. This attribute is read-only and cannot be set by the user.

**is\_combinational**

**true** if all the cells of the referenced design are combinational. A cell is combinational if it is non-sequential or non-tristate and all of its outputs compute a combinational logic function. The **report\_lib** command will report such a cell as not a black-box. This attribute is read-only and cannot be set by the user.

**is\_dw\_subblock**

**true** if the object (a cell, a reference, or a design) is a DW subblock that was automatically elaborated. This attribute is read-only and cannot be set by the user.

**NOTE:** DW subblocks that are manually elaborated will not have this attribute.

**is\_hierarchical**

**true** if the referenced design is not a leaf cell (for example, not in a logic library). This attribute is read-only and cannot be set by the user.

**is\_mapped**

**true** if the reference is linked to a design, and all the non-hierarchical cells of the referenced design are mapped to cells in a logic library. This attribute is read-only and cannot be set by the user.

**is\_sequential**

**true** if all the cells of the referenced design are sequential. A cell is sequential if it is not combinational (if any of its outputs depend on previous inputs). This attribute is read-only and cannot be set by the user.

**is\_synlib\_module**

**true** if the object (a cell, a reference, or a design) refers to an unmapped module reference or if the object is (or refers to) a design that was automatically elaborated from a synlib module or a synlib operator. This attribute is read-only and cannot be set by the user.

**NOTE:** synlib modules that are manually elaborated will not have this attribute.

**is\_synlib\_operator**

**true** if the object (a cell or a reference) is a synthetic library operator reference. This attribute is read-only and cannot be set by the user.

**is\_unmapped**

**true** if any of the non-hierarchical cells of the referenced design are not mapped to cells in a logic library, or if the reference is not yet linked to a design. This attribute is read-only and cannot be set by the user.

**scan**

When **true**, specifies that cells of the referenced design are always replaced by equivalent scan cells during **insert\_dft**. When false, cells of the design are not replaced. Set with **set\_scan**.

**scan\_chain**

Includes the specified cells of the referenced design in the scan-chain whose index is the value of this attribute. Set with the **set\_scan\_chain** command.

**scan\_element**

Determines if specified designs are scan replaced by **insert\_scan**. Set using **set\_scan\_element**.

**scan\_latch\_transparent**

When **true**, makes the specified references transparent in ATPG. For hierarchical cells, the effects apply hierarchically to level-sensitive leaf cells. The specified library cell cannot be overwritten. Set with **set\_scan\_transparent**; remove with **remove\_attribute**.

**ungroup**

Specifies that all designs linked to a reference with this attribute are ungrouped (levels of hierarchy represented by these design cells are removed) during **compile**. Set with **set\_ungroup**.

---

## SEE ALSO

`get_attribute(2)`  
`remove_attribute(2)`  
`set_attribute(2)`  
`power_attributes(3)`

---

## auto\_insert\_level\_shifters

Controls automatic level shifter insertion.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

mv

---

### DESCRIPTION

By default, this variable is **true** and enables the level-shifter insertion engine. With this variable set to **true**, commands such as **compile** and **insert\_dft** are able to automatically insert level shifters where needed.

Setting this variable to **false** disables the level-shifter insertion engine, and automatic level shifter insertion does not happen during **compile** or **insert\_dft** regardless of any user constraint.

Note that level-shifter insertion performed by the command **insert\_mv\_cells** is not affected by this variable.

---

### SEE ALSO

**compile(2)**  
**insert\_dft(2)**  
**insert\_mv\_cells(2)**

---

## auto\_insert\_level\_shifters\_on\_clocks

Directs automatic level-shifter insertion to insert level shifters on specified clocks.

---

### TYPE

string

---

### DEFAULT

""

---

### GROUP

none

---

### DESCRIPTION

This variable can be set to "all" or a list of clock names (delimited by spaces or commas). When set to "all", automatic level-shifter insertion inserts level shifters on all clock nets that need level shifters.

When this variable is set to a list of clock names, automatic level-shifter insertion inserts level shifters on the net of these clocks, if needed.

By default, automatic level-shifter insertion does not insert level shifters on the nets driven by the clocks.

Note that if a net is ideal, automatic level-shifter insertion won't insert any level shifter on it, unless the variable **mv\_insert\_level\_shifters\_on\_ideal\_nets** is set to "all".

---

### SEE ALSO

auto\_insert\_level\_shifters(3)  
create\_clock(2)  
mv\_insert\_level\_shifters\_on\_ideal\_nets(3)  
set\_ideal\_network(2)

---

## auto\_link\_disable

Specifies whether to disable the code to perform an auto\_link during any command.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When this variable is set to true, the code to perform an auto\_link during any command is disabled, resulting in faster command processing. This increase in speed is important in back-annotation commands such as **set\_load**, **set\_resistance**, and **set\_annotated\_delay**, where numerous commands are executed in sequence. Disabling the auto\_link code can significantly improve the speed with which commands are executed.

Once the sequence of time-critical commands is completed, reset the variable value to false to revert the tool back to its normal mode of operation.

To determine the current value of this variable use the **printvar auto\_link\_disable** command.

---

### SEE ALSO

**set\_annotated\_delay(2)**  
**set\_load(2)**  
**set\_resistance(2)**

---

## auto\_link\_options

Specifies the **link** command options to be used when **link** is invoked automatically.

---

### TYPE

string

---

### DEFAULT

-all

---

### DESCRIPTION

This variable specifies the **link** command options to be used when **link** is invoked automatically. The default value is -all. To find the available options, refer to the **link** command man page.

To determine the current value of this variable, use the **printvar auto\_link\_options** command.

---

### SEE ALSO

[link\(2\)](#)

---

## auto\_ungroup\_preserve\_constraints

Controls whether the timing constraints on the hierarchy are preserved when the hierarchy is ungrouped during the process of optimization.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

timing

---

### DESCRIPTION

This variable enables the ungrouping of hierarchies with timing constraints and preserves the timing constraints when the hierarchies are ungrouped during the process of optimization. By default, the **auto\_ungroup\_preserve\_constraints** variable is set to true.

The constraints are preserved when executing the following commands:

```
prompt> compile -ungroup_all  
prompt> set_ungroup  
prompt> compile  
  
prompt> compile -auto_ungroup area | delay
```

The constraints on DesignWare library hierarchical cells are also lost when the cells are ungrouped during optimization.

Set the **auto\_ungroup\_preserve\_constraints** variable to false before compiling to avoid the ungrouping of hierarchies with timing constraints.

Use the **printvar auto\_ungroup\_preserve\_constraints** command to determine the current value of this variable.

---

## SEE ALSO

`compile(2)`  
`list(2)`  
`set_ungroup(2)`

---

## auto\_wire\_load\_selection

Controls automatic selection of wire load model.

---

### TYPE

string

---

### DEFAULT

true in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

When area\_locked, the automatic wire load selection uses the initial area to do the first selection of the wire load model and then adjusts the wire load model down if the area drops. When area\_reselect, the automatic wire load selection during reporting and at various points in compile updates the wire load model to the current area of the design. When false, the automatic wire load selection is off. For backwards compatibility, we also support the value true. True is the same as area\_locked.

The automatic selection of the wire load model is used to estimate net capacitances and resistances from the net fanout. The wire load models are described in the technology library. With the automatic selection of the wire load model, if the wire load mode is **segmented** or **enclosed**, the wire load model will be chosen based on the area of the design containing the net either partially (for **segmented**) or fully (for **enclosed**). If the wire load mode is **top**, the wire load model will be chosen based on the area of the top level design for all nets in the design hierarchy.

When a design's wire load model is selected manually by the user (with the command **set\_wire\_load**), no wire load is selected automatically for that design.

To determine the current value of this variable use **printvar auto\_wire\_load\_selection**. For a list of all **compile** variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

[set\\_wire\\_load\(2\)](#)  
[report\\_design\(2\)](#)

---

## banking\_enable\_concatenate\_name

Controls the multibit cell name used for the **create\_register\_bank** commands in the output file generated by the **identify\_register\_banks** command.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
true in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Starting with the J-2014.09-SP3 release, the **banking\_enable\_concatenate\_name** variable controls the name of the multibit registers created by the **create\_register\_bank** command in the output file generated by the **identify\_register\_banks** command. By default, when the single-bit registers are grouped together, the tool uses the following naming style for multibit cells: The name of the original single-bit registers concatenated with an underscore (\_), such as reg\_1\_reg\_0.

For example, if the tool groups two single-bit registers, a\_reg[0] and a\_reg[1], to one multibit cell, it generates the following in the output file:

```
create_register_bank -name a_reg[0]_a_reg[1] {a_reg[0] a_reg[1]} -lib_cell MREG2
```

To revert to the naming style used in previous releases, set the **banking\_enable\_concatenate\_name** variable to **false**. When the variable is **false**, the name of each register bank is created using the *prefixN1\_N2* format, where N1 and N2 are integers. The N1 and N2 integers are used so the name is unique in the output file. The default prefix is group.

In the previous naming style, if the tool groups two single-bit registers, a\_reg[0] and a\_reg[1], to one multibit cell, the following command is generated in the output file:

```
create_register_bank -name group0_0 {a_reg[0] a_reg[1]} -lib_cell MREG2
```

You can change the name prefix in either naming style by specifying the **-name\_prefix** option of the **identify\_register\_banks** command.

For example, if you specify the MBIT prefix with the **-name\_prefix** option using the default naming style, the output file generated during placement includes the following **create\_register\_bank** command:

```
create_register_bank -name MBIT_a_reg[0]_a_reg[1] {a_reg[0] a_reg[1]} -lib_cell MREG2
```

Use the following command to determine the current value of the variable:

```
prompt> printvar banking_enable_concatenate_name
```

## SEE ALSO

`identify_register_banks(2)`

---

## bind\_unused\_hierarchical\_pins

Specifies if unused hierarchical pins (no driver, no load) should be connected to constant tie-off cells during compile.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable controls whether unused hierarchical pins are connected to constant tie-off cells during compile.

An unused hierarchical pin is a pin of a hierarchical cell that has no drivers and no loads associated with it. In other words, there are no leaf cells and no ports connected to the hierarchical pin. (Nets and connections to other hierarchical pins do not count.)

When this variable is set to its default of **true**, the tool ties unused hierarchical pins to logic 0 during compile:



For unused input pins, the constant is driven in the parent hierarchy. For unused output pins, the constant is driven from inside the hierarchical block.

When this variable is set to **false** before linking the design, the tool leaves unused hierarchical pins undriven:



This variable affects only compile, which is performed by the **compile** or **compile\_ultra** command. This variable does not affect design read, link, or design write commands.

Note that when boundary optimization is performed, constant propagation can result in unused hierarchical pins in the compiled design that were driven in the RTL. Boundary optimization is on by default when the **compile\_ultra** command is used.

To determine the current value of this variable, use the **printvar bind\_unused\_hierarchical\_pins** command. For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

## SEE ALSO

**compile(2)**

---

## bit\_blasted\_bus\_linking\_naming\_styles

Specifies the bus pin naming styles to be matched.

---

### TYPE

String

---

### DEFAULT

%s[%d] %s(%d) %s\_%d\_

---

### DESCRIPTION

When the **enable\_bit\_blasted\_bus\_linking** variable is set to true, the **bit\_blasted\_bus\_linking\_naming\_styles** variable allows the linker to recognize bit-blasted buses by pin names during the link process. If the pin names follow a specific pattern, DC Explorer infers a bus when encountering the individual blasted bits.

Typically, the RTL pin names and the logic library pin names should match. Signals are defined the same way in both the RTL and the library. They are defined as buses or a bus is defined by its individual wires. Occasionally, mismatches occur during design development; for example, when you transfer the design from one technology to another. To fix the mismatches, you can set the **enable\_bit\_blasted\_bus\_linking** variable to true before the design is read.

Setting the **enable\_bit\_blasted\_bus\_linking** variable to true allows the linker to match buses and bit-blasted pin names according to the patterns specified by the **bit\_blasted\_bus\_linking\_naming\_styles** variable. The default for the **enable\_bit\_blasted\_bus\_linking** variable is false.

For example,

```
prompt> set bit_blasted_bus_linking_naming_styles {%s[%d] %s_%d}
```

This setting permits the following U1 reference to link

```
input [1:0] in;  
my_macro U1( .S(in),...
```

even if my\_macro is defined as follows:

```
my_macro  
input S_1;  
input S_0;  
\...
```

For multiple-dimension buses, the style can be explicitly defined or in certain cases implied. For example, the %s[%d] setting matches A[0], A[0][0], or A[0][0][0], and so on.

However, to match the A\_0\_\_0\_\_0\_ pin name, you need to use the following setting:

%s\_%d\_\_%d\_\_%d\_

To determine the current setting of this variable, use the **printvar bit\_blasted\_bus\_linking\_naming\_styles** command. For a list of all system variables and their current values, use **print\_variable\_group system**.

---

## SEE ALSO

[enable\\_bit\\_blasted\\_bus\\_linking\(3\)](#)

---

## bit\_blasted\_bus\_linking\_order

Specifies the pin order for bus inference of bit blasted bus pins.

---

### TYPE

String

---

### DEFAULT

reference

---

### DESCRIPTION

When the **enable\_bit\_blasted\_bus\_linking** variable is set to true, the linker can recognize bit-blasted buses by pin names during the link process. If the pin names follow a specific pattern, DC Explorer infers a bus when encountering the individual blasted bits. The **bit\_blasted\_bus\_linking\_order** variable allows the user to specify the bus order.

The allowed values are {reference|ascending|descending}. when the variable value is set to 'ascending' or 'descending', a reconstructed 32 bit bus A would become, respectively, A[0:31] and A[31:0]. If the variable value is 'reference' the reconstructed bus pin order will follow the order found on the bit blasted reference. The variable defines the global behavior for all linked designs in the session.

To determine the current setting of this variable, use the **printvar bit\_blasted\_bus\_linking\_order** command. For a list of all system variables and their current values, use **print\_variable\_group system**.

---

### SEE ALSO

[enable\\_bit\\_blasted\\_bus\\_linking\(3\)](#)

---

## block\_abstraction\_compute\_area\_as\_macro

Controls the calculation of the area of cells in a block abstraction with the **report\_area** and **report\_qor** commands.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

By default, this variable is set to **false**. The area of cells in a block abstraction is calculated and reported in the regular cell portions by the **report\_area** and **report\_qor** commands. If this variable is set to **true**, the area of cells is calculated and reported in the macro portion.

---

### SEE ALSO

[report\\_area\(2\)](#)  
[report\\_qor\(2\)](#)

---

## bound\_attributes

Contains attributes related to bound.

---

## DESCRIPTION

Contains attributes related to bound.

You can use **get\_attribute** to determine value of an attribute, and use **report\_attribute** to get a report of all attributes on specified object. Specified with **list\_attribute -class bound -application**, the definition of attributes can be listed.

### Bound Attributes

#### aspect\_ratio

Specifies the **width:height** ratio of a bound.

The data type of **aspect\_ratio** is double.

This attribute is read-only.

#### bbox

Specifies the bounding-box of a bound. The **bbox** is represented by a **rectangle**.

The format of a *rectangle* specification is {{llx lly} {urx ury}}, which specifies the lower-left and upper-right corners of the rectangle.

The data type of **bbox** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### bbox\_ll

Specifies the lower-left corner of the bounding-box of a bound.

The **bbox\_ll** is represented by a **point**. The format of a *point* specification is {x y}.

You can get the **bbox\_ll** of a bound, by accessing the first element of its**bbox**.

The data type of **bbox\_ll** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### bbox\_llx

Specifies x coordinate of the lower-left corner of the bounding-box of a bound.

The data type of **bbox\_llx** is double.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### bbox\_lly

Specifies y coordinate of the lower-left corner of the bounding-box of a bound.

The data type of **bbox\_lly** is double.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**bbox\_ur**

Specifies the upper-right corner of the bounding-box of a bound.

The **bbox\_ur** is represented by a **point**. The format of a *point* specification is {x y}.

You can get the **bbox\_ur** of a bound, by accessing the second element of its **bbox**.

The data type of **bbox\_ur** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**bbox\_urx**

Specifies x coordinate of the upper-right corner of the bounding-box of a bound.

The data type of **bbox\_urx** is double.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**bbox\_ury**

Specifies y coordinate of the upper-right corner of the bounding-box of a bound.

The data type of **bbox\_ury** is double.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**color**

Specifies color to draw a move bound and its associated instances.

The data type of **color** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**dimension**

Specifies dimension of a group bound.

Its format is {**width height**}.

The data type of **dimension** is string.

This attribute is read-only.

**effort**

Specifies effort to bring cells closer inside an auto group bound.

Its valid values can be:

- **low**
- **medium**
- **high**
- **ultra**

The data type of **effort** is string.

This attribute is read-only.

#### is\_mhr

Specifies whether the exclusive movebound is a multi-height row region.

The data type of **is\_mhr** is boolean.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### name

Specifies name of a bound object.

The data type of **name** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### number\_of\_hard\_macro

Specifies number of hard macro cells inside a bound.

The data type of **number\_of\_hard\_macro** is integer.

This attribute is read-only.

#### number\_of\_standard\_cell

Specifies number of standard cells inside a bound.

The data type of **number\_of\_standard\_cell** is integer.

This attribute is read-only.

#### object\_class

Specifies object class name of a bound, which is **bound**.

The data type of **object\_class** is string.

This attribute is read-only.

#### object\_type

Specifies object type of a bound, which can be **move\_bound**, **auto\_group\_bound**, or **group\_bound**.

The data type of **object\_type** is string.

This attribute is read-only.

#### points

Specifies point list of a move bound's boundary.

The data type of **points** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### type

Specifies type of a move bound or a group bound.

The data type of **type** is string.

Its valid values are:

- **soft**
- **hard**
- **exclusive**

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### utilization

Specifies the ratio of total area size of associated instances to the area of a move bound.

The data type of **utilization** is double.

This attribute is read-only.

---

## SEE ALSO

`get_attribute(2)`  
`list_attributes(2)`  
`report_attribute(2)`  
`set_attribute(2)`

---

## bsd\_max\_in\_switching\_limit

Specifies the maximum number of design inputs that may switch simultaneously while generating input Design Compiler parametric tests using the **create\_bsd\_patterns** command.

---

### TYPE

integer

---

### DEFAULT

60000 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

Switching all inputs and outputs simultaneously can cause large currents. It is advisable to switch as few I/Os as possible while performing Design Compiler parametric tests. The **bsd\_max\_in\_switching\_limit** variable allows you to specify the maximum number of inputs that may switch simultaneously while generating VIL/VIH tests using the **create\_bsd\_patterns** command.

To determine the current value of this variable, use the **printvar bsd\_max\_in\_switching\_limit** command. For a list of BSD variables and their current values, use the **print\_variable\_group bsd** command.

---

### SEE ALSO

[create\\_bsd\\_patterns\(2\)](#)

---

## bsd\_max\_out\_switching\_limit

Specifies the maximum number of design outputs that may switch simultaneously while generating output Design Compiler parametric tests using the **create\_bsd\_patterns** command.

---

### TYPE

integer

---

### DEFAULT

60000 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

Switching all inputs and outputs simultaneously can cause large currents. It is advisable to switch as few I/Os as possible while performing Design Compiler parametric tests. The **bsd\_max\_out\_switching\_limit** variable allows you to specify the maximum number of outputs that may switch simultaneously while generating VOL/VOH tests using the **create\_bsd\_patterns** command.

To determine the current value of this variable, use the **printvar bsd\_max\_out\_switching\_limit** command. For a list of BSD variables and their current values, use the **print\_variable\_group bsd** command.

---

### SEE ALSO

[create\\_bsd\\_patterns\(2\)](#)

---

## bsd\_physical\_effort

Specifies the effort used for BSD Compiler integration features.

---

### TYPE

string

---

### DEFAULT

medium

---

### DESCRIPTION

Specifies the effort used for BSD Compiler integration features.

Valid values for this variable are low, medium, high, and ultra. The default value is medium.

To determine the current value of this variable, use the **printvar bsd\_physical\_effort** command. For a list of BSD variables and their current values, use the **print\_variable\_group bsd** command.

---

### SEE ALSO

---

## **budget\_generate\_critical\_range**

Enables automatic generation of **set\_critical\_range** commands by **dc\_allocate\_budgets** for multiply-instantiated subdesigns.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### **DESCRIPTION**

When set to true, this variable causes the **dc\_allocate\_budgets** command to automatically generate a **set\_critical\_range** command for any budgeted cells that have multiply-instantiated subdesigns. The value of **critical\_range** is set to 10% of the shortest clock period in the design. If the top-level design already has a **critical\_range** attribute, then that original value is used instead.

The purpose of this is to improve QoR, since any multiple instances must be `dont_touched` after compile in a bottom-up compile flow. Using **set\_critical\_range** causes any near-critical paths in these blocks to be optimized before the block is `dont_touched`.

To see the current value of this variable, enter the following command:

```
prompt> printvar budget_generate_critical_range
```

---

### **SEE ALSO**

`dc_allocate_budgets(2)`

---

## **budget\_map\_clock\_gating\_cells**

Maps integrated clock gating cells into target library cells during RTL budgeting.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### **DESCRIPTION**

When set to true, this variable causes the **dc\_allocate\_budgets -mode rtl** command to map any integrated clock gating cells into target library cells before calculating the budget. Normally, any unmapped cells would remain unmapped during budgeting when **-mode rtl** is used.

The purpose of this is to prevent incorrect **-level\_sensitive** delay constraints from appearing in the budget constraint files. These may otherwise appear because unmapped integrated clock gating cells can include transparent latch elements.

To see the current value of this variable, use the following command:

```
prompt> printvar budget_map_clock_gating_cells
```

---

### **SEE ALSO**

[dc\\_allocate\\_budgets\(2\)](#)

---

## bus\_inference\_descending\_sort

Specifies that the members of that port bus are to be sorted in descending order rather than in ascending order.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

Affects the **read** command except for the db, Verilog and VHDL formats. This variable is primarily used when reading in designs in the LSI/NDL format. That particular format does not support representation of busses, but, if port names follow a specific pattern (as described in the variable **bus\_inference\_style**), the individual bits can be "inferred" into a port bus. When true (the default value), This variable specifies that the members of that port bus are to be sorted in descending order rather than in ascending order.

For example, with the variable **bus\_inference\_style** set to "%s[%d]", the ports "A[1]", "A[2]", "A[3]", and "A[4]" will be "inferred" into a port bus named "A". If this variable is true, the port bus "A" will have an index from 4 to 1; if this variable is false, the port bus "A" will have an index from 1 to 4.

With the variable **bus\_inference\_style** set to "#%d%%%s", the ports "#8%cb", "#9%cb", "#10%cb", and "#11%cb" will be "inferred" into a port bus named "cb". If this variable is true, the port bus "cb" will have an index from 11 to 8; if this variable is false, the port bus "cb" will have an index from 8 to 11.

To determine the current value of this variable, type **printvar bus\_inference\_descending\_sort**. For a list of all **edif** or **io** variables and their current values, type **print\_variable\_group edif** or **print\_variable\_group io**.

---

### SEE ALSO

[create\\_bus\(2\)](#)  
[remove\\_bus\(2\)](#)  
[report\\_bus\(2\)](#)  
[bus\\_inference\\_style\(3\)](#)  
[bus\\_minus\\_style\(3\)](#)  
[bus\\_naming\\_style\(3\)](#)  
[bus\\_range\\_separator\\_style\(3\)](#)

---

## bus\_inference\_style

Specifies the pattern used to infer individual bits into a port bus.

---

### TYPE

string

---

### DEFAULT

""

---

### DESCRIPTION

This variable specifies the pattern used to infer individual bits into a port bus. The variable affects the **read** command except for the .db and VHDL formats. This variable also affects the VHDL **write** commands. The variable is used primarily when reading in designs in the LSI/NDL format. The LSI/NDL format does not support representation of buses. But if port names follow a specific pattern (as described by this variable), the individual bits can be inferred into a port bus. If you specify an invalid value, no port buses are inferred.

When running in Tcl mode, the **bus\_inference\_style** value must be specified within curly brackets ({}). For example:

```
set bus_inference_style {%s[%d]}
```

This variable must contain 1 %s (percent s) and %d (percent d) character sequence. Additional characters can be used with these symbols. To use a percent sign in a name, 2 percent signs are needed in the variable string (%%).

In naming a port bus, the port name is substituted for %s, and the port number replaces %d. A single percent sign is substituted for %%.

For example, with this variable set to "%s[%d]", the ports "A[1]", "A[2]", "A[3]", and "A[4]" will be inferred into a port bus named A either with an index from 1 to 4, or with an index from 4 to 1 (see **bus\_inference\_descending\_sort**).

With this variable set to "#%d%%%s", the ports "#8%cb", "#9%cb", "#10%cb", and "#11%cb" will be inferred into a port bus named cb either with an index from 8 to 11, or with an index from 11 to 8 (see **bus\_inference\_descending\_sort**).

To determine the current value of this variable, use the **printvar bus\_inference\_style** command. For a list of all **edif** or **io** variables and their current values, use the **print\_variable\_group edif** or **print\_variable\_group io** command.

---

### SEE ALSO

[create\\_bus\(2\)](#)  
[remove\\_bus\(2\)](#)  
[report\\_bus\(2\)](#)

```
bus_inference_descending_sort(3)
bus_minus_style(3)
bus_naming_style(3)
bus_range_separator_style(3)
```

---

## bus\_minus\_style

Controls the naming of individual members of bit-blasted port, instance, or net buses with negative indices.

---

### TYPE

string

---

### DEFAULT

-%d

---

### DESCRIPTION

This variable controls the naming of individual members of bit-blasted port, instance, or net buses with negative indices. The variable affects the **read** command with the **vhdl** format option.

To determine the current value of this variable, use the **printvar bus\_minus\_style** command. For a list of all HDL variables and their current values, use the **print\_variable\_group hdl** command.

---

### SEE ALSO

`create_bus(2)`  
`remove_bus(2)`  
`report_bus(2)`  
`bus_inference_descending_sort(3)`  
`bus_inference_style(3)`  
`bus_naming_style(3)`  
`bus_range_separator_style(3)`

---

## bus\_multiple\_name\_separator\_style

Determines the separator used to name of a multibit cell that implements bits whose original base\_names differ.

---

### TYPE

string

---

### DEFAULT

''

---

### DESCRIPTION

This variable affects the naming of multibit cells during multibit mapping. The variable is used to name a multibit cell whose original single-bit cells had different base names. The default value is a double **bus\_multiple\_separator\_style** pattern, and is used if an invalid value is specified (or no value at all).

The **bus\_multiple\_separator\_style** variable is used to separate two ranges of bits sharing the same base names, while **bus\_multiple\_name\_separator\_style** is used to separate the different base names.

The two variables are used in conjunction with the **bus\_naming\_style** and the **bus\_range\_separator\_style** variable to generate names for multibit cells.

In the following examples assume that **bus\_range\_separator\_style** is set to ":", **bus\_multiple\_name\_separator\_style** is set to "\_MB\_" and **bus\_multiple\_separator\_style** is set to ";".

If cells with the names q\_1[0], q\_1[1], q\_2[2], q\_2[5], q\_2[6], and q\_2[7] are packed into a 6-bit wide cell, the name given to the new cell is q\_1[0:1]\_MB\_q\_2[2,5:7].

If cells q[0], q[2], q[4], and q[6] are packed into a 4-bit wide cell, the name given to the new cell is q[0,2,4,6].

To determine the current value of this variable, use the following command: **printvar bus\_multiple\_name\_separator\_style**.

For a list of all **multibit** variables and their current values, use: **print\_variable\_group multibit**

---

### SEE ALSO

**bus\_multiple\_separator\_style(3)**  
**bus\_range\_separator\_style(3)**

---

## bus\_multiple\_separator\_style

Determines the name of a multibit cell that implements bits that do not form a range.

---

### TYPE

string

---

### DEFAULT

,

---

### DESCRIPTION

This variable affects the naming of multibit cells during multibit mapping. The variable is used to name a multibit cell that implements bits that do not form a range. The default is used if an invalid value is specified.

The **bus\_range\_separator\_style** variable is used to separate the start and end bit positions of a range, while **bus\_multiple\_separator\_style** is used to separate two ranges. The two variables are used in conjunction with the **bus\_naming\_style** variable to generate names for multibit cells.

Assume that **bus\_range\_separator\_style** is set to ".", **bus\_multiple\_separator\_style** is set to ",", and **bus\_naming\_style** is set to "%s[%d]" in the following examples.

For example, if cells with the names q[0], q[1], q[2], q[5], q[6], and q[7] are packed into a 6-bit wide cell, the name given to the new cell is q[0:2,5:7]. If cells q[0], q[2], q[4], and q[6] are packed into a 4-bit wide cell, the name given to the new cell is q[0,2,4,6].

To determine the current value of this variable, use the **printvar bus\_range\_separator\_style** command. For a list of all **multibit** variables and their current values, use the **print\_variable\_group multibit** command.

---

### SEE ALSO

[bus\\_range\\_separator\\_style\(3\)](#)

---

## bus\_naming\_style

Specifies the style to use in naming an individual port member, net member, or cell instance member of an EDIF array or of a Verilog or VHDL vector.

---

### TYPE

string

---

### DEFAULT

%s[%d]

---

### DESCRIPTION

This variable affects the **read** command with the EDIF, Verilog, or VHDL format option, the **write** command with the EDIF format option, and the **create\_schematic** command with the busing option.

When reading buses, this variable specifies the style to use in naming an individual port member, net member, or cell instance member of an EDIF array or of a Verilog or VHDL vector.

When running in TCL mode the **bus\_naming\_style** needs to be enclosed by curly brackets. For example:

```
set bus_naming_style {%s[%d]}
```

When writing buses, this variable used with the **bus\_range\_separator\_style** variable specifies the style to use in naming a port array or net array in the EDIF file. If you specify an invalid value, the array is given the name of the bus. When writing schematic nets, this variable used with the **bus\_range\_separator\_style** variable specifies the style to use in naming a net connected to the "wire" end of a ripper in the EDIF file. If you specify an invalid value, the net is given the name of the original net.

When creating schematics, this variable used with the variable **bus\_range\_separator\_style** variable specifies the style to use in naming a ripper, bused port, bused net, or net connected to the "wire" end of a ripper. If you specify an invalid value, the default value is used.

This variable must contain only 1 %s (percent s) and 1 %d (percent d) character sequence. To use the % (percent sign) in the name, use 2 of them in the variable string (%%). Therefore, the only characters that can follow a percent sign are %, s, or d.

When reading buses, in naming members, the name of the array is substituted for %s, and the number of the member is substituted for %d. One percent sign is substituted for %%.

For example, if this variable is set to "%s[%d]", then the first member of the 4-bit array "A", going from 0 to 3, is named:

A[0]

If this variable is set to "%s\_%%%d.X", then the first member of the 8-bit array "xy", going from 9 to 16, is named:

xy\_%9.X

See the **bus\_dimension\_separator\_style** man page for a description of how it is used in conjunction with this variable for specifying the names of the members of multidimensional arrays in the EDIF format or multidimensional vectors in the VHDL format.

See the **bus\_minus\_style** man page for a description of how to specify the names of vectors with negative indices in the VHDL format.

When creating schematics or when writing buses, in naming a bused port or bused net or a port array or net array, the original bus or array name is substituted for %. The start and end bits of the bus or array separated by the value of the variable **bus\_range\_separator\_style** are substituted for %d. One percent sign is substituted for each %%.

For example, if this variable is set to "%s[%d:%d]", then the 4-bit bus or array "A", going from 0 to 3, is named:

A[0:3]

If this variable is set to "%%%s[%d][%d]", then the 8-bit bus or array "B", going from -4 to 3, is named:

%B[-4][3]

See the **edifout\_multidimension\_arrays** man page for a description of how it is used in conjunction with this variable for specifying the names of multidimensional arrays.

See the **edifout\_numerical\_array\_members** man page for a description of how it is used in conjunction with this variable for specifying the names of descending arrays.

When creating schematics or when writing schematic nets, in naming a ripper or net connected to the "wire" end of a ripper, the original net name is substituted for %. If the net is a scalar (a single bit) net, the bit of the ripper is substituted for %d. If the net is a bused net, the start and end bits of the ripper separated by the value of the variable **bus\_range\_separator\_style** are substituted for %d. One percent sign is substituted for each %%.

For example, if this variable is set to "%s[%d]", then the ripper or the net connected to the "wire" end of the ripper that is ripping off the first bit of the 4-bit net array "A" going from 0 to 3, is named:

A[0]

If this variable is set to "%s\_%%%d.X", then the ripper or the net connected to the "wire" end of the ripper that is ripping off the first bit of the 8-bit net array "xy" going from 9 to 16, is named:

xy\_%9.X

If this variable is set to "%s[%d]" and the **bus\_range\_separator\_style** variable is set to ":" , then the net connected to the "wire" end of the ripper that is ripping off the third through fifth bits of the 8-bit net array "xy" going from 9 to 16, is named:

xy[11:13]

If this variable is set to "%s\_%%%d.X" and the **bus\_range\_separator\_style** variable is set to "...", then the ripper or the net connected to the "wire" end of the ripper that is ripping off the third through fourth bits of the 4-bit net array "A" going from 0 to 3, is named:

A\_%2..3.X

To determine the current value of this variable, use the **printvar bus\_naming\_style** command. For a list of all EDIF, HDL, or schematic variables and their current values, use the **print\_variable\_group edif**, **print\_variable\_group hdl**, or **print\_variable\_group schematic** command.

## SEE ALSO

```
create_bus(2)
remove_bus(2)
report_bus(2)
bus_inference_descending_sort(3)
bus_inference_style(3)
bus_minus_style(3)
bus_range_separator_style(3)
```

---

## bus\_range\_separator\_style

Specifies the style to use in naming a net connected to the "wire" end of a ripper in the EDIF file.

---

### TYPE

string

---

### DEFAULT

:

---

### DESCRIPTION

This variable specifies the style to use in naming a net connected to the "wire" end of a ripper in the EDIF file. This variable affects the **write** command with the EDIF format option and the **create\_schematic** command with the busing option.

When writing buses, this variable used with the **bus\_naming\_style** variable, specifies the style to use in naming a port array or net array in the EDIF file. When writing schematic nets, this variable used with the **bus\_naming\_style** variable, specifies the style to use in naming a net connected to the "wire" end of a ripper in the EDIF file.

When creating schematics, this variable used with the **bus\_naming\_style** variable, specifies the style to use in naming a ripper, bused port, bused net, or net connected to the "wire" end of a ripper. If you specify an invalid value, the default value is used.

See the **bus\_naming\_style** man page for a description of how this variable is used in conjunction with that variable.

To determine the current value of this variable, use the **printvar bus\_range\_separator\_style** command. For a list of all EDIF or schematic variables and their current values, use the **print\_variable\_group edif** or **print\_variable\_group schematic** command.

---

### SEE ALSO

**create\_bus(2)**  
**remove\_bus(2)**  
**report\_bus(2)**  
**bus\_inference\_descending\_sort(3)**  
**bus\_inference\_style(3)**  
**bus\_minus\_style(3)**  
**bus\_naming\_style(3)**

---

## case\_analysis\_log\_file

Specifies the name of a log file generated during propagation of constant values, from case analysis or from nets tied to logic zero or logic one. Each scenario has its proprietary log file if multiple scenarios exist.

---

### TYPE

string

---

### DEFAULT

""

---

### DESCRIPTION

This variable specifies the name of a log file generated during the propagation of constant values, from case analysis or from nets tied to logic zero or logic one. The log file contains the list of all ports and pins that propagate constants. The constant propagation algorithm is an iterative process that propagates constants through nets and cells starting from a list of constant pins. The algorithm finishes when no more constants can be propagated. The format of the log file follows the constant propagation algorithm.

In multicorner-multimode, you must specify the log file name in the definition of each scenario, or no log will be generated for that scenario. If you switch the active scenario, the log file used will be switched automatically. Log files for different scenarios can have the same name.

By default, this variable is set to an empty string, and no log file is generated during constant propagation.

To determine the current value of this variable, use the **printvar case\_analysis\_log\_file** command. Note that if you switch the scenario in multicorner-multimode, the value of this variable remains at the value last set.

---

### SEE ALSO

remove\_case\_analysis(2)  
report\_case\_analysis(2)  
report\_disable\_timing(2)  
set\_case\_analysis(2)  
disable\_case\_analysis(3)

---

## case\_analysis\_propagate\_through\_icg

Determines whether case analysis is propagated through integrated clock gating cells.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When this variable is set to false (the default), constants propagating throughout the design will stop propagating when an integrated clock gating cell is encountered. Regardless of whether the integrated clock gating cell is enabled or disabled, no logic values will propagate in the fanout of the cell.

When the value is true, constants propagated throughout the design will propagate through an integrated clock gating cell, provided the cell is enabled. An integrated clock gating cell is enabled when its enable pin (or test enable pin) is set to a high logic value. If the cell is disabled, then the disable logic value for the cell is propagated in its fanout. For example, for a latch\_posedge ICG, when it is disabled, it will propagate a logic 0 in its fanout.

To activate logic propagation through all integrated clock gating cells, you must set the following:

```
set case_analysis_propagate_through_icg true
```

To determine the current value of this variable, use either the **printvar case\_analysis\_propagate\_through\_icg** or the **echo \$case\_analysis\_propagate\_through\_icg** command.

---

### SEE ALSO

[remove\\_case\\_analysis\(2\)](#)  
[set\\_case\\_analysis\(2\)](#)

---

## case\_analysis\_sequential\_propagation

Determines whether case analysis is propagated across sequential cells.

---

### TYPE

string

---

### DEFAULT

never

---

### DESCRIPTION

This variable determines whether case analysis is propagated across sequential cells. Allowed values are **never** (the default) or **always**. When set to **never**, case analysis is not propagated across the sequential cells. When set to **always**, case analysis is propagated across the sequential cells.

The one exception to sequential propagation occurs when dealing with sequential integrated clock gating cells. These types of ICG cells will only propagate logic values when the **case\_analysis\_propagate\_through\_icg** variable is set to **true**.

To determine the current value of this variable, type one of the following commands:

```
printvar case_analysis_sequential_propagation  
echo $case_analysis_sequential_propagation
```

---

### SEE ALSO

```
printvar(2)  
set_case_analysis(2)  
case_analysis_propagate_through_icg(3)
```

---

## case\_analysis\_with\_logic\_constants

Enables constant propagation when set to true, even if a design contains only logic constants.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

timing

---

### DESCRIPTION

When set to true (the default), this variable enables constant propagation, even if a design contains only logic constants. When set to false, constant propagation is not performed unless a `set_case_analysis` command is specified. The `disable_case_analysis` variable overrides the `case_analysis_with_logic_constants` variable. If the `disable_case_analysis` variable is set, no constants are propagated.

To determine the current value of this variable, use the `printvar case_analysis_with_logic_constants` command.

---

### SEE ALSO

`remove_case_analysis(2)`  
`report_case_analysis(2)`  
`set_case_analysis(2)`  
`disable_case_analysis(3)`

---

## ccd\_hold\_control\_effort

Set the effort level to control hold degradation during ccd setup optimization.

---

### TYPE

*String*

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer high in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

This application variable specifies the effort level for hold degradation allowed during CCD optimization. Higher effort level will result in better hold timing during CCD optimization but setup timing improvement during CCD can reduce.

Valid values are

- **low**
  - **high**
- 

### SEE ALSO

---

## ccd\_ignore\_ports\_for\_boundary\_identification

Specifies the ports to exclude during boundary identification. This application variable is honored only when the **ccd\_optimize\_boundary\_timing** application variable is **false**.

---

### TYPE

string

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer "" in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

The **ccd\_ignore\_ports\_for\_boundary\_identification** application variable specifies the ports to exclude when concurrent clock and data optimization (CCD) performs boundary identification. Typically you would specify high-fanout ports, such as scan enable and reset ports, to prevent large numbers of flip-flops from being identified as boundary flip-flops.

The tool performs boundary identification only when the **ccd\_optimize\_boundary\_timing** application variable is **false**. If the **ccd\_optimize\_boundary\_timing** application variable is **true**, the tool ignores the setting of the **ccd\_ignore\_ports\_for\_boundary\_identification** application variable.

---

### EXAMPLES

The following examples ignore the dddi[25] and clk1 ports during boundary identification.

```
prompt> set ccd_ignore_ports_for_boundary_identification "dddi[25] clk1"
ccd_ignore_ports_for_boundary_identification {dddi[25] clk1}

prompt> set ccd_ignore_ports_for_boundary_identification \
    [list dddi[25] clk1]
ccd_ignore_ports_for_boundary_identification {{dddi[25]} clk1}
```

The following example ignores the input ports during boundary identification.

```
prompt> set ccd_ignore_ports_for_boundary_identification \
    [get_object_name [get_ports -filter "direction==in"]]
ccd.ignore_ports_for_boundary_identification {rst clk1 clk2 clk3 clk4
{sel[2]} {sel[1]} {sel[0]} {di[63]} {di[62]} {di[61]} {di[60]} ... }
```

---

## SEE ALSO

`ccd_optimize_boundary_timing(3)`

---

## ccd\_ignore\_scan\_reset\_for\_boundary\_identification

Specifies to exclude scan/reset connectivity during boundary identification. This application option is honored only when the **ccd\_optimize\_boundary\_timing** application option is **false**.

---

### TYPE

*Boolean*

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer  
false in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

The **ccd\_ignore\_scan\_reset\_for\_boundary\_identification** application option is used to ignore the connectivities on scan/reset pins when concurrent clock and data optimization (CCD) performs boundary flop identification.

The tool performs boundary flop identification only when the **ccd\_optimize\_boundary\_timing** application variable is false. If the **ccd\_optimize\_boundary\_timing** application variable is true, the tool ignores the setting of the **ccd\_ignore\_scan\_reset\_for\_boundary\_identification** application variable.

---

### SEE ALSO

[ccd\\_optimize\\_boundary\\_timing\(3\)](#)

---

## ccd\_max\_postpone

Specifies the maximum postpone value adjusted during concurrent clock and data (CCD) optimization.

---

### TYPE

float

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer 0 in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

CCD optimization adjusts clock latency to improve timing and power.

By default, there is no limit to reduce and increase clock latency during CCD optimization. To limit the value from adjusting during CCD optimization in Design Compiler NXT in topographical mode with physical guidance mode only, use the following application variables:

- **ccd\_max\_prepone**: Limits reducing the value of clock latency. - **ccd\_max\_postpone**: Limits increasing the value of clock latency.

Specify a positive value in design units with the **ccd\_max\_prepone** and **ccd\_max\_postpone** application variables.

---

### EXAMPLES

The following setting ensures that the maximum postpone value allowed during CCD optimization is 0.1 ns (design units in 1ns).

```
prompt> set_app_var ccd_max_postpone 0.1
```

---

### SEE ALSO

[ccd\\_max\\_prepone\(3\)](#)

---

## ccd\_max\_prepone

Specifies the maximum prepend value adjusted during concurrent clock and data (CCD) optimization.

---

### TYPE

float

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer 0 in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

CCD optimization adjusts clock latency to improve timing and power.

By default, there is no limit to reduce and increase clock latency during CCD optimization. To limit the value from adjusting during CCD optimization in Design Compiler NXT in topographical mode with physical guidance mode only, use the following application variables:

- **ccd\_max\_prepone**: Limits reducing the value of clock latency. - **ccd\_max\_postpone**: Limits increasing the value of clock latency.

Specify a positive value in design units with the **ccd\_max\_prepone** and **ccd\_max\_postpone** application variables.

---

### EXAMPLES

The following setting ensures that the maximum prepend value allowed during CCD optimization is 0.1 ns (design units in 1ns).

```
prompt> set_app_var ccd_max_prepone 0.1
```

---

### SEE ALSO

[ccd\\_max\\_postpone\(3\)](#)

---

## ccd\_optimize\_boundary\_timing

Controls whether concurrent clock and data optimization (CCD) optimizes boundary timing paths.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer true in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

The **ccd\_optimize\_boundary\_timing** application variable controls whether CCD performs optimization on boundary timing paths.

By default (**true**), CCD optimizes boundary timing paths. In this case, all flip-flops in the block are available for CCD. The tool does not perform boundary identification and ignores the setting of the **ccd\_ignore\_ports\_for\_boundary\_identification** and **ccd\_ignore\_scan\_reset\_for\_boundary\_identification** application variables.

To disable optimization on boundary timing paths, such as I/O paths, set the **ccd\_optimize\_boundary\_timing** application variable to **false**. When this option is **false**,

- Only internal flip-flops are available for CCD

The tool performs boundary identification to differentiate between the boundary and internal flip-flops. If your design contains ports that connect to a large number of flip-flops, such as scan enable and reset ports, you might want to exclude these ports from the boundary identification; otherwise, most of the flip-flops are considered boundary flip-flops and the CCD scope is very limited. To specify the ports to exclude, set the **ccd\_ignore\_ports\_for\_boundary\_identification** application variable; If you specify **ccd\_ignore\_scan\_reset\_for\_boundary\_identification** application variable, all of the scan/reset ports will not be considered.

- The tool does not adjust the latencies of the boundary flip-flops

Note that setting the **ccd\_optimize\_boundary\_timing** application variables to **false** prevents CCD from optimizing most of the clock tree.

---

### SEE ALSO

`ccd_ignore_ports_for_boundary_identification(3)`  
`ccd_ignore_scan_reset_for_boundary_identification(3)`



---

## ccd\_respect\_cts\_fixed\_balance\_pins

Used to control CCD engine not to optimize user specified sinks pins

---

### TYPE

*Boolean*

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer false in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

This application variable is used to exclude the sink pins with attribute **cts\_fixed\_balance\_pin** during CCD optimization and the tool will not adjust the latencies of these pins.

The valid values are

- **false** CCD in compile is free to adjust the latencies of the sink pins and does not honor the **cts\_fixed\_balance\_pin** attribute on a pin
- **true** CCD in compile will not adjust the latencies of the sink pins with attribute **cts\_fixed\_balance\_pin**. But the latencies to the sink pins with attribute **cts\_fixed\_balance\_pin** can still change because the clock cells in the clock path to these sink pins can still be optimized by CCD when skewing other sink pins

---

### EXAMPLES

The following examples control CCD engine to avoid to adjust latency for sinks pins with attribute **cts\_fixed\_balance\_pin**:

```
prompt> set ccd_respect_cts_fixed_balance_pins true
```

The flop clock pins that need not be skewed by CCD should have the following setting:

```
set ff_cp [get_pins <flop clock pins>]  
set_attribute $ff_cp cts_fixed_balance_pin true
```

---

### SEE ALSO

```
set_attribute(2)  
get_attribute(2)
```

---

## ccd\_skip\_path\_groups

Skip the path groups for concurrent clock and data (CCD) optimization.

---

### TYPE

*string*

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer  
"" in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

This option accepts a list of path groups and CCD will skip these path groups during critical endpoint selection for optimization. This app option does not skip optimization on data path on the specified path groups.

---

### SEE ALSO

---

## ccd\_write\_script\_sdc\_add\_offset\_to\_latency

Specifies how to write out clock latency offset constraints that are generated during concurrent clock and data optimization (CCD). This application variable is honored by the **write\_script** and **write\_sdc** commands.

---

### TYPE

*Boolean*

---

### DEFAULT

false

---

### DESCRIPTION

The **ccd\_write\_script\_sdc\_add\_offset\_to\_latency** application variable specifies how to write out the clock latency offset constraints that are generated during concurrent clock and data optimization (CCD) in Design Compiler NXT in topographical mode. However, latency offset is not a SDC standard. Therefore, the **write\_sdc** command ignores the latency offset constraints by default and the **write\_script** command writes the latency offset constraints separately.

When you set the **ccd\_write\_script\_sdc\_add\_offset\_to\_latency** variable to **true**,

1. The **write\_sdc** and **write\_script** commands add the latency offset value to latency value. This latency value is calculated from the user-defined latency constraints specified with the **set\_clock\_latency** command without **-offset** option.
  2. The total latency value may be written out as latency value by **set\_clock\_latency** command without **-offset** option. It may overwrites the existing user-defined clock latency constraints.
- 

### EXAMPLES

The following examples show the output of clock latency constraints in a file, written by the **write\_sdc** and **write\_script** command:

The default output of the **write\_sdc** command:

```
set_clock_latency -max 1.01 -clock [get_clocks CLK1] [get_pins fd/CP]
```

The default output of the **write\_script** command:

```
set_clock_latency -max 1.01 -clock [get_clocks CLK1] [get_pins fd/CP]
set_clock_latency -offset -max 0.03 -clock [get_clocks CLK1] [get_pins fd/CP]
```

When the Tcl value is true,

The output of the **write\_sdc** command:

```
set_clock_latency -max 1.04 -clock [get_clocks CLK1] [get_pins fd/CP]
```

The output of the **write\_script** command:

```
set_clock_latency -max 1.04 -clock [get_clocks CLK1] [get_pins fd/CP]
```

---

## SEE ALSO

[write\\_script\(2\)](#)  
[write\\_sdc\(2\)](#)

## cell\_attributes

Contains attributes that can be placed on a cell.

## DESCRIPTION

Contains attributes that can be placed on a cell.

There are a number of commands used to set attributes, however, most attributes can be set with the **set\_attribute** command. If the attribute definition specifies a **set** command, use it to set the attribute. Otherwise, use **set\_attribute**. If an attribute is read-only, you cannot set it.

To determine the value of an attribute, use the **get\_attribute** command. To remove attributes, use the **remove\_attribute** command.

For a more detailed explanation of an attribute, refer to the manual pages of the appropriate **set** command. For information on all attributes, refer to the **attributes** manual page.

### Cell Attributes

#### async\_set\_reset\_q

Establishes the value (0 or 1) that should be assigned to the q output of an inferred register if set and reset are both active at the same time. To be used with **async\_set\_reset\_qn**. Use these attributes only if you have used the **one\_hot** or **one\_cold** attributes/directives in your HDL description *and* your technology library is written using pre-V3.0a syntax; *or* if your technology library does not use a consistent convention for q and qn when set and reset are both active. If a V3.0a or later syntax technology library is used, then by default if set and reset are both active at the same time Design Compiler will use the convention of the selected technology library (**target\_library**). Set with **set\_attribute**.

**Note:** If you are unsure whether or not your technology library uses V3.0a syntax, ask your ASIC vendor.

#### async\_set\_reset\_qn

Establishes the value (0 or 1) that should be assigned to the qn output of an inferred register if set and reset are both active at the same time. To be used with **async\_set\_reset\_q**. Use these attributes only if you have used the **one\_hot** or **one\_cold** attributes/directives in your HDL description *and* your technology library is written using pre-V3.0a syntax; *or* if your technology library does not use a consistent convention for q and qn when set and reset are both active. If a V3.0a or later syntax technology library is used, then by default if set and reset are both active at the same time Design Compiler will use the convention of the selected technology library (**target\_library**). Set with **set\_attribute**.

**Note:** If you are unsure whether or not your technology library uses V3.0a syntax, ask your ASIC vendor.

#### disable\_timing \*

Disables the timing arcs of a cell. This has the same effect on timing as not having the arc in the library. Set with the **set\_disable\_timing** command.

#### dont\_touch

Identifies cells to be excluded from optimization. Values are **true** (the default) or **false**. Cells with the **dont\_touch** attribute set to **true** are not modified or replaced during **compile**. Setting **dont\_touch** on a hierarchical cell sets the attribute on all cells below it. Set with **set\_dont\_touch**.

#### flip\_flop\_type

Stores the name of the specified flip-flop to be converted from the **target\_library**. The **compile** command automatically converts all tagged flip-flops to the specified (or one similar) type. Set with **set\_register\_type -flip\_flop flip\_flop\_name [cell\_list]**.

**flip\_flop\_type\_exact**

Stores the name of the specified flip-flop to be converted from the **target\_library**. The **compile** command automatically converts all tagged flip-flops to the exact flip-flop type. Set with **set\_register\_type -exact -flip\_flop flip\_flop\_name [cell\_list]**.

**is\_black\_box**

Set to **true** if the cell's reference is not linked to a design.

This attribute is read-only and cannot be modified.

**is\_combinational**

Set to **true** if all cells of a design and all designs in its hierarchy are combinational. A cell is combinational if it is non-sequential or non-tristate and all of its outputs compute a combinational logic function. The **report\_lib** command will report such a cell as not a black-box.

This attribute is read-only and cannot be modified.

**is\_dw\_subblock**

Set to **true** if the object (a cell, a reference, or a design) is a DW subblock that was automatically elaborated.

This attribute is read-only and cannot be modified.

**Note:** DW subblocks that are manually elaborated will not have this attribute.

**is\_hierarchical**

Set to **true** if the design contains leaf cells or other levels of hierarchy.

This attribute is read-only and cannot be modified.

**is\_mapped**

Set to **true** if the cell is not generic logic.

This attribute is read-only and cannot be modified.

**is\_sequential**

Set to **true** if the cell is sequential. A cell is sequential if it is not combinational.

This attribute is read-only and cannot be modified.

**is\_synlib\_module**

Set to **true** if the object (a cell, a reference, or a design) refers to an unmapped module reference or if the object is (or refers to) a design that was automatically elaborated from a synlib module or a synlib operator.

This attribute is read-only and cannot be modified.

**Note:** synlib modules that are manually elaborated will not have this attribute.

**is\_synlib\_operator**

Set to **true** if the object (a cell or a reference) is a synthetic library operator reference.

This attribute is read-only and cannot be modified.

**is\_test\_circuitry**

Set by **insert\_dft** on the scan cells and nets added to a design during the addition of test circuitry.

This attribute is read-only and cannot be modified.

**is\_unmapped**

**true** if the cell is generic logic.

This attribute is read-only and cannot be modified.

#### latch\_type\_exact

Stores the name of the specified latch to be converted from the **target\_library**. The **compile** command automatically converts all tagged latches to the exact latch type. Set with **set\_sequential\_type -latch latch\_name [cell\_list]**.

#### map\_only

When set to **true**, **compile** will attempt to map the object exactly in the target library, and will exclude the object from logic-level optimization (flattening and structuring). The default is **false**. Set with **set\_map\_only**.

#### mask\_layout\_type

Specifies the mask layout type of a cell.

This attribute is read-only and cannot be modified.

#### max\_fall\_delay

A floating point value that specifies the maximum falling delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_max\_delay**.

#### max\_rise\_delay

A floating point value that specifies the maximum rising delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_max\_delay**.

#### max\_time\_borrow

A floating point number that establishes an upper limit for time borrowing; that is, it prevents the use of the entire pulse width for level-sensitive latches. Units are those used in the technology library. Set with **set\_max\_time\_borrow**.

#### min\_fall\_delay

A floating point value that specifies the minimum falling delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_min\_delay**.

#### min\_rise\_delay

A floating point value that specifies the minimum rising delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_min\_delay**.

#### ref\_name

The reference name of a cell.

This attribute is read-only and cannot be modified.

#### scan

When **true**, specifies that the cell is always replaced by an equivalent scan cell during **insert\_dft**. When **false**, the cell is not replaced. Set with **set\_scan**.

#### scan\_chain

Includes the specified cells of the referenced design in the scan-chain whose index is the value of this attribute. Set with **set\_scan\_chain**.

#### test\_dont\_fault

Specifies cells not faulted during test pattern generation. If no command options are specified, this attribute is set for both "stuck-at-0" and "stuck-at-1" faults. Set with **set\_test\_dont\_fault**.

#### test\_isolate

Indicates that the specified sequential cells, pins, or ports are to be logically isolated and considered untestable during test design rule checking by **check\_test**. When this attribute is set on a cell, it is also placed on all pins of that cell. Do not set this attribute on a

hierarchical cell. Use **report\_test -assertions** for a report on isolated objects. Set with **set\_test\_isolate**.

**Note:** Setting this attribute suppresses the warning messages associated with the isolated objects.

#### test\_routing\_position

Specifies the preferred routing order of the scan-test signals of the identified cells. Set with **set\_test\_routing\_order**.

#### ungroup

Removes a level of hierarchy by exploding the contents of the specified cell in the current design. If specified on a reference object, cells using that reference are ungrouped during **compile**. Set with **set\_ungroup**.

---

## SEE ALSO

[get\\_attribute\(2\)](#)  
[remove\\_attribute\(2\)](#)  
[set\\_attribute\(2\)](#)  
[attributes\(3\)](#)

---

## change\_names\_bit\_blast\_negative\_index

Bit-blast the bus if any bit of it is negative.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

none

---

### DESCRIPTION

When this variable is set to true, **change\_names** bit-blasts the bus if any bit is negative. Otherwise, **change\_names** shifts the negative range to the positive range starting at 0. The default value is false.

To determine the current value of this variable, use the **printvar change\_names\_bit\_blast\_negative\_index** command.

---

### SEE ALSO

[change\\_names\(2\)](#)  
[define\\_name\\_rules\(2\)](#)

---

## change\_names\_dont\_change\_bus\_members

Controls how the **change\_names** command modifies the names of bus members.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable is for the **change\_names** command, and affects bus members only of bused ports or nets. When false (the default), **change\_names** gives bus members the base name from their owning bus. For example, if BUS A has range 0 to 1 with the first element NET1 and the second element NET2, **change\_names** changes NET1 to A[0] and NET2 to A[1]. When this variable is set to true, **change\_names** does not change the names of bus members, so that NET1 and NET2 remain unchanged.

This variable also applies to **-special** rules, but has no effect if the name is changed by other rules that have higher priority than **-special** when **-special** rules are used; such as **-equal\_ports\_nets** and **-case\_insensitive**. For more information, see the APPLYING NAME RULES section of the **define\_name\_rules** man page.

To determine the current value of this variable, use the **printvar change\_names\_dont\_change\_bus\_members** command. For a list of all system variables and their current values, use the **print\_variable\_group system** command.

---

### SEE ALSO

**change\_names(2)**  
**define\_name\_rules(2)**

---

## **check\_design\_allow\_inconsistent\_input\_port**

Specifies the severity level to apply when the tool finds a port that is not being used in accordance with its stated direction.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

none

---

### **DESCRIPTION**

When this variable is set to true, the **compile** and **check\_design** commands issue warnings when ports that are not being used in accordance with their stated direction exist in the design. The command continues running after issuing a warning.

When the variable is set to false, the **compile** and **check\_design** commands report errors when any such ports are detected. When the **compile** command encounters an error, it quits and returns a status of 0. When the **check\_design** command encounters an error, it continues to run without any change in return status.

The default value of this variable is false.

To determine the current value of this variable, use the **get\_app\_var check\_design\_allow\_inconsistent\_input\_port** command.

---

### **SEE ALSO**

[check\\_design\(2\)](#)  
[compile\(2\)](#)  
[LINT-69\(n\)](#)

---

## check\_design\_allow\_inconsistent\_output\_port

Specifies the severity level to apply when the Design Compiler tool finds an output port direction that is not used in accordance with its stated direction.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

none

---

### DESCRIPTION

When this variable is set to true, the **compile** and **check\_design** commands issue warning messages when an output port direction is not used as specified in the design. The command continues running after issuing a warning message.

When the variable is set to false, the **compile** and **check\_design** commands report error messages when any output ports are detected. When the **compile** command encounters an error, it quits and returns a status of 0. When the **check\_design** command encounters an error, it continues to run without any change in return status.

The default is true.

To determine the current value of this variable, use the **get\_app\_var check\_design\_allow\_inconsistent\_output\_port** command.

---

### SEE ALSO

[check\\_design\(2\)](#)  
[compile\(2\)](#)  
[LINT-70\(n\)](#)  
[LINT-68\(n\)](#)

---

## **check\_design\_allow\_multiply\_driven\_nets\_by\_inputs\_and\_outp**

Controls whether the tool checks for input ports that connect to multiply driven nets whose drivers include an output port or pin.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

none

---

### **DESCRIPTION**

When this variable is set to **true**, the **compile** and **check\_design** commands skip the checking of input ports that connect to multiply driven nets whose drivers include an output port or pin.

When the variable is set to **false**, the tool reports errors when input ports are connected to multiply driven nets whose drivers include an output port or pin. When the **compile** command encounters an error, it quits and returns a status of 0. When the **check\_design** command encounters an error, it continues to run without any change in return status.

To determine the current value of this variable, use the **get\_app\_var**  
**check\_design\_allow\_multiply\_driven\_nets\_by\_inputs\_and\_outputs** command.

---

### **SEE ALSO**

**check\_design(2)**  
**compile(2)**

---

## **check\_design\_allow\_non\_tri\_drivers\_on\_tri\_bus**

Specifies the severity level to apply when the tool finds three-state buses with non-three-state drivers in the design.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true

---

### **GROUP**

none

---

### **DESCRIPTION**

When this variable is set to true, the **compile** and **check\_design** commands issue warnings when three-state buses with non-three-state drivers exist in the design. The command continues running after a warning is issued.

When the variable is set to false, the **compile** and **check\_design** commands report errors on three-state buses. When the **compile** command encounters an error, it quits and returns a status of 0. When the **check\_design** command encounters an error, it continues to run without any change in return status.

The default value of this variable is true.

To determine the current value of this variable, use the **get\_app\_var check\_design\_allow\_non\_tri\_drivers\_on\_tri\_bus** command.

---

### **SEE ALSO**

[check\\_design\(2\)](#)  
[compile\(2\)](#)

---

## check\_design\_allow\_unknown\_wired\_logic\_type

Specifies the severity level to apply when the tool finds nets with multiple drivers of the unknown wired-logic type.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

none

---

### DESCRIPTION

When this variable is set to **true**, the **compile** and **check\_design** commands report a warning for nets with multiple drivers of the unknown wired-logic type. When the variable is set to **false**, the commands report an error.

When the **compile** command encounters an error, it quits and returns a status of 0. When the **check\_design** command encounters an error, it continues to run without any change in return status.

The default value of this variable is **true**.

To determine the current value of this variable, use the **get\_app\_var check\_design\_allow\_unknown\_wired\_logic\_type** command.

---

### SEE ALSO

[check\\_design\(2\)](#)  
[compile\(2\)](#)

---

## check\_design\_check\_for\_wire\_loop

Controls whether the tool checks for wire loops that have a timing loop with no cells in it.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

none

---

### DESCRIPTION

When this variable is set to true, the **compile** and **check\_design** commands issue When the **compile** command encounters an error, it quits and returns a status of 0. When the **check\_design** command encounters an error, it continues to run without any change in return status.

When the variable is set to false, the tool skips the checking of wire loops in the design.

The default value of this variable is true.

To determine the current value of this variable, use the **get\_app\_var check\_design\_check\_for\_wire\_loop** command.

---

### SEE ALSO

[check\\_design\(2\)](#)  
[compile\(2\)](#)

---

## **check\_design\_check\_multidriven\_output\_ports**

Controls whether the tool checks for output ports that connect to multi-driver nets.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

none

---

### **DESCRIPTION**

When this variable is set to **true**, the **check\_design** command checks for output ports that connect to multi-driver nets.

When the variable is set to **false**, the tool does not check for output ports that connect to multi-driver nets.

To determine the current value of this variable, use the **get\_app\_var check\_design\_check\_multidriven\_output\_ports** command.

---

### **SEE ALSO**

[check\\_design\(2\)](#)

---

## check\_error\_list

Specifies the error codes for which the **check\_error** command checks.

---

### TYPE

list

---

### DEFAULT

CMD-004 CMD-006 CMD-007 CMD-008 CMD-009 CMD-010 CMD-011 CMD-012 CMD-014 CMD-015 CMD-016 CMD-019 CMD-026  
CMD-031 CMD-037 DB-1 DCSH-11 DES-001 ACS-193 FILE-1 FILE-2 FILE-3 FILE-4 LINK-7 LINT-7 LINT-20 LNK-023 OPT-100 OPT-  
101 OPT-102 OPT-114 OPT-124 OPT-127 OPT-128 OPT-155 OPT-157 OPT-181 OPT-462 UI-11 UI-14 UI-15 UI-16 UI-17 UI-19 UI-20  
UI-21 UI-22 UI-23 UI-40 UI-41 UID-4 UID-6 UID-7 UID-8 UID-9 UID-13 UID-14 UID-15 UID-19 UID-20 UID-25 UID-27 UID-28 UID-29  
UID-30 UID-32 UID-58 UID-87 UID-103 UID-109 UID-270 UID-272 UID-403 UID-440 UID-444 UIO-2 UIO-3 UIO-4 UIO-25 UIO-65 UIO-  
66 UIO-75 UIO-94 UIO-95 EQN-6 EQN-11 EQN-15 EQN-16 EQN-18 EQN-20

---

### DESCRIPTION

This variable specifies the error codes for which the **check\_error** command checks. The **check\_error** command returns a 1 if any of the specified error codes have been generated by a previous command in the current session.

You can use this capability to stop batch jobs in which the specified error codes occur.

To determine the current value of this variable, use the **printvar check\_error\_list** command.

---

### SEE ALSO

**check\_error(2)**

---

## clock\_attributes

Contains attributes placed on clocks.

---

## DESCRIPTION

Contains attributes that can be placed on clocks.

To set an attribute, use the command identified in the individual description of that attribute. To determine the value of an attribute, use the **get\_attribute** command. To remove attributes, use the **remove\_attribute** command.

For a more detailed explanation of an attribute, refer to the manual pages of the appropriate **set** command. For information on all attributes, refer to the **attributes** manual page.

### Clock Attributes

`dont_touch_network`

When a design is optimized, **compile** assigns **dont\_touch** attributes to all cells and nets in the transitive fanout of **dont\_touch\_network** ports. The **dont\_touch** assignment stops at the boundary of storage elements. An element is recognized as storage only if it has setup or hold constraints. Set with **set\_dont\_touch\_network**.

`fix_hold`

Specifies that **compile** should attempt to fix hold violations for timing endpoints related to this clock. Set with **set\_fix\_hold**.

`max_fall_delay`

A floating point value that specifies the maximum falling delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_max\_delay**.

`max_rise_delay`

A floating point value that specifies the maximum rising delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_max\_delay**.

`max_time_borrow`

A floating point number that establishes an upper limit for time borrowing; that is, it prevents the use of the entire pulse width for level-sensitive latches. Units are those used in the technology library. Set with **set\_max\_time\_borrow**.

`min_fall_delay`

A floating point value that specifies the minimum falling delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_min\_delay**.

`min_rise_delay`

A floating point value that specifies the minimum rising delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_min\_delay**.

`period`

Assigns a value to the clock period. The clock period (or cycle time) is the shortest time during which the clock waveform repeats. For a simple waveform with one rising and one falling edge, the period is the difference between successive rising edges. Set with **create\_clock -period period\_value**.

**hold\_uncertainty**

Specifies a negative uncertainty from the edges of the ideal clock waveform. Set with **set\_clock\_uncertainty -hold**.

**setup\_uncertainty**

Specifies a positive uncertainty from the edges of the ideal clock waveform. Set with **set\_clock\_uncertainty -setup**.

**propagated\_clock**

Specifies that the clock edge times be delayed by propagating the values through the clock network. If this attribute is not present, ideal clocking is assumed. Set with **set\_propagated\_clock**.

---

## SEE ALSO

[get\\_attribute\(2\)](#)  
[remove\\_attribute\(2\)](#)  
[attributes\(3\)](#)

---

## collection\_result\_display\_limit

Sets the maximum number of objects that can be displayed by any command that displays a collection.

---

### TYPE

integer

---

### DEFAULT

100

---

### DESCRIPTION

This variable sets the maximum number of objects that can be displayed by any command that displays a collection. The default is 100.

When a command (for example, **add\_to\_collection**) is issued at the command prompt, its result is implicitly queried, as though the **query\_objects** command had been called. You can limit the number of objects displayed by setting this variable to an appropriate integer. A value of -1 displays all objects; a value of 0 displays the collection handle ID instead of the names of any objects in the collection.

To determine the current value of this variable, use the **printvar collection\_result\_display\_limit** command.

---

### SEE ALSO

`collections(2)`  
`printvar(2)`  
`query_objects(2)`

---

## **command\_log\_file**

The **command\_log\_file** variable is obsolete. Use the **sh\_command\_log\_file** variable instead.

---

## company

Specifies the name of the company where Synopsys software is installed. The company name is displayed on the schematics.

---

### TYPE

string

---

### DEFAULT

""

---

### DESCRIPTION

This variable specifies the name of the company where Synopsys software is installed. The company name is displayed on the schematics.

To determine the current value of this variable use the **printvar company** command. For a list of all system variables and their current values, use the **print\_variable\_group system** command.

---

## compatibility\_version

Sets the default behavior of the system to be the same as the Synopsys software version specified in the variable.

---

### TYPE

string

---

### DEFAULT

current release

---

### DESCRIPTION

This variable sets the default behavior of the system to be the same as the Synopsys software version specified in the variable. This setting provides compatibility for script command files written in previous software versions. The scripts are run on the current version of the software, so results are usually better. However, the script performs the same default actions here as it did on the specified software version.

To determine the current value of this variable use the **printvar compatibility\_version** command. For a list of all system variables and their current values, use the **print\_variable\_group system** command.

---

## compile\_adjust\_max\_processes\_used

Enables automatic adjustment of number of multiprocesses in **compile**, **compile\_ultra**, **parallel\_execute**, and **redirect -bg** commands.

---

### TYPE

Integer

---

### DEFAULT

1

---

### DESCRIPTION

By default, the **compile** or **compile\_ultra** command runs new processes in parallel. The number of cores to run processes is controlled by the **set\_host\_options -max\_cores** command.

When you set the variable to **1** (the default) and if there are insufficient resources to run new processes in parallel, the **compile** or **compile\_ultra** command adjusts the number of cores used to proceed, instead of terminating. However, the command continues to execute if and only if one new process succeeds.

Similarly, the **parallel\_execute** command reduces the number of processes to be used and continues to execute in the main process if the first new process fails. The **Redirect -bg** command executes in the main process if new processes fail.

The tool behaves as follows based on the **compile\_adjust\_max\_processes\_used** variable settings:

- **1** (the default): The tool automatically adjusts the number of cores during multiprocessing if the **overcommit\_memory** parameter is set to **2** (no overcommit).
- **0**: The tool does not adjust the number of cores.
- **2**: the tool adjusts the number of cores irrespective of the **overcommit\_memory** parameter settings.

---

### SEE ALSO

UIO-306(n)  
UIO-307(n)

---

## compile\_advanced\_fix\_multiple\_port\_nets

Controls whether the **compile** or **compile\_ultra** command fixes multiple port nets using rewiring and buffering.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

true in DC Explorer

---

### DESCRIPTION

When the value is **true**, the **compile** or **compile\_ultra** command fixes multiple port nets using rewiring and buffering. Where possible, all multiple port nets and constant-driven ports are fixed by changing the connections elsewhere in the hierarchy. Any remaining multiple port nets and constant ports are fixed using buffering.

Use the following command to determine the current value of the variable:

```
prompt> printvar compile_advanced_fix_multiple_port_nets
```

---

### SEE ALSO

`set_fix_multiple_port_nets(2)`

---

## **compile\_allow\_dw\_hierarchical\_inverter\_opt**

Allows the phase inversion boundary optimization to be applied to DesignWare components.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

The **compile\_allow\_dw\_hierarchical\_inverter\_opt** variable allows the phase inversion boundary optimization to be applied to DesignWare components, when boundary optimization in general is permitted on the component.

The default value of this variable is false, which prevents the **compile** command from changing the phase of DesignWare component output signals. Other boundary optimizations are still attempted.

Setting the variable to true enables the phase inversion on DesignWare component outputs. Note that the true setting may interfere with formal verification of the design.

---

### **SEE ALSO**

[compile\(2\)](#)

---

## **compile\_assume\_fully\_decoded\_three\_state\_busses**

Specifies whether the **compile** and **translate** commands can assume that three-state buses are fully decoded.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

When this variable value is set to true, the **compile** and **translate** commands assume that three-state buses are fully decoded, and therefore can be replaced by multiplexed buses when mapping to a library that contains no three-state cells. The default value is false.

To determine the current value of this variable, use the **printvar compile\_assume\_fully\_decoded\_three\_state\_busses** command. For a list of compile variables and their current values, use the **print\_variable\_group compile** command.

---

### **SEE ALSO**

---

## compile\_auto\_ungroup\_area\_num\_cells

Defines the minimum number of child cells a design hierarchy must have so that the **compile -auto\_ungroup area** command does not ungroup the hierarchy.

---

### TYPE

integer

---

### DEFAULT

30 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

The **compile\_auto\_ungroup\_area\_num\_cells** variable defines the minimum number of child cells a design hierarchy must have so that the **compile -auto\_ungroup area** command does not ungroup the hierarchy. The default value for this variable is 30. By default, the threshold check is done only on the child cells of its immediate hierarchy. You can enable the threshold check to include all of the leaf cells of this design hierarchy (for example, both the child cells of its immediate hierarchy and all of its subdesigns) by setting the **compile\_auto\_ungroup\_count\_leaf\_cells** variable to true.

To determine the current value of this variable, use the **printvar compile\_auto\_ungroup\_area\_num\_cells** command. For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

[compile\(2\)](#)  
[compile\\_auto\\_ungroup\\_count\\_leaf\\_cells\(3\)](#)  
[compile\\_auto\\_ungroup\\_override\\_wlm\(3\)](#)

---

## compile\_auto\_ungroup\_count\_leaf\_cells

Determines if the number of leaf cells should be counted or the number of child cells in the immediate hierarchy should be counted to compare against the value of the **compile\_auto\_ungroup\_area\_num\_cells** variable in area-based auto-ungrouping.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

The **compile\_auto\_ungroup\_count\_leaf\_cells** variable determines the way the tool counts the number of child cells of a design hierarchy. When this variable is set to false, the default value, only child cells in the immediate hierarchy are counted; the number of child cells in its subdesigns is considered.

When this variable is set to true, the leaf cells of a design hierarchy (for example, both the child cells of its immediate hierarchy and all its subdesigns) are considered. The number of child cells of a design hierarchy is compared against the value of **compile\_auto\_ungroup\_area\_num\_cells** in area-based auto-ungrouping to determine if a design hierarchy can be considered as a candidate for ungrouping.

Because of this, for the same design hierarchy and same variable settings for auto-ungroup, a certain design hierarchy may be ungrouped if **compile\_auto\_ungroup\_count\_leaf\_cells** is set to false, but may not be ungrouped if it is set to true. For example, assume design hierarchy A has 20 immediate child cells and a subdesign B, and subdesign B has another 40 immediate child cells with no more subdesigns. In a compile flow where **compile -auto\_ungroup area** is used and the **compile\_auto\_ungroup\_area\_num\_cells** variable is set to 30, if **compile\_auto\_ungroup\_count\_leaf\_cells** is set to false, design hierarchy A will be considered as a candidate for auto-ungrouping because it has  $20 < 30$  child cells in its immediate hierarchy. However, if **compile\_auto\_ungroup\_count\_leaf\_cells** is set to true, since design A has  $20+40 = 60 > 30$  leaf cells, it will not be considered as a candidate for auto-ungrouping.

To determine the current value of this variable, use the **printvar compile\_auto\_ungroup\_count\_leaf\_cells** command. For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

[compile\(2\)](#)  
[compile\\_auto\\_ungroup\\_area\\_num\\_cells\(3\)](#)



---

## compile\_auto\_ungroup\_override\_wlm

Specifies whether the compiler considers a cell instance for automatic ungrouping, if the cell's wire load model differs from that of its parent.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies whether the compiler considers a cell instance for automatic ungrouping, if the cell's wire load model is different from the wire load model of its parent cell. The default value is false, which means that the cell instance is not considered for automatic ungrouping should its wire load model differ from that of its parent.

If you set the value of this variable as true, the ungrouped child cells of the named cell instance inherit the wire load model of its parent. A result of setting this variable to true is that the tool might use more pessimistic wire load models for the child cells of this cell instance. This in turn might offset the delay improvement from the **compile -auto\_ungroup area** or **-compile -auto\_ungroup delay** command and lead to seemingly worse timing behavior for the design.

To determine the current value of this variable, use the **printvar compile\_auto\_ungroup\_override\_wlm** command. For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

[compile\(2\)](#)  
[compile\\_auto\\_ungroup\\_area\\_num\\_cells\(3\)](#)

---

## compile\_automatic\_clock\_phase\_inference

Specifies the method used to determine the clock phase during sequential mapping.

---

### TYPE

string

---

### DEFAULT

strict

---

### DESCRIPTION

When this variable is set to strict, the **compile** command attempts to determine the desired clock phase for each unmapped register, and does not allow opposite phase devices to be used in constructing registers.

When the value is set to relaxed, **compile** allows the implementation of an opposite phase device for a register only if there is no other way to implement that register.

When set to none, **compile** ignores the clock phase during sequential mapping. The default value is *strict*.

To determine the current value of this variable, use the **printvar compile\_automatic\_clock\_phase\_inference** command. For a list of compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

---

## compile\_cell\_density\_aware\_optimization

Enable cell density awareness, during delay optimizations in **DCNXT compile\_ultra -spg**.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer  
false in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

During Post placement delay optimization, **Design Compiler** can clump/over-lap critical cells in the design while improving WNS, TNS. This could impact the correlation to post legalization result in IC Compiler II. When you set the **compile\_cell\_density\_aware\_optimization** variable to **true**, Design Compiler identifies and reduces cell density violations, while performing Delay Optimizations. This lessens the impact on correlation to post legalization of IC Compiler II. The design will have reduced density violations when this variable is enabled, but not always a zero violation. This is not a placement feature and none of the placer density variables will affect it.

---

### EXAMPLES

The following example shows how to enable and disable this feature for a design:

```
prompt> set compile_cell_density_aware_optimization true
prompt> set compile_cell_density_aware_optimization false
```

---

### SEE ALSO

`compile_ultra(2)`  
`compile_cell_density_aware_optimization_threshold(3)`

---

## compile\_cell\_density\_aware\_optimization\_threshold

The value you specify sets the threshold for how tightly the cells are allowed to clump during delay optimizations.

---

### TYPE

float

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer 1.15 in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

When **compile\_cell\_density\_aware\_optimization** variable is set to **true**, the value of the **compile\_cell\_density\_aware\_optimization\_threshold** variable determines which regions of physical design are considered to be **dense**. During delay optimizations, Design Compiler tries to control the dense regions by preventing cell clumping above this threshold.

---

### EXAMPLE

The following example sets the threshold to 1.5.

```
prompt> set compile_cell_density_aware_optimization_threshold 1.5
```

---

### SEE ALSO

[compile\\_cell\\_density\\_aware\\_optimization\(3\)](#)

---

## compile\_checkpoint\_phases

Determines whether checkpoints are generated during execution of the **compile** command.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

When true, checkpoints automatically between each phase of **compile**. The default is false.

To determine the current value of this variable, type **printvar compile\_checkpoint\_phases**. For a list of all **compile** variables and their current values, type **print\_variable\_group compile**.

---

### SEE ALSO

---

## compile\_clock\_gating\_through\_hierarchy

Controls whether the **compile** or **compile\_ultra** command with the **-gate\_clock** option performs clock gating through hierarchy boundaries.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

When this variable is set to **true**, **compile -gate\_clock** and **compile\_ultra -gate\_clock** are allowed to use one clock gate to gate registers in different hierarchical cells. This can increase the number of clock gating opportunities and reduce the number of clock gates.

When the value is **false** (the default), the clock gating is only performed in such a way that clock gates are in the same hierarchy cell as all registers gated by them.

A clock gating cell will not be modified or removed if it or its parent hierarchical cell is marked **dont\_touch** with the **set\_dont\_touch** command; it will not be modified by global clock gating optimization.

To determine the current value of this variable, use the **printvar compile\_clock\_gating\_through\_hierarchy** command. For a list of all compile variables and their current values, use **print\_variable\_group compile**.

This variable is not supported in DC Explorer.

---

### SEE ALSO

---

## compile\_create\_wire\_load\_table

Controls the type of wire load model generated by the **create\_wire\_load** command.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable is used to control the type of wire load model generated by the **create\_wire\_load** command. The default setting of this variable is false and the wire load models generated are in the wire\_load format. It includes resistance, capacitance, area slope coefficients, and fanout\_length (fanout, length, average\_cap, std\_dev, and points)

If this variable is set to true the wire load models generated are in the wire\_load\_table format. The resistance is calculated explicitly for each fanout using the back-annotated values and the tree type from the current operating condition set on the design.

To determine the current value of this variable, use **printvar compile\_create\_wire\_load\_table**.

For a list of all **compile** variables and their current values, use the **print\_variable\_group compile** command. For a list of all **links\_to\_layout** variables and their current values, type **print\_variable\_group links\_to\_layout**.

---

### SEE ALSO

[compile\(2\)](#)

---

## **compile\_delete\_unloaded\_sequential\_cells**

Controls whether the **compile** command deletes unloaded sequential cells.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true

---

### **DESCRIPTION**

By default, the **compile** command deletes unloaded sequential cells. To retain such cells, set the **compile\_delete\_unloaded\_sequential\_cells** variable to false.

During compile, if a design contains sequential cells that do not drive loads, the logic driven by that sequential cell might be optimized away, resulting in an inferred no-load cell, or no path to a primary output.

---

### **SEE ALSO**

[compile\(2\)](#)

---

## compile\_dft\_log\_print\_mis\_info

If this is true, info about multi-input switching cells decomposition will be displayed in the log file. Please note that, this will be supported only if MIS cells decomposition is enabled using **compile\_enable\_mis\_cells\_decomposition** or **dft\_enable\_mis\_cells\_decomposition** variable.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

If this is true, info about multi-input switching cells decomposition will be displayed in the log file using INFO-123 messages. This helps to display the reason for skipping certain cells from decomposition. Please note that, this will be supported only if MIS cells decomposition is enabled using **compile\_enable\_mis\_cells\_decomposition** or **dft\_enable\_mis\_cells\_decomposition** variable.

---

### EXAMPLES

The following examples show how to enable and disable printing of information about skipped cells during decomposition of MIS cells:

```
prompt> set compile_dft_log_print_mis_info true  
prompt> set compile_dft_log_print_mis_info false
```

---

### SEE ALSO

`compile_enable_mis_cells_decomposition(3)`  
`dft_enable_mis_cells_decomposition(3)`  
`report_misViolation_summary(2)`

---

## compile\_disable\_hierarchical\_inverter\_opt

Controls whether inverters can be moved across hierarchical boundaries during boundary optimization.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable affects the behavior of the boundary optimization feature in the **compile** command. By default, boundary optimization attempts to push inverters across hierarchies to improve the optimization cost of the design. However, if the **compile\_disable\_hierarchical\_inverter\_opt** variable is set to true, boundary optimization will not move inverters across hierarchical boundaries even if doing so could improve the design.

To determine the current value of this variable, use the **printvar compile\_disable\_hierarchical\_inverter\_opt** command. For a list of all **compile** variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

[compile\(2\)](#)  
[set\\_boundary\\_optimization\(2\)](#)  
[port\\_complement\\_naming\\_style\(3\)](#)

---

## **compile\_dont\_touch\_annotated\_cell\_during\_inplace\_opt**

Controls whether cells that have annotated delays can be optimized.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

When true, **reoptimize\_design -in\_place** and **compile -in\_place** disallow swapping cells that have annotated delays. When false (the default value), **reoptimize\_design -in\_place** and **compile -in\_place** allow annotated cells to be swapped for cells without annotated delay.

This variable is used to run **reoptimize\_design -in\_place** and **compile -in\_place** with annotated cell and net delays and allowing only buffers to be inserted. When this variable is true, Design Compiler considers all cells with annotated delays as **dont\_touch**. This allows avoiding exchanging a cell with annotated delays for a cell with lower estimated delays but higher real delays.

To determine the current value of this variable, use **printvar compile\_dont\_touch\_annotated\_cell\_during\_inplace\_opt**. For a list of all **compile** variables and their current values, use the **print\_variable\_group compile** command. For a list of all **links\_to\_layout** variables and their current values, use the **print\_variable\_group links\_to\_layout** command.

---

### **SEE ALSO**

**compile(2)**

---

## compile\_dont\_use\_dedicated\_scanout

Controls whether optimizations use a scan cell's dedicated scan-out pin for functional connections.

---

### TYPE

integer

---

### DEFAULT

1

---

### DESCRIPTION

Optimizations by **place\_opt**, **clock\_opt**, **route\_opt** and **psyn\_opt** do not use a scan cell's dedicated scan-out pin for functional connections. When this variable is set to 0, optimizations can use dedicated scan-out pins for functional connections.

Dedicated scan-out pins must be identified in the technology library using the **test\_output\_only** attribute. Contact your ASIC Vendor to ensure that dedicated scan-out pins are correctly modeled in the library that you are using.

To determine the current value of this variable, use the **printvar compile\_dont\_use\_dedicated\_scanout** command.

---

## compile\_enable\_async\_mux\_mapping

Controls whether the **compile** or **compile\_ultra** command tries to preserve multiplexers in the fanin cone of asynchronous register pins.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When this variable is set to **true**, the **compile** or **compile\_ultra** command tries to preserve multiplexers in the fanin cone of asynchronous register pins. More specifically, if multiplexing logic (any MUX\_OP or 2-input SELECT\_OP) is found that is in the fanin of only asynchronous register pins (clock, and asynchronous set and reset), then this logic is mapped to a multiplexer, and a size-only attribute is set on the multiplexer. If the MUX\_OP or SELECT\_OP cell is specified as **dont\_touch**, Design Compiler does not map the cell to a multiplexer. The purpose of this is to reduce the occurrence of glitches on asynchronous register pins. The default value of this variable is true.

To determine the current value of the **compile\_enable\_async\_mux\_mapping** variable, use the **printvar compile\_enable\_async\_mux\_mapping** command.

For a list of all compile variables and their current values, use **print\_variable\_group compile**.

---

### SEE ALSO

[hdlin\\_mux\\_size\\_only\(3\)](#)

---

## compile\_enable\_ccd

Enables concurrent clock and data optimization (CCD) during compile.

---

### TYPE

*Boolean*

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer false in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

With this application variable set to true, concurrent clock and data optimization (CCD) is enabled during incremental compile which does the useful skew computation. The useful skew computation incrementally updates the existing user-specified offsets (both balance points and clock latencies).

The magnitude of skew offsets added by compile CCD is bounded by the **ccd\_max\_postpone** and the **ccd\_max\_prepone** application variables.

The general recommendation is to align with the CCD setting during place\_opt.

---

### SEE ALSO

`compile(2)`  
`ccd_max_postpone(3)`  
`ccd_max_prepone(3)`

---

## compile\_enable\_constant\_propagation\_with\_no\_boundary\_opt

Controls whether the constants are propagated across hierarchies when boundary optimization is disabled.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When this variable is set to **true** (the default), the tool propagates constants across design hierarchies and simplifies the logic even when boundary optimization is disabled by setting the **boundary\_optimization** attribute to **false** or using the **-no\_boundary\_optimization** option with the **compile\_ultra** command.

When the variable is set to **false**, the tool does not propagate constants across hierarchical boundaries.

The variable has no effect on other optimizations, such as the propagation of equal and opposite information, the propagation of unconnected port information, and phase inversion.

To stop constant propagation through specific design hierarchies, use the **set\_compile\_directives** command with the **-constant\_propagation** option set to **false** on a specific hierarchical pin or a list of hierarchical pins. When you do this, the tool sets a **const\_prop\_off** attribute on the specified pins and disables constant propagation through them.

Use the following command to determine the current value of the variable:

```
printvar compile_enable_constant_propagation_with_no_boundary_opt
```

---

### SEE ALSO

`compile_ultra(2)`  
`set_boundary_optimization(2)`  
`set_compile_directives(2)`

---

## compile\_enable\_enhanced\_leakage\_optimization

Enables enhanced leakage optimization in **compile\_ultra**.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

When you set the **compile\_enable\_enhanced\_leakage\_optimization** variable to **true**, the **compile\_ultra** command runs a strategy intended to improve the leakage of the design, possibly at the cost of additional runtime and a change of qor trajectory. Use the **compile\_ultra** command without the variable as the default strategy, and enable this variable to fine tune the flow, as needed, on designs that require further leakage optimization.

---

### EXAMPLES

The following example shows how to enable and disable enhanced leakage optimization for a design:

```
prompt> compile_enable_enhanced_leakage_optimization true  
prompt> compile_enable_enhanced_leakage_optimization false
```

---

### SEE ALSO

[compile\\_ultra\(2\)](#)

---

## compile\_enable\_min\_delay\_fixing

Enables hold fixing in the DC Ultra wire load model flow when set to **true**.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

When you set **compile\_enable\_min\_delay\_fixing** to **true** in DC Ultra wire load mode, Design Compiler performs minimum path, minimum capacitance, and minimum transition time fixing. However, be aware that enabling this variable can increase area and runtime.

The **compile\_enable\_min\_delay\_fixing** variable has no effect in DC Expert, Design Compiler in topographical mode, or Design Compiler Graphical flows. Hold fixing is not performed in these flows.

Use the following command to determine the current value of the variable:

```
prompt> printvar compile_enable_min_delay_fixing
```

---

### SEE ALSO

---

## compile\_enable\_mis\_cells\_decomposition

If this is true, combinational multi-input switching cells tied to same net will be decomposed as part of compile and incremental compile(s). This feature is supported in DCG and DCNXT only.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

The variable **compile\_enable\_mis\_cells\_decomposition** is used to enable or disable decomposition of combinational MIS cells tied to same net in the subsequent compile command(s). This feature is supported in DCG and DCNXT only.

---

### EXAMPLES

The following examples show how to enable and disable decomposition of MIS cells during compile:

```
prompt> set compile_enable_mis_cells_decomposition true  
prompt> set compile_enable_mis_cells_decomposition false
```

---

### SEE ALSO

`report_misViolationSummary(2)`  
`compileDFTLogPrintMisInfo(3)`

---

## **compile\_enable\_multibit\_rewiring\_in\_incremental**

---

**TYPE**

Boolean

---

**DEFAULT**

false

---

**DESCRIPTION**

When set to true before **compile\_ultra -incremental**, and when the target library includes library cells with mixed drive properties, a new step will be enabled that will apply sizing with rewiring capabilities to the multi-bit registers of the netlist in order to save power when not all the slices of a multi-bit register are critical.

---

**SEE ALSO**

[enable\\_enhanced\\_physical\\_multibit\\_banking\(3\)](#)  
[compile\\_enable\\_physical\\_multibit\\_banking\(3\)](#)

---

## **compile\_enable\_physical\_multibit\_banking**

---

**TYPE**

Boolean

---

**DEFAULT**

false

---

**DESCRIPTION**

When set to true before main **compile\_ultra**, the enhanced physical multibit banking engine will be executed after the second placement of the netlist during main **compile\_ultra** in order to improve the QoR before incremental compile as compared to a standalone physical multibit banking.

---

**SEE ALSO**

[enable\\_enhanced\\_physical\\_multibit\\_banking\(3\)](#)

---

## compile\_enable\_register\_merging

Controls whether the **compile** command should identify and merge equal and opposite registers.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When this variable is set to **true** (the default), the **compile** command tries to identify and merge registers in the current design that are equal or opposite. This improves the area of the design.

When two registers are merged, the tool issues an OPT-1215 message.

Register merging can also be controlled by a design-by-design or a cell-by-cell basis by using the **set\_register\_merging** command. However, the **compile\_enable\_register\_merging** variable takes precedence over the **set\_register\_merging** command.

Note: No register merging is performed if the **compile\_enable\_register\_merging** variable is set to **false**.

To determine the current value of the **compile\_enable\_register\_merging** variable, use the **printvar compile\_enable\_register\_merging** command.

For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

**set\_register\_merging(2)**  
**compile\_enable\_register\_merging\_with\_exceptions(3)**

---

## compile\_enable\_register\_merging\_with\_exceptions

Controls whether the **compile** command tries to identify and merge equal and opposite registers with path group exceptions.

---

### TYPE

Boolean

---

### DEFAULT

true in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

When this variable is set to **true**, the **compile** command tries to identify and merge registers in the current design that are equal or opposite even if they are with path group exceptions, as long as they are in the same path group. This improves the area of the design.

When this variable is set to **false** (the default), the **compile** command does not merge registers with path group exceptions.

To determine the current value of the **compile\_enable\_register\_merging\_with\_exceptions** variable, use the **printvar compile\_enable\_register\_merging\_with\_exceptions** command.

For a list of all compile variables and their current values, use **print\_variable\_group compile**.

---

### SEE ALSO

`set_register_merging(2)`  
`compile_enable_register_merging(3)`

---

## compile\_enable\_total\_power\_optimization

Controls NXT total power optimization feature.

This variable is supported only in NXT shell and in topographical mode.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable controls NXT total power optimization feature which includes both sizing and placement related total power optimizations. For the NXT total power optimization feature to work in MCMM designs, atleast one scenario should be set as dynamic.

This variable is supported only in NXT shell and in topographical mode.

Allowed values are **false** and **true**.

When set to **false**, NXT optimizes only for leakage power.

When set to **true**, NXT optimizes combinedly for both leakage and dynamic power. Enabling NXT total power optimization features can lead to different QoR tradeoff behaviors than the ones seen with the default compile flow and hence, it can affect WNS and/or TNS and/or leakage power.

To determine the current value of this variable, use the **printvar compile\_enable\_total\_power\_optimization** command. For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

`compile(2)`

---

## compile\_enhanced\_tns\_optimization

Enables enhanced TNS optimization (ETO) for delay optimization engines with the **compile\_ultra -spg** command in the Design Compiler NXT tool.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer  
false in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

When you set the **compile\_enhanced\_tns\_optimization** variable to **true**, the **compile\_ultra** command while running in **dcnxt\_shell** runs a strategy intended to improve the TNS of the design, possibly at the cost of additional runtime, area, and worst negative slack (WNS).

Use the **compile\_ultra** command without the variable as the default strategy, and enable the **compile\_enhanced\_tns\_optimization** variable to fine-tune the flow as needed on designs that require further TNS optimization. This strategy performs a different method of selecting optimization candidates to achieve better TNS optimization.

To enable enhanced TNS optimization with the **compile\_ultra** and **compile\_ultra -incremental** commands, use the **set\_app\_var compile\_enhanced\_tns\_optimization true** variable.

From R2020.09-SP1 **compile\_enhanced\_tns\_optimization\_in\_incremental** is on by default when **compile\_timing\_high\_effort\_tns** is enabled and the user is running **compile\_ultra -incremental**.

---

### EXAMPLES

To enable enhanced TNS optimization only with the **compile\_ultra** command and not with the **compile\_ultra -incremental** command, set the variables as follows:

```
prompt> set_app_var compile_enhanced_tns_optimization true
prompt> set_app_var compile_enhanced_tns_optimization_in_incremental false
```

To disable enhanced TNS optimization during compile, set the variables as follows:

```
prompt> set_app_var compile_enhanced_tns_optimization false
prompt> set_app_var compile_enhanced_tns_optimization_in_incremental default
```

---

## SEE ALSO

`compile_ultra(2)`  
`compile_enhanced_tns_optimization_in_incremental(3)`  
`compile_enhanced_tns_optimization_effort_level(3)`

---

## compile\_enhanced\_tns\_optimization\_effort\_level

Effort level parameter for **compile\_enhanced\_tns\_optimization** for enhanced cell candidate selection for delay optimization engines in **DCNXT compile\_ultra -spg**.

---

### TYPE

String

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer low in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

When you meet the requirements for running and have enabled **compile\_enhanced\_tns\_optimization** variable to **true**, large designs may benefit from setting **compile\_enhanced\_tns\_optimization\_effort\_level** to "medium" or "high", rather than the default of "low". Adjust this variable to fine tune the flow, as needed, on large designs that require further tns optimization. Timing on smaller designs may be negatively impacted when running a higher effort level.

---

### EXAMPLES

The following example shows how to set the parameter for enhanced tns optimization effort level for a design:

```
prompt> set compile_enhanced_tns_optimization_effort_level "low"
prompt> set compile_enhanced_tns_optimization_effort_level "medium"
prompt> set compile_enhanced_tns_optimization_effort_level "high"
```

---

### SEE ALSO

[compile\\_ultra\(2\)](#)  
[compile\\_enhanced\\_tns\\_optimization\(3\)](#)

---

---

## compile\_enhanced\_tns\_optimization\_in\_incremental

Enables enhanced TNS optimization (ETO) for delay optimization engines with the **compile\_ultra -incremental -spg** command in the Design Compiler NXT tool.

This strategy performs a different method of selecting optimization candidates to achieve better TNS optimization while running in dcnxt\_shell, possibly at the cost of additional runtime area and WNS.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer default in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

With this variable set to **default**, the delay optimization engines strictly observe the value defined by the **compile\_enhanced\_tns\_optimization** variable. The default setting also allows backward compatibility, if needed.

From R2020.09-SP1 **compile\_enhanced\_tns\_optimization\_in\_incremental** is on by default when **compile\_timing\_high\_effort\_tns** is enabled and the user is running **compile\_ultra -incremental**.

However, setting the **compile\_enhanced\_tns\_optimization\_in\_incremental** variable to **true** or **false** allows more explicit control over enhanced TNS optimization in the **compile\_ultra -incremental** flow step.

It is generally recommended

- To use the **compile\_ultra -incremental** command without enhanced TNS optimization as the default strategy and
- To enable enhanced TNS optimization in the **compile\_ultra -incremental** step to fine-tune the flow as needed on designs that require further TNS optimization

Depending on scripting and debugging requirements, enhanced TNS optimization can be enabled during the **compile\_ultra -incremental** step (if required) in one of the following ways:

- Set the **compile\_enhanced\_tns\_optimization** variable to **true** only before the **compile\_ultra -incremental** step or
- Set the **compile\_enhanced\_tns\_optimization\_in\_incremental** variable to **true** at any point in the flow either before the **compile\_ultra** or **compile\_ultra -incremental** step

Setting of the variables is not order dependent, as the tool uses the **compile\_enhanced\_tns\_optimization** value for both compile and incremental compile, unless the **compile\_enhanced\_tns\_optimization\_in\_incremental** variable is set to **true** or **false**.

---

## EXAMPLES

To enable enhanced TNS optimization only with the **compile\_ultra -incremental** command and not with the **compile\_ultra** command, set the variables as follows:

```
prompt> set_app_var compile_enhanced_tns_optimization false  
prompt> set_app_var compile_enhanced_tns_optimization_in_incremental true
```

To disable enhanced TNS optimization during the compile and incremental compile steps, set the variables as follows:

```
prompt> set_app_var compile_enhanced_tns_optimization false  
prompt> set_app_var compile_enhanced_tns_optimization_in_incremental default
```

---

## SEE ALSO

[compile\\_ultra\(2\)](#)  
[compile\\_enhanced\\_tns\\_optimization\(3\)](#)  
[compile\\_enhanced\\_tns\\_optimization\\_effort\\_level\(3\)](#)

---

## compile\_final\_drc\_fix

Controls final DRC fixing stage of the compile command to fix DRC violations.

This variable is supported only in topographical mode.

---

### TYPE

string

---

### DEFAULT

none

---

### DESCRIPTION

This variable controls whether final DRC fixing stage is invoked or not to fix different type of DRC violations.

This variable is supported only in topographical mode.

Allowed values are **none** (the default), **transition**, **fanout**, **capacitance** and **all**.

When set to **none**, no DRC violation are fixed in final DRC fixing stage of compile command.

When set to **transition**, only max\_transition violations are fixed in final DRC fixing stage of compile command.

When set to **fanout**, only max\_fanout violations are fixed in final DRC fixing stage of compile command.

When set to **capacitance**, only max\_capacitance violations are fixed in final DRC fixing stage of compile command.

If the variable is set to **all**, compile tries to fix all three - max\_transition, max\_fanout and max\_capacitance violations in final DRC fixing stage of compile command.

To determine the current value of this variable, use the **printvar compile\_final\_drc\_fix** command. For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

[compile\(2\)](#)

---

## compile\_fix\_cell\_degradation

Controls whether the algorithms for fixing cell degradation violation are activated.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

When true, the algorithms for fixing cell degradation violations in **compile** and **reoptimize\_design** are activated. Different strategies, such as sizing and buffering, try to fix violations of the cell degradation design rule.

To determine the current value of this variable, type **printvar compile\_fix\_cell\_degradation**. For a list of all compile variables and their current values, type **print\_variable\_group compile**.

---

### SEE ALSO

[compile\(2\)](#)

---

## compile\_high\_effort\_area

If this is true, high effort area optimization will be done as part of compile and incremental compile(s). This feature is supported in DCNXT only.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

The variable **compile\_high\_effort\_area** is used to enable high effort for area optimization in the subsequent compile command(s). Please note that when this variable is enabled, the following variables get enabled by default unless explicitly disabled by the user - **compile\_optimize\_netlist\_area\f**, **compile\_high\_effort\_area\_in\_incremental\f** and **compile\_optimize\_netlist\_area\_in\_incremental\f**. This feature is supported in DCNXT only.

---

### EXAMPLES

The following examples show how to enable and disable high effort area optimization during compile:

```
prompt> set compile_high_effort_area true  
prompt> set compile_high_effort_area false
```

---

### SEE ALSO

`compile_high_effort_area_in_incremental(3)`  
`compile_optimize_netlist_area(3)`  
`compile_optimize_netlist_area_in_incremental(3)`

---

## **compile\_high\_effort\_area\_in\_incremental**

If this is true, high effort area optimization will be done as part of incremental compile(s). This feature is supported in DCNXT only.

---

### **TYPE**

Boolean

---

### **DEFAULT**

default

---

### **DESCRIPTION**

The **compile\_high\_effort\_area\_in\_incremental** variable is used to set the area optimization effort as high for the incremental compile command(s). Please note that the default value of this variable will be set according to the settings used for primary compile. This means, this variable will be set to true by default, if **compile\_high\_effort\_area** is set. Thus if high effort area optimization is enabled/disabled for compile, it will be automatically enabled/disabled for incremental compile as well. This feature is supported in DCNXT only.

---

### **EXAMPLES**

The following examples show how to explicitly enable and disable high effort area optimization during incremental compile:

```
prompt> set compile_high_effort_area_in_incremental true  
prompt> set compile_high_effort_area_in_incremental false
```

---

### **SEE ALSO**

`compile_high_effort_area(3)`  
`compile_optimize_netlist_area_in_incremental(3)`

---

## compile\_high\_pin\_density\_cell\_optimization

Directs the **compile\_ultra -spg** command to replace high-pin-density cells with low-pin-density variant-aware electrically equivalent (EEQ) cells that can be routed more easily.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

High-pin-density cells are hard to route in high utilization regions of the design. When you set the **compile\_high\_pin\_density\_cell\_optimization** variable to **true**, the **compile\_ultra -spg** command replaces high-pin-density cells with equivalent low-pin-density variant-aware equivalent EEQ cells to reduce congestion and improve routability with minimal impact to quality of results (QoR).

This feature works only in topographical mode.

To determine the current value of this variable, use the **printvar compile\_high\_pin\_density\_cell\_optimization** command.

---

### EXAMPLES

The following example enables the variable, and the high-pin-density cells are replaced during synthesis:

```
prompt> set_app_var compile_high_pin_density_cell_optimization true
true
```

---

### SEE ALSO

`compile_high_pin_density_cell_optimization_utilization_threshold(3)`  
`compile_ultra(2)`  
`printvar(2)`



---

## compile\_high\_pin\_density\_cell\_optimization\_utilization\_threshold

Specifies the utilization threshold percentage that determines which regions of the design will be targeted for cell optimization by the **compile\_ultra** command.

---

### TYPE

Float. Valid range is from 0.0 to 1.0.

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
0.5 in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

When the **compile\_high\_pin\_density\_cell\_optimization** variable is set to **true**, the value of the **compile\_high\_pin\_density\_cell\_optimization\_utilization\_threshold** variable controls which high-pin-density cells are replaced by electrically equivalent (EEQ) cells by the **compile\_ultra -spg** command.

The tool divides the design into smaller areas and computes the regional utilization of these regions. When the utilization of a region is above the user-specified threshold, the high-pin-density cells in these regions are swapped with equivalent low-pin-density electrically equivalent (EEQ) cells that can be routed more easily.

This feature works only in topographical mode.

To determine the current value of this variable, use the **printvar compile\_high\_pin\_density\_cell\_optimization\_utilization\_threshold** command.

---

### EXAMPLES

The following example shows how to set the utilization threshold percentage to identify regions in the design for replacing high-pin-density cells during synthesis:

```
prompt> set compile_high_pin_density_cell_optimization_utilization_threshold 0.75
0.75
```

## SEE ALSO

`compile_high_pin_density_cell_optimization(3)`  
`compile_ultra(2)`  
`printvar(2)`

---

## compile\_high\_pin\_density\_cell\_spreading

Places high pin density cells so they are spread out by the **compile\_ultra** command to improve routing.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

High pin density cells are hard to route when they are placed too close together. When you set the **compile\_high\_pin\_density\_cell\_spreading** variable to **true**, the **compile\_ultra** command separates high pin density cells to reduce congestion and improve routability.

This feature works only in topographical mode.

To determine the current value of this variable, use the **printvar compile\_high\_pin\_density\_cell\_spreading** command.

---

### EXAMPLES

The following example enables the variable and the high pin density cells in the design are spread out during placement:

```
prompt> set_app_var compile_high_pin_density_cell_spreading true
true
```

---

### SEE ALSO

`compile_high_pin_density_cell_spreading_threshold(3)`  
`compile_ultra(2)`  
`printvar(2)`

---

## compile\_high\_pin\_density\_cell\_spreading\_threshold

Specifies the pin density threshold percentage that determines which high pin density cells will be spread out by the **compile\_ultra** command

---

### TYPE

Float. Valid range is from 0.0 to 1.0.

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

0.9 in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

When the **compile\_high\_pin\_density\_cell\_spreading** variable is set to **true**, the value of the **compile\_high\_pin\_density\_cell\_spreading\_threshold** variable controls which high pin density cells will be placed with a larger separation by the **compile\_ultra** command. The cells with a pin density that exceeds the threshold percentage are spread out during placement,

This feature works only in topographical mode.

To determine the current value of this variable, use the **printvar compile\_high\_pin\_density\_cell\_spreading\_threshold** command.

---

### EXAMPLES

The following example shows how to set the pin density threshold percentage to spread out high pin density cells during placement for a design:

```
prompt> set compile_high_pin_density_cell_spreading_threshold 0.75  
0.75
```

---

### SEE ALSO

[compile\\_high\\_pin\\_density\\_cell\\_spreading\(3\)](#)  
[compile\\_ultra\(2\)](#)

```
printvar(2)
```

---

## compile\_hold\_reduce\_cell\_count

Controls whether the logic used to fix hold time violations is selected based on minimum cell count or minimum area.

---

### TYPE

Boolean

---

### DEFAULT

strict

---

### DESCRIPTION

When true, Design Compiler uses the minimum number of cells to fix the hold time (min path) violations, rather than choosing cells that minimize the total new area. This means that the area may be worsened (compared to the default flow) while the hold time violations are being fixed.

---

### SEE ALSO

---

## compile\_implementation\_selection

Controls whether the **compile** command reevaluates the current implementation of a synthetic module during optimization.

---

### TYPE

Boolean

---

### DEFAULT

true in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

When this variable is set to true (the default), the **compile** command reevaluates the current implementation of a synthetic library module and replaces it, if appropriate for optimizing the design. When the value is false, this optimization is disabled, saving CPU time with a potential loss of quality of results.

To determine the current value of this variable, use the **printvar compile\_implementation\_selection** command. For a list of compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

[compile\(2\)](#)  
[set\\_implementation\(2\)](#)

---

## compile\_inbound\_cell\_optimization

Enables inbound cell optimization in **compile\_ultra**.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When you set the **compile\_inbound\_cell\_optimization** variable to **true**, the **compile\_ultra** command runs a strategy intended to control the usage of inbound cells in the design. This may increase or reduce the number of inbound cells depending on the threshold specified by **compile\_inbound\_max\_cell\_percentage**.

---

### EXAMPLES

The following example shows how to enable and disable inbound cell optimization for a design:

```
prompt> set compile_inbound_cell_optimization true  
prompt> set compile_inbound_cell_optimization false
```

---

### SEE ALSO

`compile_ultra(2)`  
`compile_inbound_max_cell_percentage(3)`  
`compile_inbound_sitedef_name(3)`

---

## compile\_inbound\_max\_cell\_percentage

Specifies a threshold for the percentage of total inbound cells in the design.

---

### TYPE

float

---

### DEFAULT

10.0

---

### DESCRIPTION

The value you specify for the **compile\_inbound\_max\_cell\_percentage** variable defines a maximum threshold for the percentage of the total inbound cells in the design. The **inbound cell optimization** will control the number of inbound cells in the design so that the percentage of inbound cells never exceeds the specified value.

---

### EXAMPLE

The following example sets the inbound cells threshold to 10%.

```
prompt> set compile_inbound_max_cell_percentage 10.0
```

---

### SEE ALSO

`compile_inbound_cell_optimization(3)`  
`compile_inbound_sitedef_name(3)`

---

## compile\_inbound\_sitedef\_name

Specifies sitedef name for inbound cells.

---

### TYPE

string

---

### DESCRIPTION

This variable **compile\_inbound\_sitedef\_name** specifies the name of your library's site definition for inbound cells. This name is required for identifying inbound library cells while performing **inbound cell optimization**.

---

### EXAMPLES

The following example shows how to set this variable:

```
prompt> set compile_inbound_sitedef_name ibunit
```

---

### SEE ALSO

`compile_inbound_cell_optimization(3)`  
`compile_inbound_max_cell_percentage(3)`

---

## **compile\_instance\_name\_prefix**

Specifies the prefix used in generating cell instance names when the **compile** command is run.

---

### **TYPE**

string

---

### **DEFAULT**

U

---

### **DESCRIPTION**

This variable specifies the prefix used in generating cell instance names when running the **compile** command.

To determine the current value of this variable, use the **printvar compile\_instance\_name\_prefix** command. For a list of compile variables and their current values, use the **print\_variable\_group compile** command.

---

### **SEE ALSO**

---

## compile\_instance\_name\_suffix

Specifies the suffix used for generating cell instance names when the **compile** command is run.

---

### TYPE

string

---

### DEFAULT

""

---

### DESCRIPTION

This variable specifies the suffix used for generating cell instance names when running the **compile** command.

To determine the current value of this variable, use the **printvar compile\_instance\_name\_suffix** command. For a list of **compile** variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

---

## compile\_keep\_original\_for\_external\_references

Instructs the **compile** command to keep the original design when there is an external reference to the design.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

none

---

### DESCRIPTION

By default, the **compile** command modifies the original copy of the designs in the current design. When the **compile\_keep\_original\_for\_external\_references** variable is set to true, the original design and its subdesigns are copied and preserved (before doing any modifications during compile), if there is an external reference to this design.

For example, if there is an instance of a design named *bot*, *U1* in the current design named *mid*, and there is an external reference from another design named *top* that is not part of current hierarchy, then *U1* will be unqualified to a new design named *bot\_0* before doing any modification to the design. Therefore, when you change the *current\_design* to *top* and perform a link, the original *bot* design will be linked into the *current\_hierarchy*.

Usually this is needed only when you are doing a bottom compile without setting **dont\_touch** attributes on all of the subdesigns, particularly with boundary optimization turned on during compile.

If there is a **dont\_touch** attribute on any of the instances of the design or in the design itself, this variable does not have any effect.

---

### SEE ALSO

[compile\(2\)](#)

## compile\_log\_format

Controls the format of the columns to be displayed during the mapping phases of **compile** and **reoptimize\_design** commands.

---

### TYPE

string

---

### DEFAULT

%elap\_time %area %wns %tns %drc %endpoint in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable controls the format of the columns to be displayed during the mapping phases of **compile** and **reoptimize\_design** commands. The default specification is shown in the DEFAULT section above and results in an output display format similar to Table 1. The headings and order of the columns displayed correspond to the keywords specified in the syntax. For example, "%elap\_time" specifies the ELAPSED TIME column, "%area" the AREA column, and so on.

**Table 1**  
Default Compile Log Output Format

| ELAPSED<br>TIME | AREA   | TOTAL          |             |               |                           | ENDPOINT |
|-----------------|--------|----------------|-------------|---------------|---------------------------|----------|
|                 |        | WORST<br>SLACK | NEG<br>COST | SETUP<br>COST | DESIGN<br>RULE COST       |          |
| 18:00:30        | 1498.0 | 4.12           | 32.2        | 0.0           | U1/U2/CURRENT_SECS_reg[4] |          |
| 18:00:30        | 1498.0 | 4.07           | 31.6        | 0.0           | U1/U2/CURRENT_SECS_reg[4] |          |
| 18:00:30        | 1497.0 | 4.07           | 30.6        | 0.0           | U1/U2/CURRENT_SECS_reg[4] |          |
| 18:00:31        | 1499.0 | 3.61           | 27.5        | 0.0           | U1/U2/CURRENT_SECS_reg[4] |          |
| 18:00:31        | 1499.0 | 3.58           | 26.1        | 0.0           | U1/U2/CURRENT_SECS_reg[4] |          |

By default, the columns in Table 1 are nine characters wide except for the ENDPOINT column, which is 25 characters. The default precision for the floating-point data types AREA, TOTAL NET SLACK, and DESIGN RULE COST is 1 digit to the right of the decimal point; for WORST NEG SLACK, 2 digits.

There are 13 possible columns that can be displayed; only 6 are displayed in the default format. You can create a customized output format by specifying any number of the available columns, with their keywords and defaults. For example, specifying "%mem" displays the MBYTES column with a width of 6 characters and a precision of 1 digit to the right of the decimal point. When you specify "%mem", the following information is displayed horizontally under these column names: COLUMN HEADER, DATA TYPE, KEYWORD, WIDTH, PRECISION, and FORMAT.

|        |                |     |   |   |   |
|--------|----------------|-----|---|---|---|
| MBYTES | floating point | mem | 6 | 1 | f |
|--------|----------------|-----|---|---|---|

See the section "Definitions of Column Fields with Default Values" for descriptions and contents of the fields corresponding to the column headers.

## Changing Default Column Parameters

You can change the default column parameters using the optional expression (w(pf,split)), as follows:

```
set_app_var compile_log_format = "%elap_time %area %wns %tns %drc %endpoint".
```

where each column entry can be configured as follows:

```
"%keyword(w(pf,split))"
```

The quantities w, p, f, and split are defined as follows:

w

Specifies the column width. Specifying a width less than 6 defaults the width to 6. For string data types, specifying a width greater than 99 defaults the width to 99. For decimal or floating-point data types, specifying a width greater than 25 defaults to 25.

p

For floating-point numbers only. Specifies the precision in number of digits. See also the definition of f.

f

For floating-point numbers only. Specifies the precision format; values are f or g. The value of f specifies that the precision is expressed as the number of digits to the right of the decimal point. The value of g specifies that the precision is expressed as the total number of significant digits. For example, expressing the floating-point number 13.533 with a precision of 3 in the f format reports the number as 13.533 while in the g format the number is reported as 13.5.

split

By default, if the information in a given field exceeds the column width, it pushes out the next field and the next field is not printed on a new line. Specifying split overrides the default and causes the next field to begin on a new line, starting in the correct column.

## 1998.02 Compile Log Format

The fields for the 1998.02 version are TRIALS, AREA, DELTA DELAY, TOTAL NEG SLACK, and DESIGN RULE COST. The DELTA DELAY field is renamed MAX DELAY COST in the 1998.08 format.

To display the same log format as the 1998.02 version, set the variable as follows:

```
compile_log_format = ""
```

## Definitions of Column Fields with Default Values

The fields listed under the 5 columns are defined in the following text, showing the default values. Except where noted, units are those defined by the library.

AREA

Shows the area of the design during the optimization.

Data type: floating point  
Keyword: are  
Width: 9  
Precision: 1  
Format: f

CPU SEC

Shows the process CPU time used, in seconds.

Data type: decimal  
Keyword: cpu

Width: 7  
Precision: ignored  
Format: ignored

#### DELTA DELAY

See MAX DELAY COST.

#### DESIGN RULE COST

Measures the distance between the actual results and user-specified design rule constraints.

Data type: floating point  
Keyword: drc  
Width: 9  
Precision: 1  
Format: f

#### ELAPSED TIME

Tracks the elapsed time since the beginning of the current **compile** or **reoptimize\_design**.

Data type: string  
Keyword: elap\_time  
Width: 9  
Precision: ignored  
Format: ignored

#### MAX DELAY COST

Shows the current maximum delay cost of the design, which is the sum of the worst negative slack (max\_path violation) in each path group. Called DELTA DELAY in the 1998.02 version.

Data type: floating point  
Keyword: max\_delay  
Width: 9  
Precision: 2  
Format: f

#### MBYTES

Shows the process memory used, in mbytes.

Data type: floating point  
Keyword: mem  
Width: 6  
Precision: 1  
Format: f

#### MIN DELAY COST

Shows the current minimum delay cost of the design, which is the sum of the worst negative slack (min\_path violation) in each path group.

Data type: floating point  
Keyword: min\_delay  
Width: 9  
Precision: 2  
Format: f

#### TIME OF DAY

Shows the current time.

Data type: string  
Keyword: time  
Width: 8

Precision: ignored  
Format: ignored

#### TOTAL SETUP COST

Shows the sum of the weighted costs across all endpoints in the design.

Data type: floating point  
Keyword: tns  
Width: 9  
Precision: 1  
Format: f

#### TRIALS

Tracks the number of transformations that the optimizer tries before making the current selection.

Data type: decimal  
Keyword: trials  
Width: 6  
Precision: ignored  
Format: ignored

#### WORST NEG SLACK

Shows the worst negative slack (max\_path violation) in all path groups.

Data type: floating point  
Keyword: wns  
Width: 9  
Precision: 2  
Format: f

#### ENDPOINT

Shows the current endpoint being on which work is being done. When the delay violation is being fixed, the object for the ENDPOINT is a cell or a port. When the design rule violations are being fixed, the object for the ENDPOINT is a net.

Data type: string  
Keyword: endpoint  
Width: 25  
Precision: ignored  
Format: ignored

#### PATH GROUP

Shows the current path group of a valid endpoint.

Data type: string  
Keyword: group\_path  
Width: 10  
Precision: ignored  
Format: ignored

#### DYNAMIC POWER

Shows the dynamic power of the design during optimization.

Data type: floating point  
Keyword: dynamic\_power  
Width: 9  
Precision: 4  
Format: f

#### LEAKAGE POWER

Shows the leakage power of the design during optimization.

Data type: floating point  
Keyword: leakage\_power  
Width: 9  
Precision: 4  
Format: f

#### TOTAL POWER

Shows the total power of the design during optimization. (total\_power = dynamic\_power + leakage\_power)

Data type: floating point  
Keyword: total\_power  
Width: 9  
Precision: 4  
Format: f

#### INSTANCE COUNT

Shows the total cell instance count of the design during optimization.

Data type: integer  
Keyword: instance\_count  
Width: 9  
Precision: ignored  
Format: ignored

---

## EXAMPLES

The following example increases the precision of the WORST NEG SLACK column by 1 (to 3 digits from its default of 2 digits):

```
prompt> set compile_log_format {%elap_time %area %wns(.3) %tns %drc %endpoint}
```

The following example replaces the TOTAL SETUP COST column in the default format with the CPU column:

```
prompt> set compile_log_format {%elap_time %area %wns %cpu %drc %endpoint}
```

In the following example, if the ENDPOINT value exceeds the column width, the next field begins on a new line, starting in the correct column:

```
prompt> set compile_log_format {%elap_time %wns %endpoint(19,split) %group_path}
```

The following example displays only the MIN DELAY COST column, changes the column width to 12 characters from the default of 9, and expresses the value with a precision of 3 significant digits:

```
prompt> set compile_log_format {%-min_delay(12.3g)}
```

The following example sets the compile log to the same format as the 1998.02 version:

```
prompt> set compile_log_format = ""
```

To determine the current value of this variable, use the **printvar compile\_log\_format** command. For a list of all compile variables and their current values, use **print\_variable\_group compile**.

---

## SEE ALSO

[compile\(2\)](#)

---

## compile\_log\_print\_pathgroups\_in\_delayopt

Enables printing of Elapsed time, PG, hiers, cells processed in an iteration in delay optimization. This variable is supported in topographical mode in compile\_ultra as well as compile\_ultra -incremental. This can be used along with the variable "compile\_log\_format".

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

Enables printing of Elapsed time, PG, hiers, cells processed in an iteration in delay optimization. This variable is supported only in topographical mode in compile\_ultra as well as compile\_ultra -incremental. This can be used along with the variable "compile\_log\_format".

Allowed values are **false** (the default), **true**.

To determine the current value of this variable, use the **printvar compile\_log\_print\_pathgroups\_in\_delayopt** command. For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

compile(2)

---

## compile\_negative\_logic\_methodology

Specifies the logic value connected to floating inputs by the **compile** and **translate** commands.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

When this variable is set to **true**, the **compile** and **translate** commands connect floating inputs to logic 1. When set to the default value of **false**, floating inputs are connected to logic 0.

This variable assignment should be placed at the beginning of the `.synopsys_dc.setup` file (or `dc_shell` session) and the value should not be changed during the session.

To determine the current value of this variable, use the **printvar compile\_negative\_logic\_methodology** command. For a list of all **compile** variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

---

## compile\_no\_new\_cells\_at\_top\_level

Controls whether the **compile** command adds new cells to the top-level design.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When this variable is set to **true**, no new cells are added to the top-level design of the hierarchy during **compile**. New cells are added only to lower levels.

This variable is used when the original design has no top-level cells, to prevent the addition of new cells when adding buffers for timing optimization and design rule fixes.

If the design has leaf cells at the top level, the cells are optimized as normal, so this variable should be set to **false** (the default). Setting this variable to **true** means that **compile** will not add any cells during buffering and design rule fixing, even if the design is flat.

Note that if **set\_isolate\_ports** requires insertion of new cells at the top level, then these cells will be added even if **compile\_no\_new\_cells\_at\_top\_level** is set to **true**. This is because port isolation takes precedence.

To determine the current value of this variable, use the **printvar compile\_no\_new\_cells\_at\_top\_level** command. For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

---

## compile\_optimize\_netlist\_area

If this is true, area optimization will be done as part of compile and incremental compile(s). This feature is supported in DCNXT only.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

The **compile\_optimize\_netlist\_area** variable is used to enable area optimization in subsequent compile and incremental compile command(s). This will be enabled by default if **compile\_high\_effort\_area** is turned on. This can be disabled by explicitly resetting the value for this variable. This feature is supported in DCNXT only.

---

### EXAMPLES

The following examples show how to enable and disable area optimization during compile:

```
prompt> set compile_optimize_netlist_area true  
prompt> set compile_optimize_netlist_area false
```

---

### SEE ALSO

[compile\\_optimize\\_netlist\\_area\\_in\\_incremental\(3\)](#)  
[compile\\_high\\_effort\\_area\(3\)](#)

---

## **compile\_optimize\_netlist\_area\_in\_incremental**

If this is true, area optimization will be done as part of incremental compile(s). This feature is supported in DCNXT only.

---

### **TYPE**

Boolean

---

### **DEFAULT**

default

---

### **DESCRIPTION**

The **compile\_optimize\_netlist\_area\_in\_incremental** variable is used to enable area optimization for the incremental compile command(s). Please note that the default value for this variable will be picked up based on the settings used for primary compile. That means, this variable will be set to true by default, if **compile\_optimize\_netlist\_area** is set. Thus if area optimization is enabled/disabled for compile, it will be automatically enabled/disabled for incremental compile as well. This feature is supported in DCNXT only.

---

### **EXAMPLES**

The following examples show how to explicitly enable and disable area optimization during incremental compile:

```
prompt> set compile_optimize_netlist_area_in_incremental true  
prompt> set compile_optimize_netlist_area_in_incremental false
```

---

### **SEE ALSO**

`compile_optimize_netlist_area(3)`  
`compile_high_effort_area_in_incremental(3)`

---

## compile\_optimize\_unloaded\_seq\_logic\_with\_no\_bound\_opt

Controls whether unused sequential logic is optimized away when boundary optimization is disabled.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When this variable is set to **true**, the tool optimizes away unused sequential logic even when boundary optimization is disabled by setting the **boundary\_optimization** attribute to **false** or using the **-no\_boundary\_optimization** option with the **compile\_ultra** command.

In an attempt to remove sequential logic, the tool removes unloaded combinational logic and unloaded nets as well.

If unloaded hierarchical pins are used as connection points for post-compile steps, e.g. clock-gating, dft insertion, etc. then the logic and nets fanning into these pins will need to be protected by a **dont\_touch** in order to preserve them.

When the variable is set to **false** (the default), the tool does not optimize unused sequential logic.

Use the following command to determine the current value of the variable:

```
prompt> printvar compile_optimize_unloaded_seq_logic_with_no_bound_opt
```

---

### SEE ALSO

[compile\\_ultra\(2\)](#)  
[set\\_boundary\\_optimization\(2\)](#)  
[set\\_compile\\_directives\(2\)](#)

---

## **compile\_power\_domain\_boundary\_optimization**

Disables boundary optimization across power domain boundaries when set to false.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true

---

### **GROUP**

mv

---

### **DESCRIPTION**

This variable controls whether to allow boundary optimization across all power domain boundaries. By default, boundary optimization across power domain boundaries is enabled in **compile\_ultra**, unless specifically disabled by a command such as **set\_boundary\_optimization**. This variable provides an automatic way to disable boundary optimization across all power domain boundaries.

---

### **SEE ALSO**

[set\\_boundary\\_optimization\(2\)](#)

---

## compile\_prefer\_mux

Maps multiplexing logic in the RTL to MUX trees where necessary to reduce design congestion. This feature is only available in Design Compiler Graphical.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

When you set the **compile\_prefer\_mux** variable to **true**, the **compile\_ultra** command runs a strategy intended to improve the congestion of designs that contain multiplexing logic, possibly at the cost of additional runtime and some area. The default flow typically maps most multiplexers to and-or-invert (AOI) logic in order to minimize area, but in some cases this can result in congestion hotspots. With **compile\_prefer\_mux** enabled, multiplexing logic that is likely to cause congestion is converted to MUX trees where possible.

The **compile\_prefer\_mux** variable is supported only in the initial compile step, not in incremental compile.

You can use the variable as an alternative to the **map\_to\_mux** attribute, which requires you to manually investigate where the attribute needs to be applied.

---

### EXAMPLES

The following example shows how to enable and disable congestion-driven MUX optimization for a design. Enable the **compile\_prefer\_mux** variable by setting it to **true** before running the initial compile.

```
prompt> set compile_prefer_mux true
prompt> set compile_prefer_mux false
```

---

### SEE ALSO

```
compile_ultra(2)
set_attribute(2)
get_attribute(2)
remove_attribute(2)
```

---

## compile\_preserve\_subdesign\_interfaces

Controls whether the **compile** command preserves the subdesign interface.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When this variable is set to **true**, it disables customization of logic external to a subdesign during **compile**, and preserves the subdesign interface. When set to **false** (the default), **compile** customizes the logic external to a subdesign based on the subdesign's internal logic.

**compile\_ultra -no\_boundary\_optimization** command sets this variable to **true**.

Optimization across hierarchies can take place in 2 different ways:

- (1) Optimizing the logic external to a subdesign, based on that specific subdesign

In this type of optimization, the external logic is customized based on the contents of the subdesign. For example, if one of the output ports of the subdesign is internally grounded, then that constant can be pushed out to the higher level of the design and used at that level to further optimize the design. With this optimization, top-level ("pins-out") functionality of all blocks is preserved. However, if the specification of the lower-level subdesign is then changed; for example, so that the output port is instead tied to a logic 1, the higher level of the design cannot be updated accordingly. The logic propagation already occurred based on the original implementation of the subdesign.

By default, **compile** performs this type of optimization. Setting **compile\_preserve\_subdesign\_interfaces** to **true** disables the optimization.

- (2) Optimizing the logic internal to a subdesign, based on its specific instantiation

In Design Compiler, hierarchical optimization of a subdesign's internal logic is referred to as boundary optimization. By default, **compile** does not perform boundary optimization. You can enable boundary optimization for a particular module or for the entire design by running the **compile -boundary\_optimization** command or by setting the **boundary\_optimization** attribute on the desired object using the **set\_boundary\_optimization** command.

As a result of boundary optimization, the subdesign is customized for its specific environment. Boundary optimization results in an improved overall cost, but the subdesign is no longer functionally equivalent to its original specification. Therefore, the subdesign cannot be reused in an environment that does not match the environment for which it was optimized. For example, if one of the subdesign's input pins is tied externally to a logic 0, boundary optimization can push that logic constant into the subdesign and further optimize the logic in the subdesign. However, if this subdesign is then used in any environment where the input is no longer tied to a logic 0, the resulting design can be logically incorrect.

The **compile\_preserve\_subdesign\_interfaces** variable has no effect on objects that are enabled for boundary optimization.

By default, **compile** performs (1) described above, but not (2). When boundary optimization is enabled, both types of hierarchical optimization are performed.

Set the **compile\_preserve\_subdesign\_interfaces** variable to **true** whenever the internal functionality of a subdesign might change in the future. In this case, **compile** should be disabled from customizing the external logic based on the internal logic of the block. When the internal logic of all blocks has stabilized, you can set this variable to **false** to allow further optimization of external logic based on the internal logic of the submodules.

To determine the current value of this variable, use the **printvar compile\_preserve\_subdesign\_interfaces** command. For a list of **compile** variables and their current values, use the **print\_variable\_group compile** command.

---

## SEE ALSO

[compile\(2\)](#)  
[compile\\_ultra\(2\)](#)  
[set\\_boundary\\_optimization\(2\)](#)  
[OPT-113\(n\)](#)

---

## compile\_print\_crossprobe\_info\_with\_seqmap\_messages

Adds cross probing information to register removal seqmap log file messages

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When this variable is set to **true** before compile, the tool prints cross-probe information (origin RTL file name with its full path and line number) of the registers optimized away with sequential optimization Information messages OPT-1206 (constant registers removed), OPT-1207(unloaded registers removed) and OPT-1215 (registers merged).

Use the following command to determine the current value of the variable:

```
prompt> printvar compile_print_crossprobe_info_with_seqmap_messages
```

---

### EXAMPLE

#### Constant register removed:

Information: The register 'a/b/const\_0\_reg { /users/testcases/top.v:49 }' is a constant and will be removed. (OPT-1206)

#### Unloaded register removed:

Information: The register 'a/b/unloaded\_reg{ /users/testcases/top.v:193 }' will be removed. (OPT-1207)

#### Register merged:

Information: In design 'RAM\_0', the register 'mul\_reg[1] { /user/testcases/top.v:113 }' is removed because it is merged to 'mul\_reg[0]'. (OPT-1215)

---

### SEE ALSO

---

## compile\_register\_replication

Controls register replication with the **compile\_ultra** and **compile** commands.

---

### TYPE

Boolean

---

### DEFAULT

default

---

### DESCRIPTION

When this variable is set to **true**, which is the default value when you use the **-timing\_high\_effort\_script** and **-spg** options, the **compile\_ultra** command tries to identify registers in the current design that can be split to balance the loads for better QoR. This feature works only in topographical mode.

Register splitting can also be controlled on a design-by-design or cell-by-cell basis using the **set\_register\_replication** command with the **compile** command. The variable and command do not affect each other and should be controlled independently.

To determine the current value of the **compile\_register\_replication** variable, use the **printvar compile\_register\_replication** command.

For a list of all compile variables and their current values, use **print\_variable\_group compile**.

---

### SEE ALSO

**set\_register\_replication(2)**

---

## compile\_register\_replication\_across\_hierarchy

Controls whether the **compile** command tries to perform register replication across hierarchies to improve timing.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

When **compile\_register\_replication\_across\_hierarchy** is set to **true**, the **compile** command enables register replication. In addition, it creates new ports on instances of subdesigns while performing register replication if it is necessary to improve the timing of the design. Register replication across hierarchies might change the interfaces among subdesign instances. If the interfaces are required to be preserved, this variable should be set to **false** (the default).

To determine the current value of the **compile\_register\_replication\_across\_hierarchy** variable, use the **printvar compile\_register\_replication\_across\_hierarchy** command.

For a list of all compile variables and their current values, use **print\_variable\_group compile**.

---

### SEE ALSO

[set\\_register\\_replication\(2\)](#)

---

## compile\_register\_replication\_do\_size\_only

Controls register replication for size-only cells during compile.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When this variable is set to **true** (the default), and the **compile\_register\_replication** variable is also set to **true**, the **compile\_ultra** command tries to identify registers in the current design that can be split to balance the loads for better QoR, even if they are size-only cells. This feature is available only in topographical mode.

To disable register replication for registers with a **size\_only** attribute, set the **compile\_register\_replication\_do\_size\_only** variable to **false**.

You can also control register splitting on a design-by-design or cell-by-cell basis by using the **set\_register\_replication** command with either the **compile** or **compile\_ultra** command. The **compile\_register\_replication\_do\_size\_only** variable and the **set\_register\_replication** command do not affect each other and should be controlled independently.

To determine the current value of the **compile\_register\_replication\_do\_size\_only** variable, use the **printvar compile\_register\_replication\_do\_size\_only** command.

For a list of all compile variables and their current values, use **print\_variable\_group compile**.

---

### SEE ALSO

**set\_register\_replication(2)**  
**compile\_register\_replication(3)**

---

## compile\_report\_on\_unmapped\_cells

Controls printing error messages when there are unmapped cells, PVT mismatches or placer errors in the design being synthesized.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When this variable is set to **true**, **compile\_ultra** will print out OPT-999 error message when any of the following condition is met,

- there are unmapped cells in the design
- there are PVT mismatches in the design
- placer has aborted due to over utilization
- basic gates are not available for synthesis

The unmapped cells in the design could be combination cells or power management cells. In the case of power management cells, user can refer to,  
- TRANS-11 messages to get more details on unampped isolation or enable level shifter cells. TRANS-11 will give details on why an isolation or enable level shifter is left unmapped.  
- PWR-662 messages to know the sequential elements with retention constraint that could not be mapped.

For PVT mismatches in the design, user can refer to LIBSETUP-051, LIBSETUP-052, LIBSETUP-053 and LIBSETUP-054 messages to identify the cause of PVT mismatch and fix the design constraints or make suitable PVT matching technology library cells available.

In the event the design has more than one issues listed above, OPT-999 error message will concatenate all the reasons and emit one error message. Here is a sample OPT-999 error message,

**Error: compile\_ultra is not successful, as there are unmapped isolation and mismatching PVT cells. Refer to TRANS-11, LIBSETUP-051/2/3/4 warning messages. (OPT-999)**

In the event there are not any of the issues listed above, **compile\_ultra**, will emit OPT-799 information message indicating synthesis is successful. This is how OPT-799 will be,

**Information: Design Compiler (DC) completed successfully. (OPT-799)**

To determine the current value of this variable, use the **printvar compile\_report\_on\_unmapped\_cells** command.

---

### SEE ALSO

---

## compile\_restructure\_sync\_set\_reset

Controls whether the **compile\_ultra** command tries to perform additional optimizations on the input logic to registers affected by the sync\_set\_reset attribute.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When you set this variable to **true**, the **compile\_ultra** command tries to perform additional logic optimization on the driving logic to registers affected by the sync\_set\_reset attribute.

To determine the current value of the **compile\_restructure\_sync\_set\_reset** variable, use the **printvar compile\_restructure\_sync\_set\_reset** command.

For a list of all compile variables and their current values, use **print\_variable\_group compile**.

---

### SEE ALSO

---

## compile\_retime\_exception\_registers

Controls whether registers with common path exceptions, including max\_path, min\_path, multicycle\_path, false\_path, and group\_path, can be moved by adaptive retiming.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable controls whether registers with common path exceptions, including max\_path, min\_path, multicycle\_path, false\_path, and group\_path, can be moved by adaptive retiming.

For example, if an SDC script contains the following command where **reg** is a register, there is a path exception on**reg**:

```
set_max_delay 1.0 -to reg
```

The variable only affects flows that use the **compile\_ultra** command with the **-retiming** option.

Allowed values are **false** (the default) and **true**.

If **false** is specified, adaptive retiming does not attempt to move registers with exceptions to improve timing or area.

If **true** is specified, adaptive retiming may try to move registers with the max\_path, min\_path, multicycle\_path, false\_path, and group\_path path exceptions to improve timing or area.

---

### SEE ALSO

[compile\\_ultra\(2\)](#)

---

## compile\_retime\_license\_behavior

Controls how the **compile** command behaves when the **optimize\_registers** or **balance\_registers** attribute is set on a design or parts of a design and the required license(s) (BOA-BRT or DC-Expert) are not available immediately.

---

### TYPE

string

---

### DEFAULT

wait in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable controls how the **compile** command behaves when the **optimize\_registers** or **balance\_registers** attribute is set on a design or parts of a design and the required licenses (BOA-BRT or DC-Expert) are not immediately available.

Allowed values are **wait** (the default), **stop**, and **next**.

- If **wait** is selected, **compile** waits and checks every 5 minutes until the license becomes available. Once the license is available **compile** resumes running.
- If **stop** is selected, **compile** is aborted immediately when the required license is not available.
- If **next** is selected, retiming is executed with the a license allowing less capabilities. If the **optimize\_registers** attribute is set and the BOA-BRT license is not available, retiming will be run with the DC-Expert license. QoR will likely be worse. For the **balance\_registers** attribute, there is no lower-level capability, so **next** has the same effect as **stop** for **balance\_registers**.

To avoid any waiting or aborting of the **compile** command because of retiming licensing, obtain the required license in dc\_shell before the start of **compile**. Use **get\_license BOA-BRT** or **get\_license DC-Expert** repeatedly until the command is successful.

To determine the current value of this variable, use the **printvar compile\_retime\_license\_behavior** command. For a list of all **compile** variables and their current values, use **print\_variable\_group compile**.

---

### SEE ALSO

**set\_balance\_registers(2)**  
**set\_optimize\_registers(2)**

---

## compile\_seqmap\_disable\_qn\_pin\_connections

Controls whether the **compile** command allows sequential elements to use qn pins for connections.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When the value of this variable is **true**, the **compile** command will avoid using qn pins when mapping the sequential elements in the design .

To determine the current value of this variable, use the **printvar compile\_seqmap\_disable\_qn\_pin\_connections** command. For a list of all compile variables and their current values, use **print\_variable\_group compile**.

---

### SEE ALSO

[compile\\_ultra\(2\)](#)

---

## compile\_seqmap\_enable\_output\_inversion

Controls whether the **compile** command allows sequential elements to have their output phase inverted. This variable has no effect on the **compile\_ultra** command.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When the value of this variable is **true**, the **compile** command allows the mapping of the sequential elements in the design to library cells whose output phase is inverted. This can help improve QoR. It is also useful when mapping sequential cells to a target library whose sequential cells have only one type of asynchronous inputs (either set or reset). In this case, the only way to match a sequential cell that uses the missing asynchronous input is to use a library cell with the other type of asynchronous input and to invert the output of that cell.

This variable has no effect on the **compile\_ultra** command. To control sequential output inversion for **compile\_ultra**, use the **-no\_seq\_output\_inversion** option to **compile\_ultra**. Use of the **-exact\_map** option would disable sequential output inversion even the value of this variable is true.

Note that when using sequential output inversion, you must use the SVF file to verify the functionality of the design using Formality.

To determine the current value of this variable, use the **printvar compile\_seqmap\_enable\_output\_inversion** command. For a list of all compile variables and their current values, use **print\_variable\_group compile**.

---

### SEE ALSO

[compile\\_ultra\(2\)](#)

---

## compile\_seqmap\_honor\_sync\_set\_reset

Controls whether the tool tries to keep the synchronous set and reset logic close to the registers during compile.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When the value is **true**, flip-flops with synchronous reset or preset pins are mapped in one of the following ways: If your library has registers with synchronous reset (or preset) pins, the reset (or preset) net is connected to the reset (or preset) pin of a register with a dedicated reset (or preset) pin. If your library does not have any registers with synchronous reset (or preset) pins, the tool adds extra logic to the data input to generate the reset (or preset) condition on a register without a reset (or preset) pin. In these cases, Design Compiler attempts to map the logic as close as possible to the data pin to minimize X-propagation problems that lead to synthesis/simulation mismatches. It is still important to use the **sync\_set\_reset** directive in your RTL so that Design Compiler can distinguish the reset (or preset) signals from other data signals and connect the reset signal as close to the register as possible.

To determine the current value of this variable, use the **printvar compile\_seqmap\_honor\_sync\_set\_reset** command. For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

[hdlin\\_ff\\_always\\_sync\\_set\\_reset\(3\)](#)

---

## compile\_seqmap\_identify\_shift\_registers

Controls the identification of shift registers in **compile -scan**. This feature is only supported in test-ready compile with Design Compiler Ultra with a multiplexed scan style.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When the value of this variable is set to the default value of **true**, Design Compiler Ultra automatically identifies shift registers in the design during test-ready compile.

When all of the shift registers are identified, only the first register is mapped to a scan cell, while the remaining registers are mapped to non-scan cells. This can save a significant amount of area for designs containing many identified shift registers.

Once these shift registers are identified by Design Compiler Ultra, DFT Compiler will also recognize the identified shift registers as shift-register scan segments. But DFT Compiler will break these scan segments, if necessary, to respect test setup requirements such as maximum chain length.

Shift registers that contain synchronous logic between the registers can also be identified if the synchronous logic can be controlled such that the data can be shifted from the output of the first register to the input of the next register. This synchronous logic can either be internal to the register (for example, synchronous reset and enable) or it can be external synchronous logic (for example, multiplexor logic between the registers). For shift registers identified with synchronous logic between the registers, DFT Compiler will add additional logic to the scan-enable signal during scan insertion in order to allow the data to be shifted between the registers when in scan mode. This capability is controlled by the **compile\_seqmap\_identify\_shift\_registers\_with\_synchronous\_logic** variable, and is enabled by default. See the **compile\_seqmap\_identify\_shift\_registers\_with\_synchronous\_logic** variable man page for details.

Shift-register identification is only supported in test-ready compile with Design Compiler Ultra with a multiplexed scan-style.

Set the **compile\_seqmap\_identify\_shift\_registers** variable to **false** if you do not want **compile\_ultra -scan** to identify shift registers, or if you want to rescan the shift registers already identified in the design back to scan cells.

The **compile\_seqmap\_identify\_shift\_registers\_with\_synchronous\_logic** variable does not have any effect when shift-register identification is disabled with the **compile\_seqmap\_identify\_shift\_registers** variable.

---

### SEE ALSO

```
compile_seqmap_identify_shift_registers_with_synchronous_logic(3)
```

---

## compile\_seqmap\_identify\_shift\_registers\_with\_synchronous\_logic

Controls whether shift registers that contain synchronous logic between the registers are identified. This variable only has an effect on DC Ultra optimization when shift register identification is enabled with the **compile\_seqmap\_identify\_shift\_registers** variable.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When the value of this variable is set to **true** and the value of the **compile\_seqmap\_identify\_shift\_registers** variable is set to **true**, DC Ultra automatically identifies shift registers that contain synchronous logic between the registers during test-ready compilation if the synchronous logic can be controlled such that data can be shifted from the output of the first register to the input of the next register. This synchronous logic can either be internal to the register (for example, synchronous reset and enable), or it can be external synchronous logic (for example, multiplexer logic between the registers).

For shift registers that have been identified, only the first register is mapped to a scan cell while the remaining registers are mapped to nonscan cells. This can save a significant amount of area for designs containing many identified shift registers. This capability is only available with test-ready compilation when using a multiplexed scan style.

After the shift registers are identified by DC Ultra, DFT Compiler also recognizes the identified shift registers as shift-register scan segments. DFT Compiler breaks these scan segments, if necessary, to respect test setup requirements such as maximum chain length. For shift registers identified with synchronous logic between the registers, DFT Compiler adds additional logic to the scan-enable signal during scan insertion to allow the data to be shifted between the registers. This extra logic results in shared paths between the scan-enable signal and the functional logic, so it is important not to set a **dont\_touch\_network** attribute on the scan-enable ports or signals. A **dont\_touch\_network** attribute on the scan-enable signal would propagate into functional logic paths, preventing the optimization of those paths and possibly leading to QoR degradation.

To disable timing optimization, use the **set\_case\_analysis** command on scan-enable ports. To disable DRC fixing, use the **set\_ideal\_network** command on the scan-enable ports. If the **dont\_touch\_network** attribute must be used, use the **set\_dont\_touch\_network -no\_propagate** command instead to avoid propagation of **dont\_touch** into functional logic.

Set this variable to **false** if you do not want DC Ultra to identify shift registers containing synchronous logic between the registers or if your design flow does not permit the insertion of additional logic on the scan-enable signal.

If you are using an ASCII flow before running DFT Compiler and shift registers with synchronous logic between the registers have been identified in the design, you must set the **compile\_seqmap\_identify\_shift\_registers\_with\_synchronous\_logic\_ascii** variable to **true** and use the **set\_scan\_state test\_ready** command to infer the shift registers again after reading in the ASCII netlist.

---

## SEE ALSO

`set_case_analysis(2)`  
`set_dont_touch_network(2)`  
`set_ideal_network(2)`  
`compile_seqmap_identify_shift_registers(3)`  
`compile_seqmap_identify_shift_registers_with_synchronous_logic_ascii(3)`

---

## compile\_seqmap\_identify\_shift\_registers\_with\_synchronous\_logic\_ascii

Controls the identification of synchronous-logic shift registers by the **set\_scan\_state test\_ready** command in an ASCII netlist flow.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When this variable is set to **true**, the **set\_scan\_state test\_ready** command supports re-identification of synchronous-logic shift registers for ASCII netlists. This flow requires a DC-Ultra license and a DFT-Compiler license. In addition, the following related variables must also be set:

```
set_app_var compile_seqmap_identify_shift_registers true  
set_app_var compile_seqmap_identify_shift_registers_with_synchronous_logic true
```

In a binary (regular) flow, shift register identification is performed by the **compile\_ultra -scan** command. The identified shift registers are annotated with attributes that are used by the DFT architect for reporting and scan stitching.

In an ASCII flow, these shift register attributes are not available in the test-ready netlist. As a result, the **set\_scan\_state test\_ready** command will re-identify shift registers when shift register identification is enabled.

When synchronous-logic shift register re-identification is enabled by this variable, the **set\_scan\_state test\_ready** command calls the DC Ultra shift register identification code (which identifies both simple and synchronous-logic shift registers). If this code identifies shift registers differently than the original test-ready synthesis run, the tool restructures the registers, scanning or unscanning registers as needed:

```
prompt> set_scan_state test_ready  
Information: Performing full identification of complex shift registers. (TEST-1190)
```

This restructuring can improve the quality of results, especially when importing netlists from flows without shift register identification. Although restructuring occurs only when this variable is set, the re-identification processes both simple and synchronous-logic shift registers.

Once the design is in a **test\_ready** state, running the **set\_scan\_state test\_ready** command again does not have any effect.

If the DC-Ultra and DFT-Compiler licenses are not available, only simple shift registers are identified by the **set\_scan\_state test\_ready** command.

## SEE ALSO

`compile_seqmap_identify_shift_registers(3)`  
`compile_seqmap_identify_shift_registers_with_synchronous_logic(3)`

---

## compile\_seqmap\_propagate\_constant\_clocks

Controls whether the **compile** command will propagate constant clock while identifying and removing constant registers.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When the value is **false** (default value), **compile** will treat constant clock as normal clock and registers would not be removed due to constant clock.

When this variable is set to **true**, **compile** will propagate constant clock so that register with constant clock may be removed as constant register.

To determine the current value of this variable, use the **printvar compile\_seqmap\_propagate\_constant\_clocks** command. For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

`compile_seqmap_propagate_constants(3)`  
`compile_seqmap_propagate_high_effort(3)`

---

## compile\_seqmap\_propagate\_constants

Controls whether the **compile** command tries to identify and remove constant registers and propagate the constant value throughout the design.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When the value is **true** (the default), **compile** tries to identify and remove constant sequential elements in the design, which improves the area of the design.

When a constant register is removed, an OPT-1206 message is printed. A register is constant if it is forced into a state (0 or 1) from which it can never escape. A register is also constant if it cannot escape its reset state. The latter behavior is further controlled by the **compile\_seqmap\_propagate\_high\_effort** variable.

The reset state of a register is determined by the presence of set and/or reset inputs on that register. For example, if a register has a non-constant reset input and no set input it is assumed that the reset state of the register is logic 0.

To determine the current value of this variable, use the **printvar compile\_seqmap\_propagate\_constants** command. For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

[compile\\_seqmap\\_propagate\\_high\\_effort\(3\)](#)

---

## compile\_seqmap\_propagate\_constants\_size\_only

Controls whether the **compile\_ultra** command will propagate constant values through registers that are marked size\_only when trying to identify and remove constant registers.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When the value is **false** (default value), **compile\_ultra** will assume that all size\_only registers are nonconstant.

When this variable is set to **true**, **compile\_ultra** will propagate constant values through size\_only registers. It will not remove the size\_only registers, however. Even if it finds them to be constant.

To determine the current value of this variable, use the **printvar compile\_seqmap\_propagate\_constants\_size\_only** command. For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

`compile_seqmap_propagate_constants(3)`  
`compile_seqmap_propagate_high_effort(3)`  
`set_size_only(2)`

---

## compile\_seqmap\_propagate\_high\_effort

Controls whether the **compile** command considers registers that cannot escape their reset state to be constant.

---

### TYPE

Boolean

---

### DEFAULT

true in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

When **compile\_seqmap\_propagate\_high\_effort** is true, the **compile** command tries to identify registers that cannot escape their reset state. Such registers are considered constant and are removed from the design, which improves the area of the design.

The reset state of a register is determined by the presence of set and/or reset inputs on that register. For example, if a register has a non-constant reset input and no set input, it is assumed that the reset state of the register is logic 0. Furthermore, if once this register is in the logic 0 state, it cannot enter the logic 1 state, it is considered to be trapped in the logic zero state and will be removed by **compile** as a constant register.

The **compile** command prints an OPT-1206 message whenever a constant register is removed from the design.

To determine the current value of this variable, use the **printvar compile\_seqmap\_propagate\_high\_effort** command. For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

[compile\\_seqmap\\_propagate\\_constants\(3\)](#)

---

## compile\_seqmap\_report\_non\_scan\_mapping

Controls whether to report the reason or constraint on a register if it cannot be mapped to scan cell in scan replacement.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When this variable is set to **true**, the **compile\_ultra -scan** and **insert\_dft** command analyze library and provide message when a register cannot be mapped to scan cell.

An OPT-1250 message is printed when compile command does not have -scan option or there is no valid scan libcell in the library.

An OPT-1251 message is printed when scan\_element attribute is false. The scan\_element attribute could be set on registers or design.

An OPT-1252 message is printed when the library has limited libcell type to match the register.

An OPT-1253 message is printed when the cell is unscan for shift-register.

An OPT-1254 message is printed when a mapping constraint is set on a cell, tool might not be able to map to scan cells.

An OPT-1255 message is printed when the register type is not available in the library.

To determine the current value of the **compile\_seqmap\_report\_non\_scan\_mapping** variable, use the **printvar compile\_seqmap\_report\_non\_scan\_mapping** command.

For a list of all compile variables and their current values, use **print\_variable\_group compile**.

---

### SEE ALSO

[compile\\_ultra\(2\)](#)  
[insert\\_dft\(2\)](#)

---

## compile\_shift\_register\_max\_length

Limit the bit length of shift registers identified in **compile -scan**. This variable only has an effect on DC Ultra optimization when shift register identification is enabled with the **compile\_seqmap\_identify\_shift\_registers** variable.

---

### TYPE

Integer

---

### DEFAULT

0

---

### DESCRIPTION

When the value of this variable is set to an integer equal or larger than 2, the identified shift register segments would be split into small segments.

It is not meaningful to set value 1, since shift registers are at least 2 bit long.

The feature is designed to target very long shift register segment. By splitting long segments, the congestion issue could be eased in the PnR stage.

Shift register identification would try to balance the length of segments within the limitation of the feature. For example, a 100 length segment with limitation of 80 would be splitted to two 50 segments, instead of 80 and 20.

---

### SEE ALSO

[compile\\_seqmap\\_identify\\_shift\\_registers\(3\)](#)

---

## compile\_state\_reachability\_high\_effort\_merge

High effort for register merging is a new capability for the **compile** command. It allows to find more equal and opposite registers.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When **compile\_state\_reachability\_high\_effort\_merge** is **true**, the **compile** command tries to identify equal and opposite registers by running a more aggressive algorithm.

The **compile** command prints an OPT-1215 message whenever a register is removed from the design because it is equal or opposite to another register.

To determine the current value of this variable, use the **printvar compile\_state\_reachability\_high\_effort\_merge** command. For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

[compile\\_seqmap\\_propagate\\_constants\(3\)](#)

---

## compile\_timing\_high\_effort

Enables high-effort timing optimizations in **compile\_ultra**.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

When you set the **compile\_timing\_high\_effort** variable to **true**, the **compile\_ultra** command runs a strategy intended to improve the delay of the design, possibly at the cost of additional runtime. Use the **compile\_ultra** command without the variable as the default strategy, and enable this variable to fine tune the flow, as needed, on designs that require further timing optimization. This strategy will perform additional runtime intense passes to achieve better timing optimization.

---

### EXAMPLES

The following example shows how to enable and disable high-effort timing optimizations for a design:

```
prompt> compile_timing_high_effort true  
prompt> compile_timing_high_effort false
```

---

### SEE ALSO

`compile_ultra(2)`  
`set_attribute(2)`  
`get_attribute(2)`  
`remove_attribute(2)`

---

## compile\_timing\_high\_effort\_tns

Enables high-effort optimization to improve total negative slack when you use the **compile\_ultra** command.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When you set the **compile\_timing\_high\_effort\_tns** variable to **true**, the **compile\_ultra** command runs a strategy intended to improve the total negative slack (TNS) in the design at the cost of additional runtime.

Use the **compile\_ultra** command without the variable as the default strategy. Enable the variable by setting the **compile\_timing\_high\_effort** variable set to **true** to fine-tune the flow, as needed, on designs that require further TNS optimization.

---

### EXAMPLES

The following example shows how to enable and then disable high-effort total negative slack optimization for a design:

```
prompt> set_app_var compile_timing_high_effort_tns true  
prompt> set_app_var compile_timing_high_effort_tns false
```

---

### SEE ALSO

[compile\\_ultra\(2\)](#)

---

## compile\_top\_all\_paths

Controls whether the **compile -top** command fixes all violations in the design, or only those that cross top-level hierarchical boundaries.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

This variable is for use only with the **-top** option of the **compile** command.

When this variable is set to **true**, the **compile -top** command fixes all design rule violations and all timing violations in the design. When **false** (the default), **compile -top** fixes all design rule violations, but only those timing violations that cross top-level hierarchical boundaries.

To determine the current value of this variable, use the **printvar compile\_top\_all\_paths** command. For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

**compile(2)**

---

## compile\_ultra\_ungroup\_dw

Determines whether to unconditionally ungroup DesignWare cells in the **compile\_ultra** flow.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

In the **compile\_ultra** flow, by default all DesignWare hierarchies are unconditionally ungrouped in the second pass of compile.

The **compile\_ultra\_ungroup\_dw** variable determines whether the DesignWare cells are auto-ungrouped in the **compile\_ultra** flow. If this variable is set to **false**, **compile\_ultra** does not unconditionally ungroup the DesignWare cells.

To determine the current value of this variable, use the **printvar compile\_ultra\_ungroup\_dw** command. For a list of all compile variables and their current values, use **print\_variable\_group compile**.

---

### SEE ALSO

[compile\\_ultra\(2\)](#)

---

## compile\_ultra\_ungroup\_small\_hierarchies

Determines whether to automatically ungroup small hierarchies in the **compile\_ultra** flow.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable, when set to **false**, turns off the automatic ungrouping of small user design hierarchies at the beginning of the **compile\_ultra** flow.

Alternatively, you can achieve the same results by running the **compile\_ultra** command with the **-no\_autoungroup** option.

Use the **printvar compile\_ultra\_ungroup\_small\_hierarchies** command to determine the current value of this variable.

---

### SEE ALSO

[compile\\_ultra\(2\)](#)

---

## compile\_update\_annotated\_delays\_during\_inplace\_opt

Controls whether **compile -in\_place** can update annotated delay values in the neighborhood of swapped cells. It has no effect for **reoptimize\_design** and **physopt**, which always update annotated delay values.

---

### TYPE

Boolean

---

### DEFAULT

true in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

When true (the default value), **compile -in\_place** is allowed to modify the values of annotated delays on nets connected to the swapped cells and to remove annotated delays on cells connected to the swapped cells.

When false, **compile -in\_place** disallows annotated delays to be modified.

This variable is used to run **compile -in\_place** with annotated cell and net delays and allows the optimization to update the annotated delays to reflect the timing changes due to swapping cells.

For example, when a cell is swapped for a cell whose input pins have higher pin capacitances, the transition delay on the cells in the fanin increases and invalidates the delays annotated on these cells. In the same manner, swapping a cell will modify the slope component of the delay of cells in the fanout of the swapped cell, thus invalidating the delay annotated on these cells.

With this variable set to true, the annotated delays on cells in the fanin and fanout of the swapped cells are removed so that new cell delays will be calculated. It is important to back-annotate net resistances and especially net capacitances to get accurate cell delays.

With this variable set to true, the annotated delays on nets connected to the swapped cells are incrementally modified to take into account the change in load due to the new pin capacitance of the new cells.

Set this variable to false to disallow modification of annotated net delays and removal of annotated cell delays.

To determine the current value of this variable, type **printvar compile\_update\_annotated\_delays\_during\_inplace\_opt**. For a list of all **compile** variables and their current values, type **print\_variable\_group compile**. For a list of all **links\_to\_layout** variables and their current values, type **print\_variable\_group links\_to\_layout**.

---

### SEE ALSO

compile(2)

---

## complete\_mixed\_mode\_extraction

Enables extraction of both routed and unrouted nets with a single command. This is known as mixed-mode extraction.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXT non-topographical mode

true in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### GROUP

physopt

---

### DESCRIPTION

By default, the **extract\_rc** command skips unrouted or partially routed nets and extracts only completely routed nets. To estimate partially routed or unrouted nets, you must use the **extract\_rc** command with the **-estimate** option. Consequently, you must run both **extract\_rc** and **extract\_rc -estimate** to completely extract a partially routed design.

Mixed-mode extraction simplifies this process by enabling simultaneous handling of routed and unrouted nets. By default, this variable is set to **true** enabling the following capabilities:

- The **extract\_rc** command performs detailed extraction first, followed by estimation for broken or unrouted nets.
- When you run the **write\_parasitics** command after doing mixed-mode extraction, it writes out mixed-mode parasitics.

To disable the mixed-mode extraction capability, set the value of this variable to **false**.

To see the current value of this variable, use the **printvar complete\_mixed\_mode\_extraction** command.

---

### SEE ALSO

[extract\\_rc\(2\)](#)



---

## core\_area\_attributes

Contains attributes related to core area.

---

## DESCRIPTION

Contains attributes related to core area.

You can use **get\_attribute** to determine value of an attribute, and use **report\_attribute** to get a report of all attributes on specified object. Specified with **list\_attribute -class core\_area -application**, the definition of attributes can be listed.

### Core Area Attributes

area

Specifies area of a core area object.

The data type of **area** is double.

This attribute is read-only.

bbox

Specifies the bounding-box of a core area. The **bbox** is represented by a **rectangle**.

The format of a *rectangle* specification is {{llx lly} {urx ury}}, which specifies the lower-left and upper-right corners of the rectangle.

The data type of **bbox** is string.

This attribute is read-only.

boundary

Specifies point list of a core area's boundary.

The data type of **boundary** is string.

This attribute is read-only.

cell\_id

Specifies Milkyway design ID in which a core area object is located.

The data type of **cell\_id** is integer.

This attribute is read-only.

direction

Specifies the direction to orient the rows in a core area.

The valid values can be horizontal and vertical.

The data type of **direction** is string.

This attribute is read-only.

is\_double\_back

Specifies whether a core area contains pairs of rows with one row flipped in each pair.

The data type of **is\_double\_back** is boolean.

This attribute is read-only.

#### is\_flip\_first\_row

Specifies whether to flip the first row at the bottom of a horizontal core area or at the left of a vertical core area.

The data type of **is\_flip\_first\_row** is boolean.

This attribute is read-only.

#### is\_start\_first\_row

Specifies whether the pairing of rows starts at the bottom of a horizontal core area or at the left of a vertical core area.

The data type of **is\_start\_first\_row** is boolean.

This attribute is read-only.

#### name

Specifies name of a core area object.

The data type of **name** is string.

This attribute is read-only.

#### num\_rows

Specifies number of rows inside a core area.

The data type of **num\_rows** is integer.

This attribute is read-only.

#### object\_class

Specifies object class name of a core area, which is **core\_area**.

The data type of **object\_class** is string.

This attribute is read-only.

#### object\_id

Specifies object ID in Milkyway design file.

The data type of **object\_id** is integer.

This attribute is read-only.

#### row\_density

Specifies the ratio of total height (if it's a horizontal core area) or width (otherwise) of rows to the height or width of a core area.

The data type of **row\_density** is string.

This attribute is read-only.

#### tile\_height

Specifies height of tile cell used in a core area.

The data type of **tile\_height** is double.

This attribute is read-only.

**tile\_width**

Specifies width of tile cell used in a core area.

The data type of **tile\_width** is double.

This attribute is read-only.

---

**SEE ALSO**

[get\\_attribute\(2\)](#)  
[list\\_attributes\(2\)](#)  
[report\\_attribute\(2\)](#)  
[set\\_attribute\(2\)](#)

---

## cts\_clock\_source\_is\_exclude\_pin

This variable controls the cascaded create-clock behavior. If this variable is set to true, clock tree synthesis (CTS) marks the clock source of a downstream **create\_clock** command as an implicit exclude pin.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable controls the cascaded create-clock behavior. When set to true, it enables CTS to mark the sources of cascaded `create_clocks` downstream as implicit exclude pins for the purpose of upstream clocks. This behavior is consistent with the timer behavior for cascaded clocks. For example, the following command:

```
prompt> create_clock CLK1
```

has a **create\_clock CLK2** defined in its fanouts at pin PIN2. CTS marks PIN2 as an implicit exclude pin for CLK1. PIN2 is still a valid driver for CLK2. This de-couples the two clocks and prevents quality of results (QoR) degradation resulting from the synthesis order of CLK1 and CLK2. If CLK1 is synthesized first, PIN2 still has a huge design rule checking (DRC) violation because CLK2 has not yet been touched by CTS. This affects the results for CLK1 when CTS tries to balance an unsynthesized tree with other synthesized trees.

---

### SEE ALSO

`create_clock(2)`

---

## **db\_load\_ccs\_data**

This variable is obsolete. The tool automatically loads the CCS timing information.

---

## dc\_allow\_rtl\_pg

Allows Design Compiler to read RTL containing a limited set of PG (power/ground) nets and pin connections.

---

### TYPE

Boolean

---

### DESCRIPTION

When **true**, RTL read into Design Compiler can contain some PG nets and PG pin connections. These can represent wiring of macros and other special cells but cannot entail a full power netlist.

PG nets must be declared in the RTL as ordinary wires and/or ports. They must not be driven by constants or declared as supply0/supply1.

The RTL PG nets can be connected to leaf cell pins as long as these pins are declared as PG pins in the technology library. This is how a net is inferred as a PG net. In addition, such nets can also be connected to signal pins of leaf cells.

PG connections can only be made to macros, pad cells, and power management cells, such as power switches, level shifters, and isolation cells. Connections can also be made to hierarchical cells; the associated pins and ports are inferred as PG pins and ports. Design Compiler does not permit PG net connections to standard cells.

If RTL containing PG nets has been read, these nets and pin connections, and associated ports, are removed from the logic netlist. They can optionally be included in Verilog output by using the **write\_file -format verilog -pg** command. If the **-pg** option is not used, the PG nets and ports will not appear.

In the UPF flow, execution of the UPF commands 'create\_supply\_port supply\_port' and 'create\_supply\_net supply\_net' will result in the logical port/net being removed from the logical netlist. Also, execution of these commands will not throw up any error messages related to name space conflicts.

---

### SEE ALSO

[dc\\_allow\\_rtl\\_pg\\_to\\_analog\\_pins\(3\)](#)  
[dc\\_allow\\_rtl\\_pg\\_to\\_signal\\_pins\(3\)](#)

---

## dc\_allow\_rtl\_pg\_to\_analog\_pins

Allows an RTL containing PG (power/ground) connections to analog signal pins to be read in successfully.

---

### TYPE

Boolean

---

### DESCRIPTION

When this variable set to **true** (the default), an RTL containing PG connections to analog signal pins will be read in successfully. These connections will be preserved in the Verilog netlist, and also in DDC. A signal pin is identified as an analog signal pin by the presence of "is\_analog" Liberty attribute.

When this variable is set to **false**, PG connections to analog signal pins are not allowed. Such connections will result in error messages during link. The connections to analog signal pins will be dropped and the analog signal pins will be connected to constants.

## dc\_allow\_rtl\_pg\_to\_signal\_pins

Allows an RTL containing PG (power/ground) connections to signal pins to be read in successfully.

### TYPE

Boolean

### DESCRIPTION

When this variable is set to **true** (the default), an RTL containing PG connections to signal pins will be read in successfully. These connections will be preserved in the Verilog netlist, and also in DDC.

When this variable is set to **false**, PG connections to signal pins are not allowed. Such connections will result in UID-622/UID-632 error messages during link. The connections to signal pins will be dropped and the signal pins will be connected to constants.

There are 2 variables now to control RTLPG connections to analog/signal pins -

1. **dc\_allow\_rtl\_pg\_to\_analog\_pins**: Allows RTLPG connections to analog pins only.
2. **dc\_allow\_rtl\_pg\_to\_signal\_pins**: Allows RTLPG connections to all signal pins.

Here is the table listing the tool behavior in the presence of the

2 variables -

signal\_pins | analog\_pins | Behavior

|       |       |                                                                                                                                                                                                                                                     |
|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ----- | ----- | -----                                                                                                                                                                                                                                               |
| true  |       | *   Connections to all signal pins<br>will be allowed. When signal_pins = true,<br>the value of analog_pins will be a NO OP.                                                                                                                        |
| false |       | true   Connections to only analog pins<br>will be allowed. Connections to signal pins<br>will be dropped with UID-622/UID-632 error<br>messages and the signal pins will be<br>connected to constants. This will achieve<br>backward compatibility. |
| false |       | false   Connections to analog/signal pins<br>will be dropped with UID-622/UID-632 error<br>messages and the analog/signal pins will be<br>connected to constants.                                                                                   |

### SEE ALSO

[dc\\_allow\\_rtl\\_pg\(3\)](#)  
[dc\\_allow\\_rtl\\_pg\\_to\\_analog\\_pins\(3\)](#)

---

## dc\_shell\_mode

Reports the mode of the current dc\_shell session.

---

### TYPE

string

---

### DEFAULT

tcl

---

### DESCRIPTION

This variable is set to the mode of the application currently running. The value of this variable can be either **default** or **tcl**. A value of **default** means that the application is running in dcsh default mode. A value of **tcl** means that the application is running in Tcl mode. The variable is read-only.

To determine the current value of this variable, use the **printvar dc\_shell\_mode** command in Tcl mode, or use the **printvar dc\_shell\_mode** command in dcsh.

---

## dct\_enable\_track\_auto\_fill

Determines if congestion estimation in Design Compiler Topographical should use layer tracks based on the layer pitch.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

true in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

The setting of the **dct\_enable\_track\_auto\_fill** variable determines whether to fill empty space with routing tracks and how congestion estimates the number of available tracks in Design Compiler topographical.

When set to **true**, Design Compiler Topographical congestion estimation fills tracks across the core area according to the pitch of the layer. This will emulate evenly distributed tracks on the design.

When set to **false**, Design Compiler Topographical congestion estimation uses actual tracks as defined in the floorplan. In this case, congestion report and congestion map use actual track availability.

To determine the current value of this variable, use the **printvar dct\_enable\_track\_auto\_fill** command.

---

### SEE ALSO

[report\\_congestion\(2\)](#)

---

## dct\_enable\_va\_aware\_ao\_synthesis

Sets the flag to enable the voltage aware buffering on physical feedthrough nets during compile\_ultra in Design Compiler Topographical.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Setting the **dct\_enable\_va\_aware\_ao\_synthesis** variable to **true** enables voltage aware AO synthesis on certain physical feedthrough paths. It enables buffer insertion in physical feedthrough path when there is disjoint voltage area, and the physical feedthrough net is very long, but logically they belong to same hierarchy.

---

### SEE ALSO

[compile\\_ultra\(2\)](#)

---

## dct\_maskshift\_consistency\_check

Sets the flag to enable color mask shift consistency checking during extract\_physical\_constraints in Design Compiler Topographical.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Setting the **dct\_maskshift\_consistency\_check** variable to **true** enables color mask shift consistency checking between the input DEF and the reference libraries during **extract\_physical\_constraints**.

These checks work only in topographical mode.

To determine the current value of this variable, use the **printvar dct\_maskshift\_consistency\_check** command.

---

### SEE ALSO

[extract\\_physical\\_constraints\(2\)](#)

---

## dct\_placement\_ignore\_scan

Sets the flag for the placer to ignore scan connections in Design Compiler topographical.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

Setting the **dct\_placement\_ignore\_scan** variable to **true** flags the placer to ignore scan connections, particularly for a scan-stitched design. This is similar to the **create\_placement** command with the **-ignore\_scan** option in IC Compiler.

---

### SEE ALSO

[compile\\_ultra\(2\)](#)

---

## dct\_port\_dont\_snap\_onto\_tracks

Sets the flag so that ports are not snapped onto tracks after pin placement in Design Compiler in topographical mode.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

If you set the **dct\_port\_dont\_snap\_onto\_tracks** variable to **true**, the ports are not snapped onto tracks after pin placement. By default, the ports are snapped onto tracks.

---

### SEE ALSO

[compile\\_ultra\(2\)](#)

---

## dct\_preserve\_all\_preroutes

Determines whether all preroutes are preserved during compilation.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

If you set the **dct\_preserve\_all\_preroutes** variable to **true**, all preroute elements in the design are preserved as they are. By default, the preroutes of non-existent non-P/G nets are filtered out and removed from the database. Preserving all preroute elements during compilation can increase the memory usage during the **compile\_ultra** command run.

---

### SEE ALSO

[compile\\_ultra\(2\)](#)

---

## dct\_remove\_invalid\_bounds

Determines whether invalid bounds and voltages areas identified through the PDC (Physical Data Check) tag are removed during compilation.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer  
false in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

If you set the **dct\_remove\_invalid\_bounds** variable to **true**, all invalid bounds and voltages areas identified through the PDC (Physical Data Check) tag are removed from the design during `compile_ultra`. Correcting invalid bounds is important for the tool to run smoothly. This feature is exclusive to DCNXT.

---

### SEE ALSO

`compile_ultra(2)`

---

## ddc\_allow\_unknown\_packed\_commands

Causes the **read\_file** command to attempt to read .ddc files that contain packed commands that are unknown to the current version of **dc\_shell**.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When this variable is set to **true** (the default), the **read\_file** command attempts to read a .ddc file that contains embedded commands (constraints) that are unknown to the current version of **dc\_shell**. This might allow the tool to read a .ddc file that was written by a newer version of **dc\_shell** which, for some reason, is not currently available.

If this feature is enabled, any unrecognized commands are discarded, possibly resulting in the loss of important data. It is best that .ddc files be read by the same (or later) version of the tool as was used to write them out.

If the variable is set to **false**, any attempt to read a file with unknown embedded commands results in a read failure and DDC-6 error message. You might want to set this variable to **false** as a check against possible loss of constraint data.

It may not be possible to read certain DDC files written by newer versions of the tool, even with this variable set to **true**.

This variable is only evaluated during the **read\_file** command. Unknown commands read in from DDC files while this variable is **true** will continue to be skipped, even if the variable is subsequently set to **false**.

---

### SEE ALSO

**read\_file(2)**  
**DDC-6(n)**  
**DDC-12(n)**  
**DDC-13(n)**

---

## de\_enable\_physical\_flow

Allows DC Explorer to perform optimization with physical design data.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

false in DC Explorer

---

### DESCRIPTION

By default, the optimization does not include any physical design data. When this variable is set to true, DC Explorer can perform optimization using floorplan information or physical constraints.

---

## de\_enable\_upf\_exploration

Enable the UPF exploration mode in DC Explorer.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

none

---

### DESCRIPTION

This variable determines if the UPF exploration mode is turned on in DC Explorer.

---

### SEE ALSO

[insert\\_mv\\_cells\(2\)](#)

---

## de\_log\_html\_filename

Changes the file name of the HTML log file.

---

### TYPE

string

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

default.html in DC Explorer

---

### GROUP

system\_variables

---

### DESCRIPTION

Use this variable to change the file name of the compile log in HTML format that is generated in de\_shell.

---

### SEE ALSO

---

## de\_log\_redirect\_enable

Enables redirection of warnings and messages in the DC Explorer log file to the HTML file.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

true in DC Explorer

---

### GROUP

system\_variables

---

### DESCRIPTION

By default, uncritical warnings and messages from the DC Explorer log file are redirected to HTML file. When this variable is set to false, the messages and warnings stay visible only in the log file.

---

### SEE ALSO

---

## **de\_log\_show\_derived\_ideal\_nets**

Enables reporting of nets marked as ideal in DE.

---

### **TYPE**

Boolean

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

false in DC Explorer

---

### **DESCRIPTION**

By default, information message about a net marked as ideal in DE is not printed. When this variable is set to true, the messages are printed in the log file.

---

### **SEE ALSO**

---

## de\_rename\_shell\_name\_to\_dc\_shell

`de_rename_shell_name_to_dc_shell`

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

false in DC Explorer

---

### GROUP

none

---

### DESCRIPTION

To change the `synopsys_program_name` variable setting to `dc_shell` during the `de_shell` session, set this variable to true.

```
prompt> echo $synopsys_program_name  
de_shell  
prompt> set de_rename_shell_name_to_dc_shell true  
true  
prompt> echo $synopsys_program_name  
dc_shell  
prompt> set de_rename_shell_name_to_dc_shell false  
false  
prompt> echo $synopsys_program_name  
de_shell
```

To determine the current setting of this variable, use the `get_app_var de_rename_shell_name_to_dc_shell` command.

---

## **default\_input\_delay**

Specifies the global default input delay value to be used for environment propagation.

---

### **TYPE**

float

---

### **DEFAULT**

30 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### **DESCRIPTION**

Specifies the global default input delay value to be used for environment propagation. This variable is used by the **derive\_constraints** command.

To determine the current value of this variable, use the **printvar default\_input\_delay** command.

---

### **SEE ALSO**

[derive\\_constraints\(2\)](#)

---

## **default\_name\_rules**

Contains the name of a name rule to be used as a default by the **change\_names** command, if the command's **-rules** option does not specify a *name\_rules* value.

---

### **TYPE**

string

---

### **DEFAULT**

""

---

### **DESCRIPTION**

This variable contains the name of a name rule to be used as a default by the **change\_names** command, if the command's **-rules** option does not specify a *name\_rules* value.

The **change\_names** command changes the names of ports, cells, and nets to conform to the rules specified by **default\_name\_rules**. The *name\_rule* you assign to **default\_name\_rules** must already have been defined using **define\_name\_rules**. For information on the format and creation of *name\_rules*, see the **define\_name\_rules** man page.

To determine the current value of this variable, use the **printvar default\_name\_rules** command. For a list of all system variables and their current values, use **print\_variable\_group system**.

---

### **SEE ALSO**

**change\_names(2)**  
**define\_name\_rules(2)**

---

## **default\_output\_delay**

Specifies the global default output delay value to be used for environment propagation.

---

### **TYPE**

float

---

### **DEFAULT**

30 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### **DESCRIPTION**

This variable specifies the global default output delay value to be used for environment propagation. This variable is used by the **derive\_constraints** command.

To determine the current value of this variable, use the **printvar default\_output\_delay** command.

---

### **SEE ALSO**

[derive\\_constraints\(2\)](#)

---

## **default\_port\_connection\_class**

Contains the value of the connection class to be assigned to ports that do not have a connection class assigned to them.

---

### **TYPE**

string

---

### **DEFAULT**

universal

---

### **DESCRIPTION**

This variable specifies the value of the connection class to be assigned to ports that do not have a connection class assigned to them. The default value for **default\_port\_connection\_class** is **universal**.

To determine the current value of this variable, use the **printvar default\_port\_connection\_class** command. For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### **SEE ALSO**

[set\\_connection\\_class\(2\)](#)

---

## default\_schematic\_options

Specifies options to use when schematics are generated.

---

### TYPE

string

---

### DEFAULT

-size infinite in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable options to use when schematics are generated. When the value is set to **-size infinite** (the default), the schematic for a design is displayed on a single page. This is used by the Design Analyzer.

To determine the current value of this variable, use the **printvar default\_schematic\_options** command. For a list of all schematic or view variables and their current values, use either the **print\_variable\_group schematic** or the **print\_variable\_group view** command.

---

# design\_attributes

---

## DESCRIPTION

Contains attributes that can be placed on a design.

There are a number of commands used to set attributes. Most attributes, however, can be set with the **set\_attribute** command. If the attribute definition specifies a **set** command, use it to set the attribute. Otherwise, use **set\_attribute**. If an attribute is "read only," it cannot be set by the user.

To determine the value of an attribute, use the **get\_attribute** command. To remove attributes, use the **remove\_attribute** command.

For a more detailed explanation of an attribute, refer to the manual pages of the appropriate **set** command. For information on all attributes, refer to the **attributes** manual page.

### Design Attributes

#### async\_set\_reset\_q

Establishes the value (0 or 1) that should be assigned to the q output of an inferred register if set and reset are both active at the same time. To be used with **async\_set\_reset\_qn**. Use these attributes only if you have used the **one\_hot** or **one\_cold** attributes/directives in your HDL description *and* your technology library is written using pre-V3.0a syntax; *or* if your technology library does not use a consistent convention for q and qn when set and reset are both active. If a V3.0a or later syntax technology library is used, then, by default, if set and reset are both active at the same time Design Compiler will use the convention of the selected technology library (**target\_library**). Set with **set\_attribute**.

**Note:** If you are unsure whether your technology library uses V3.0a syntax, ask your ASIC vendor.

#### async\_set\_reset\_qn

Establishes the value (0 or 1) that should be assigned to the qn output of an inferred register if set and reset are both active at the same time. To be used with **async\_set\_reset\_q**. Use these attributes only if you have used the **one\_hot** or **one\_cold** attributes/directives in your HDL description *and* your technology library is written using pre-V3.0a syntax; *or* if your technology library does not use a consistent convention for q and qn when set and reset are both active. If a V3.0a or later syntax technology library is used, then, by default, if set and reset are both active at the same time Design Compiler will use the convention of the selected technology library (**target\_library**). Set with **set\_attribute**.

**Note:** If you are unsure whether your technology library uses V3.0a syntax, ask your ASIC vendor.

#### balance\_registers

Determines whether the registers in a design are retimed during **compile**. When **true** (the default value), **compile** invokes the **balance\_registers** command, which moves registers to minimize the maximum register-to-register delay. Set this attribute to **false**, or remove it, to disable this behavior.

Set with **set\_balance\_registers**.

If your design contains generic logic, you should ensure that all components are mapped to cells from the library before setting the **balance\_registers** attribute.

#### boundary\_optimization

Enables **compile** to optimize across hierarchical boundaries. Hierarchy is ignored during optimization for designs with this attribute set to **true**. Set with **set\_boundary\_optimization**.

#### default\_flip\_flop\_type

Specifies the default flip-flop type for the current design. During the mapping process, **compile** tries to convert all unmapped flip-flops to this type. If **compile** is unable to use this flip-flop, it maps these cells into the smallest flip-flop possible. Set with **set\_register\_type -flip\_flop flip\_flop\_name**.

#### default\_flip\_flop\_type\_exact

Specifies the exact default flip-flop type for the current design. During the mapping process, **compile** converts unmapped flip-flops to the exact flip-flop type specified here. Set with **set\_register\_type -exact -flip\_flop flip\_flop\_name**.

#### default\_latch\_type\_exact

Specifies the exact default latch type for the current design. During the mapping process, **compile** converts unmapped latches to the exact latch type specified here. Set with **set\_register\_type -exact -latch latch\_name**.

#### design\_type

Specifies the type of the current design. Allowed values are **fsm** (finite state machine); **pla** (programmable logic array); **equation** (Boolean logic); or **netlist** (gates). This attribute is read-only and cannot be set by the user.

#### dont\_touch

Identifies designs that are to be excluded from optimization. Values are **true** (the default) or **false**. Designs with the **dont\_touch** attribute set to **true** are not modified or replaced during **compile**. Setting **dont\_touch** on a design has an effect only when the design is instantiated within another design as a level of hierarchy; setting **dont\_touch** on the top-level design has no effect. Set with **set\_dont\_touch**.

#### flatten

When set to **true**, determines that a design is to be flattened during **compile**. By default, a design is not flattened. Set with **set\_flatten**.

#### flatten\_effort

Defines the level of CPU effort that **compile** uses to flatten a design. Allowed values are **low** (the default), **medium**, or **high**. Set with **set\_flatten**.

#### flatten\_minimize

Defines the minimization strategy used for logic equations. Allowed values are **single\_output**, **multiple\_output**, or **none**. Set with **set\_flatten**.

#### flatten\_phase

When **true**, allows logic flattening to invert the phase of outputs during **compile**. By default, logic flattening does not invert the phase of outputs. Used only if the **flatten** attribute is set. Set with **set\_flatten**.

#### hdl\_template

Specifies the original RTL design name for a parameterized design after running the **analyze** and **elaborate** commands. This attribute is not available after running the **uniquify** command on the design. After running the **uniquify** command, use the **original\_design\_name** attribute to get the original design name.

#### is\_combinational

**true** if all cells of a design and all designs in its hierarchy are combinational. A cell is combinational if it is non-sequential or non-tristate and all of its outputs compute a combinational logic function. The **report\_lib** command will report such a cell as not a black-box. This attribute is read-only and cannot be set by the user.

#### is\_dw\_subblock

**true** if the object (a cell, a reference, or a design) is a DW subblock that was automatically elaborated. This attribute is read-only and cannot be set by the user.

**NOTE:** DW subblocks that are manually elaborated will not have this attribute.

#### is\_hierarchical

**true** if the design contains leaf cells or other levels of hierarchy. This attribute is read only and cannot be set by the user.

**is\_mapped**

**true** if all the non-hierarchical cells of a design are mapped to cells in a technology library. This attribute is read-only and cannot be set by the user.

**is\_sequential**

**true** if any cells of a design or designs in its hierarchy are sequential. A cell is sequential if it is not combinational (if any of its outputs depend on previous inputs). This attribute is read-only and cannot be set by the user.

**is\_synlib\_module**

**true** if the object (a cell, a reference, or a design) refers to an unmapped module reference or if the object is (or refers to) a design that was automatically elaborated from a synlib module or a synlib operator. This attribute is read-only and cannot be set by the user.

**NOTE:** synlib modules that are manually elaborated will not have this attribute.

**is\_unmapped**

**true** if any of the cells are not linked to a design or mapped to a technology library. This attribute is read-only and cannot be set by the user.

**local\_link\_library**

A string that contains a list of design files and libraries to be added to the beginning of the **link\_library** whenever a **link** operation is performed. Set with **set\_local\_link\_library**.

**map\_only**

When set to **true**, **compile** will attempt to map the object exactly in the target library, and will exclude the object from logic-level optimization (flattening and structuring). The default is **false**. Set with **set\_map\_only**.

**max\_capacitance**

A floating point number that sets the maximum capacitance value for input, output, or bidirectional ports; or for designs. The units must be consistent with those of the technology library used during optimization. Set with **set\_max\_capacitance**.

**max\_total\_power**

A floating point number that specifies the maximum target total power for the **current\_design**. Total power is defined as the sum of dynamic and leakage power. If this attribute is specified more than once for a design, the latest value is used. Set with **set\_max\_total\_power**.

**minimize\_tree\_delay**

When **true** (the default value), **compile** restructures expression trees in the **current\_design** or in a list of specified designs, to minimize tree delay. Set this attribute to **false** for any designs that you do not wish to be restructured. Set with **set\_minimize\_tree\_delay**.

**model\_map\_effort**

Specifies the relative amount of CPU time to be used by **compile** during modeling, typically for synthetic library implementations. Values are **low**, **medium**, and **high**, or 1, 2, and 3. If **model\_map\_effort** is not set, the value of **synlib\_model\_map\_effort** is used. Set with **set\_model\_map\_effort**.

**model\_scale**

A floating point number that sets the model scale factor for the **current\_design**. Set with **set\_model\_scale**.

**optimize\_registers**

When **true** (the default value), **compile** automatically invokes the Behavioral Compiler **optimize\_registers** command to retime the design during optimization. Setting the attribute to **false** disables this behavior.

Your design cannot contain generic logic at the instant **optimize\_registers** is invoked during **compile**. Set with **set\_optimize\_registers**.

**original\_design\_name**

Specifies the original design name for a parameterized design after running the **uniquify** command.

**part**

A string value that specifies the Xilinx part type for a design. For valid part types, refer to the Xilinx *XC4000 Databook*. Set with **set\_attribute**.

**resource\_allocation**

Indicates the type of resource allocation to be used by **compile** for the **current\_design**. Allowed values are **none**, indicating no resource sharing; **area\_only**, indicating resource sharing with tree balancing without considering timing constraints; **area\_no\_tree\_balancing**, indicating resource sharing without tree balancing and without considering timing constraints; and **constraint\_driven** (the default), indicating resource sharing so that timing constraints are met or not worsened. The value of this attribute overrides the value of the variable **hlo\_resource\_allocation** for the **current\_design**. Set with **set\_resource\_allocation**.

**resource\_implementation**

Indicates the type of resource implementation to be used by **compile** for the **current\_design**. Allowed values are **area\_only**, indicating resource implementation without considering timing constraints; **constraint\_driven**, indicating resource implementation so that timing constraints are met or not worsened; and **use\_fastest**, indicating resource implementation using the fastest implementation initially and using components with smaller area later in uncritical parts of the design. The value of this attribute overrides the value of the variable **hlo\_resource\_implementation** for the **current\_design**. Set with **set\_resource\_implementation**.

**structure**

Determines if a design is to be structured during **compile**. If **true**, adds logic structure to a design by adding intermediate variables that are factored out of the design's equations. Set with **set\_structure**.

**structure\_boolean**

Enables the use of Boolean (non-algebraic) techniques during the structuring phase of optimization. This attribute is ignored if the **structure** attribute is **false**. Set with **set\_structure**.

**structure\_timing**

Enables timing constraints to be considered during the structuring phase of optimization. This attribute is ignored if the **structure** attribute is **false**. Set with **set\_structure**.

**ungroup**

Removes a level of hierarchy from the current design by exploding the contents of the specified cell in the current design. Set with **set\_ungroup**.

**wired\_logic\_disable**

When **true**, disables the creation of wired OR logic during **compile**. The default is **false**; if this attribute is not set, wired OR logic will be created if appropriate. Set with **set\_wired\_logic\_disable**.

**wire\_load\_model\_mode**

Determines which wire load model to use to compute wire capacitance, resistance, and area for nets in a hierarchical design that has different wire load models at different hierarchical levels. Allowed values are **top**, use the wire load model at the top hierarchical level; **enclosed**, use the wire load model on the smallest design that encloses a net completely; and **segmented**, break the net into segments, one within each hierarchical level. In the **segmented** mode, each net segment is estimated using the wire load model on the design that encloses that segment. The **segmented** mode is not supported for wire load models on clusters. If a value is not specified for this attribute, **compile** searches for a default in the first library in the link path. If none is found, **top** is the default. Set with **set\_wire\_load**.

---

**SEE ALSO**

```
get_attribute(2)
remove_attribute(2)
set_attribute(2)
attributes(3)
```

---

## designer

Specifies the name of the current user.

---

### TYPE

string

---

### DEFAULT

""

---

### DESCRIPTION

This variable specifies the name of the current user. This name is displayed on the schematics.

To determine the current value of this variable, use the **printvar designer** command. For a list of all system variables and their current values, use the **print\_variable\_group system** command.

---

## dft\_enable\_mis\_cells\_decomposition

If this is true, multi-input switching cells will be decomposed as part of dft insertion.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

The variable **dft\_enable\_mis\_cells\_decomposition** is used to enable or disable decomposition of MIS cells in the subsequent insert\_dft command(s).

---

### EXAMPLES

The following examples show how to enable and disable decomposition of MIS cells during insert\_dft command:

```
prompt> set dft_enable_mis_cells_decomposition true  
prompt> set dft_enable_mis_cells_decomposition false
```

---

### SEE ALSO

---

## die\_area\_attributes

Contains attributes related to die area.

---

### DESCRIPTION

Contains attributes related to die area.

You can use **get\_attribute** to determine value of an attribute, and use **report\_attribute** to get a report of all attributes on specified object. Specified with **list\_attribute -class die\_area -application**, the definition of attributes can be listed.

#### Die Area Attributes

**bbox**

Specifies the bounding-box of a die area. The **bbox** is represented by a **rectangle**.

The format of a *rectangle* specification is {{llx lly} {urx ury}}, which specifies the lower-left and upper-right corners of the rectangle.

The data type of **bbox** is string.

This attribute is read-only.

**boundary**

Specifies point list of a die area's boundary.

The data type of **boundary** is string.

This attribute is read-only.

**cell\_id**

Specifies Milkyway design ID in which a die area object is located.

The data type of **cell\_id** is integer.

This attribute is read-only.

**name**

Specifies name of a die area object.

The data type of **name** is string.

This attribute is read-only.

**object\_class**

Specifies object class name of a die area, which is **die\_area**.

The data type of **object\_class** is string.

This attribute is read-only.

**object\_id**

Specifies object ID in Milkyway design file.

The data type of **object\_id** is integer.

This attribute is read-only.

---

## SEE ALSO

`get_attribute(2)`  
`list_attributes(2)`  
`report_attribute(2)`  
`set_attribute(2)`

---

## disable\_auto\_time\_borrow

Determines whether the **report\_timing** command and other commands will use automatic time borrowing.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

timing\_variables

---

### DESCRIPTION

This variable determines whether the **report\_timing** command and other commands will use automatic time borrowing. When the value is **false** (the default), automatic time borrowing occurs. Automatic time borrowing balances the slack along back-to-back latch paths, to reduce the overall delay cost. Allocating slack throughout the latch stages can improve optimization results.

When set to **true**, no slack balancing occurs during time borrowing. This means the first paths borrow enough time to meet the constraint until the *max\_time\_borrow* is reached. Setting the variable to **true** produces time-borrow results consistent with PrimeTime.

---

### SEE ALSO

[report\\_timing\(2\)](#)

---

## disable\_case\_analysis

Disables constant propagation from both logic constants and **set\_case\_analysis** command constants when set to **true**.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

timing

---

### DESCRIPTION

When this variable is set to **true**, it disables constant propagation from both logic constants and **set\_case\_analysis** command constants. By default, the **disable\_case\_analysis** variable is **false**, so constant propagation is performed if there has been a **set\_case\_analysis** command, or if the **case\_analysis\_with\_logic\_constants** variable has been specified.

To determine the current value of this variable, use the **printvar disable\_case\_analysis** command.

---

### SEE ALSO

[remove\\_case\\_analysis\(2\)](#)  
[report\\_case\\_analysis\(2\)](#)  
[set\\_case\\_analysis\(2\)](#)  
[case\\_analysis\\_with\\_logic\\_constants\(3\)](#)

---

## disable\_library\_transition\_degradation

Controls whether the transition degradation table is used to determine the net transition time.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

timing\_variables

---

### DESCRIPTION

When this variable is set to **false** (the default), **report\_timing** and other commands that use timing in dc\_shell use the transition degradation table in the library to determine the net transition time. When **true**, the timing commands behave as though there were no transition degradation across the net.

---

### SEE ALSO

[report\\_timing\(2\)](#)

---

## disable\_mdb\_stop\_points

Disables the "stop at any level" functionality in the **write\_mdb** command.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

By default, the **write\_mdb** command traverses the entire hierarchy for the specified design and writes all cell information into the destination Milkyway database. To increase the capacity and to reduce the runtime, you can also specify some modules as "stop point" by setting the **is\_mdb\_stop\_point** to **true**. The **write\_mdb** command then handles these modules as leaf modules and does not explore their submodules.

This function can be turned off by setting **disable\_mdb\_stop\_points** to **true**. This setting causes the **write\_mdb** command to ignore all stop points.

---

### SEE ALSO

[set\\_attribute\(2\)](#)

---

## disable\_multicore\_resource\_checks

Disables the resource checks on the host machine for the multicore flow.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

By default, the tool checks resource requirements in the multicore flow, such as the number of cores available and the load on the host machine. If the host machine does not meet the resources that you specified with the **set\_host\_options** command, the tool overrides your **set\_host\_options** settings and uses the optimal resources available on the host machine.

You can override this default behavior by setting the **disable\_multicore\_resource\_checks** variable to **true**. In this case, the tool disables the resource checking on the host machine and uses your **set\_host\_options** settings. However, this can slow down the tool if the host does not have the necessary cores or is heavily loaded.

The default for the **disable\_multicore\_resource\_checks** variable is **false**.

---

### SEE ALSO

UIO-230(n)  
UIO-231(n)

---

## do\_operand\_isolation

Enables or disables operand isolation as a dynamic power optimization technique for a design.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable enables or disables operand isolation as a dynamic power optimization technique for a design. When set to **false** (the default value), this technique is disabled. Set the value to **true** to enable operand isolation.

Operand isolation can insert isolation cells for both operators and hierarchical combinational cells. There are two mechanisms for operand isolation: automatic selection and user-driven mode. This and other parameters can be specified with the **set\_operand\_isolation\_style** command.

To determine the current value of this variable, use the **printvar do\_operand\_isolation** command. For a list of power variables and their current values, use the **print\_variable\_group power** command.

---

### SEE ALSO

`compile(2)`

---

## **dont\_bind\_unused\_pins\_to\_logic\_constant**

Specify whether timing analysis should apply case analysis of '0' to undriven input pins.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

This variable controls how the timing engine (i.e., the **update\_timing** command) handles undriven leaf and hierarchical input pins.

When this variable is set to its default of **false**, the timing engine applies a case analysis value of 0 at undriven pins. This is consistent with how synthesis optimizes the logic.

When this variable is set to **true**, the timer no longer assumes any case-analysis constant value at undriven input pins.

This variable only affects timing analysis. It has no effect on optimization, which always assumes logic 0 at undriven pins.

---

### **SEE ALSO**

`set_case_analysis(2)`

---

## **dont\_touch\_nets\_with\_size\_only\_cells**

Specifies whether a net is marked as dont\_touch when it connects at least one leaf-level size-only driver and at least one leaf-level size-only load.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

When set to **true**, this variable indicates whether nets with one of the following types of connections will have an implicit dont\_touch attribute marking. These connections are considered transparently across design hierarchies.

- The net connects a leaf-level size-only driving cell and at least one leaf-level size-only load cell
- The net connects a top-level input port and a leaf-level size-only load cell
- The net connects a leaf-level size-only driving cell and a top-level output port

If a net is explicitly set as **dont\_touch false** by using the **set\_dont\_touch** command, this dont\_touch setting supersedes the dont\_touch marking derived from the variable.

Cells can be marked as size-only by using the **set\_size\_only** command.

Be cautious when setting this variable to **true**. If a net is marked as dont\_touch, it cannot be changed by commands that optimize or manipulate the design. In particular, dont\_touch feedthrough nets and the dont\_touch nets connected to two output ports will not be fixed.

The default value of this variable is **false**.

To determine the current value of this variable, use the **printvar dont\_touch\_nets\_with\_size\_only\_cells** command. For a list of compile variables and their current values, use the **print\_variable\_group compile** command.

---

### **SEE ALSO**

**set\_size\_only(2)**  
**set\_dont\_touch(2)**  
**report\_dont\_touch(2)**



---

## duplicate\_ports

Specifies whether ports are to be drawn on every sheet for which an input or output signal appears.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable controls the partitioning option that specifies if ports are to be drawn on every sheet for which an input or output signal appears. When set to **true**, no off-sheet connectors are used for input and output signals, and signal ports are duplicated where indicated on each sheet.

To determine the current value of this variable, use the **printvar duplicate\_ports** command. For a list of all schematic variables and their current values, use the **print\_variable\_group schematic** command.

---

## echo\_include\_commands

Controls whether the contents of a script file are printed as it executes.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When this variable is set to **true** (the default value), the **include** command prints the contents of files as it executes. When set to **false**, the contents of the files are not printed.

To determine the current value of this variable, use the **printvar echo\_include\_commands** command. For a list of all system variables and their current values, use the **print\_variable\_group system** command.

---

## enable\_bit\_blasted\_bus\_linking

Resolves the mismatches between bit-blasted bus bits and the buses during the link process.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

true in DC Explorer

---

### DESCRIPTION

Setting this variable to true allows the linker to recognize bit-blasted buses by pin names during the link process. If the pin names follow a specific pattern, the tool infers a bus when encountering the individual bits.

Typically, the RTL pin names and the logic library pin names should match. Signals are defined the same way in both the RTL and the library. They are defined as buses or a bus is defined by its individual wires. Occasionally, mismatches occur during design development; for example, when you transfer the design from one technology to another. To fix the mismatches, you can set the **enable\_bit\_blasted\_bus\_linking** variable to true before the design is read.

When you set the **enable\_bit\_blasted\_bus\_linking** variable to true, the linker allows you to read your design even if pin name mismatches occur. By default, this variable is set to false, but the default for DC Explorer is true. Note that when this variable is set to true, the tool matches pin names according to the setting of the **bit\_blasted\_bus\_linking\_naming\_styles** variable.

You specify the pin name patterns by using the **bit\_blasted\_bus\_linking\_naming\_styles** variable. For example:

```
prompt> set bit_blasted_bus_linking_naming_styles {%s[%d]}
```

This permits the U1 reference

```
input [1:0] in;  
my_macro U1( .S(in),...
```

to link even if my\_macro is defined as follows:

```
my_macro  
input S[1];  
input S[0];  
\...
```

To determine the current value of this variable, use the **printvar enable\_bit\_blasted\_bus\_linking** command. For a list of all system variables and their current values, use **print\_variable\_group system**.

## SEE ALSO

`bit_blasted_bus_linking_naming_styles(3)`

---

## enable\_cell\_based\_verilog\_reader

Turns on the verilog2cel Verilog reader.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable enables the verilog2cel Verilog reader, which is a CEL-based Verilog reader that saves the netlist directly into the Milkyway CEL, without creating tool data structures.

To determine the current value of this variable, use the **printvar enable\_cell\_based\_verilog\_reader** command. For a list of all HDL variables and their current values, use the **print\_variable\_group hdl** command.

---

### SEE ALSO

[read\\_verilog\(2\)](#)  
[mw\\_current\\_design\(3\)](#)

---

## enable\_clock\_to\_data\_analysis

Enables the usage of latency and transition time of ideal clocks for timing analysis in clock-to-data signal paths.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable, when set to **true**, enables timing analysis of clock-to-data pins when the clock is ideal. The ideal clock latency is used as the data arrival time at the clock-to-data pin, and the ideal transition is used as data transition time at that pin. If more than one clock drives the data pin, the worst latency and transition values apply.

When the variable is set to **false** (the default), the tool uses the actual propagated clock latency and transition time at the clock-to-data pin, if any, and ignores any ideal clock latency and transition time set for the clock.

A clock-to-data pin is a cell's data input pin in the fanout of a clock, such as the input of a clock divider circuit. A pin attribute called `pin_is_clock_to_data` is set to true for these pins.

You can set the ideal latency and ideal transition time of a clock by using the `set_clock_latency` and `set_clock_transition` commands.

---

### SEE ALSO

`create_clock(2)`  
`create_generated_clock(2)`  
`set_clock_latency(2)`  
`set_clock_transition(2)`

---

## **enable\_enhanced\_physical\_multibit\_banking**

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

When set to true before the **identify\_register\_banks** command, will switch to a new optimization engine that produces equal or better bits-per-cell with better timing QoR. The new engine will also implement the netlist changes immediately during the execution of **identify\_register\_banks**, thus creating an empty output script with a comment communicating that. The behavior of the new engine can be fully controlled by the use of the **set\_multibit\_options** command.

---

### **SEE ALSO**

[compile\\_enable\\_physical\\_multibit\\_banking\(3\)](#)

---

## enable\_golden\_upf

Enables the golden UPF mode when set to true.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

true in DC Explorer

---

### GROUP

mv

---

### DESCRIPTION

This variable, when set to true, enables the golden UPF mode. By default, the variable is set to false and the golden UPF mode is disabled. In that case, the **save\_upf** command writes out a full set of UPF commands that reflect the changes made by the tool to the UPF power intent of the design, as well as the UPF commands run during the tool session.

In the golden UPF mode, the same original "golden" UPF script file is used throughout the synthesis, physical implementation, and verification flow. The **save\_upf** command writes out a supplemental UPF file that reflects only the changes made by the tool to the UPF power intent of the design. Downstream tools and verification tools use the golden and supplemental UPF files together to completely specify the power intent of the design. To use the golden UPF mode, set this variable to true before you execute any UPF commands. Once enabled, the golden UPF mode requires that you run UPF commands only by using the **load\_upf** command. You cannot execute individual UPF commands at the shell prompt, except for UPF query commands.

In the golden UPF mode, the **save\_upf** command writes out a supplemental UPF file, which contains only the UPF changes made by the tool during the session, such as tool-derived power intent and addition of power management cells. You can choose to write out a concise or verbose supplemental UPF file. A verbose file contains **connect\_supply\_net** commands that connect supply nets to the power management cells; these commands are needed if the netlist written in the session does not include PG connections. If the netlist includes PG connections, you can write out a concise supplemental UPF file instead.

To determine the current value of this variable, use **printvar enable\_golden\_upf** command. For a list of all mv variables and their current values, use the **print\_variable\_group mv** command.

## SEE ALSO

`load_upf(2)`  
`save_upf(2)`  
`upf_name_map(3)`

---

## enable\_instances\_in\_report\_net

Enables the **report\_net** command to report on instances in the current design.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

none

---

### DESCRIPTION

This variable enables the **report\_net** command to report on instances in the current design, when set to **true** (the default value).

When this variable is set to **false**, the **report\_net** command reports only nets for the current design. Also, nets in the current instance are reported if the **current\_instance** command is set.

---

### SEE ALSO

[report\\_net\(2\)](#)

---

## enable\_keep\_signal

Determines whether the tool forces preservation of a signal throughout compilation.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When you set the **enable\_keep\_signal** variable to **true**, the tool preserves marked nets throughout the compile process.

To mark a net to be preserved, the net should have the `keep_signal_name` label on it in the RTL source, and the `hdlin_keep_signal_name` variable should be set to either `user` or `user_driving`, depending on the nets to be preserved. See the `hdlin_keep_signal_name` variable man page for more information.

At the beginning of the compile process, the tool issues an OPT-154 message, indicating the presence of these marked nets. Note that preserving a net can cause QoR degradation.

#### **QoR Impact:**

- Logic connected to the preserved net is marked `size_only`.
- Automatic ungrouping of user hierarchies is disabled if the hierarchy has a preserved net connected to one of its ports.
- Constant propagation is disabled through preserved nets because the nets are marked `dont_touch`.
- Equal and opposite net optimization is disabled for preserved nets.
- The deletion of unused logic is disabled on the input cone of a preserved net.

#### **Limitations:**

- Ungrouping of synthetic cells during compile can cause the loss of a preserved net connected to its outputs (for example, two output nets of a synthetic cell that end up being driven by the same internal driver after ungrouping of the synthetic cell).
- Requests to preserve nets inside mapped synthetic cells post compile are ignored. Use a `dont_touch` explicitly on the synthetic cell hierarchy.
- Requests to preserve nets inside hierarchical clock-gating cells are ignored. Use a `dont_touch` explicitly on the clock-gating cell.

## SEE ALSO

`hdlin_keep_signal_name(3)`  
`enable_keep_signal_dt_net(3)`  
`set_dont_touch(2)`

---

## enable\_keep\_signal\_dt\_net

Determines whether the tool forces preservation of a signal throughout compilation.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When you set the **enable\_keep\_signal\_dt\_net** variable to **true**, the tool preserves marked nets during compilation.

Set the **enable\_keep\_signal\_dt\_net** variable to **true** before you use the **set\_dont\_touch** command on the net to mark it for preservation. Setting the **dont\_touch** attribute on a net sets an implicit size\_only on logic connected to that net even if logic connected to it is unmapped and not combinational.

At the beginning of compilation, the tool issues an OPT-154 warning indicating the presence of nets mark for preservation throughout compile. Preserving specific nets throughout compilation can cause quality of results (QoR) degradation. If you preserve a net that is in the critical path, the QoR degradation can be severe. This net preservation functionality is intended to facilitate verification. It should not be used to achieve final QoR goals.

#### Qor Impact:

- Logic connected to the preserved net is marked size\_only.
- Automatic ungrouping of user hierarchies is disabled if the hierarchy has a preserved net connected to one of its ports.
- Constant propagation is disabled through preserved nets because the nets are marked dont\_touch.
- Equal and opposite net optimization is disabled for preserved nets.
- The deletion of unused logic is disabled on the input cone of a preserved net.

#### Limitations:

- Ungrouping of synthetic cells during compile can cause the loss of a preserved net connected to its outputs (for example, two output nets of a synthetic cell that end up being driven by the same internal driver after ungrouping of the synthetic cell).
- Requests to preserve nets inside mapped synthetic cells post compile are ignored. Use a dont\_touch explicitly on the synthetic cell hierarchy.
- Requests to preserve nets inside hierarchical clock-gating cells are ignored. Use a dont\_touch explicitly on the clock-gating cell.

---

## SEE ALSO

`enable_keep_signal(3)`  
`set_dont_touch(2)`

---

## enable\_nldm\_timing\_noise\_signoff

Determines whether to use timing data and nonlinear delay filters to check for timing data and nonlinear delay errors in your library models.

---

### TYPE

Boolean

---

### DEFAULT

0

---

### DESCRIPTION

The **enable\_nldm\_timing\_noise\_signoff** variable determines whether to use the timing data and the nonlinear delay filters to check for timing data and nonlinear delay errors in the library model.

**enable\_nldm\_timing\_noise\_signoff** is default false, Library Compiler wouldn't enable the filters for timing data and nonlinear delay errors.

If it is set to true, the Library Compiler command, `read_lib <library_name> -signoff_screening`, would enable the filters. Screener functions would be enabled separately by setting:

`set chk_noise_exis true:`

Checks for missing noise data.

`set chk_noise_range true:`

Checks noise table with a less than recommended range for input noise width and height.

`set chk_noise_extrapol true:`

Checks extrapolation on noise data.

`set chk_noise_polar true:`

Checks for polarity on I-V curves.

`set chk_IV true:`

Checks for polarity on I-V curves.

`set chk_DC true:`

Screens negative noise tables.

`set chk_NIC true:`

Screens noise immunity curves.

`set chk_NPT true:`

Screens noise propagation tables.

`set chk_reg1 true:`

Screens low and high noise regions.

`set chk_reg2 true:`

Screens below\_low and above\_high noise regions.

`set chk_noise_mono true:`

Screens non-monotonic noise arcs.



---

## enable\_page\_mode

Controls whether long reports are displayed one page at a time (similar to the UNIX **more** command).

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable, when set to **true**, displays long reports one page at a time (similar to the UNIX **more** command). Commands affected by this variable include **list**, **help**, and the **report** commands.

To determine the current value of this variable, use the **list enable\_page\_mode** command. For a list of all system variables and their current values, use the **print\_variable\_group system** command.

---

## enable\_phys\_lib\_during\_elab

Enables linking of physical libraries when you use the **analyze** and **elaborate** commands

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

none

---

### DESCRIPTION

When this variable is set to **true**, the tool manually links physical libraries before using the **analyze** and **elaborate** commands. Then, the **analyze** and **elaborate** flow behaves the same as the **read\_verilog** flow.

---

### SEE ALSO

[analyze\(2\)](#)  
[elaborate\(2\)](#)  
[read\\_verilog\(2\)](#)

---

## enable\_presynthesis\_floorplanning

Enables floorplan exploration on a design containing unmapped logic.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

true in DC Explorer

---

### DESCRIPTION

This variable allows floorplan exploration on a design that contains unmapped logic. When it is set to true, DC Explorer creates dummy physical library cells for any cell in the design that does not have one, including unmapped cells, unmapped DesignWare components, black box cells, and so on.

---

### SEE ALSO

[start\\_icc\\_dp\(2\)](#)

---

## enable\_recovery\_removal\_arcs

Controls whether the tool accepts recovery and removal arcs specified in the technology library.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable, when set to **true**, enables the acceptance of recovery and removal arcs specified in the technology library. Recovery or removal timing arcs impose constraints on asynchronous pins of sequential cells. Typically, recovery time specifies the time the inactive edge of the asynchronous signal has to arrive before the closing edge of the clock. Removal time specifies the length of time the active phase of the asynchronous signal must be held after the closing edge of clock.

To enable the **compile**, **report\_timing**, and **report\_constraint** commands to accept recovery or removal arcs specified in the library, set **enable\_recovery\_removal\_arcs** to **true**.

Note that independent of the value of this variable, the **write\_timing** and **report\_delay\_calculation** commands always accept and report recovery or removal timing information.

This variable is the logical opposite of the variable **timing\_disable\_recovery\_removal\_checks**. If you set either one of these variables to **true**, the tool automatically sets the other variable to **false**, and vice versa.

---

### SEE ALSO

[compile\(2\)](#)  
[timing\\_disable\\_recovery\\_removal\\_checks\(3\)](#)

---

## enable\_rule\_based\_query

Enables or disables rule-based matching.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

none

---

### DESCRIPTION

When this variable is set to **true**, rule-based matching is enabled. However, you must run the **set\_query\_rules** command first. If you set this variable to **true** without running the **set\_query\_rules** command first, the default query rules are used.

When this variable is set to **true**, the runtime for the query might be slower. Disable rule-based matching when it is no longer needed.

---

### SEE ALSO

[set\\_query\\_rules\(2\)](#)

---

## enable\_slew\_degradation

Determines whether the transition degradation is considered for nets with physical information.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When this variable is set to **true** (the default value), timing calculation takes into account transition degradation across a net. For a long net, this might mean that the transition at the net driver could be very different than the various load pins. Because all load pins on the same net might not have the same transition time, optimization with physical information fixes transitions on a per pin basis. This might lead to increased runtime for these commands.

Setting this variable to **false** causes the timing calculation to not calculate transition degradation across a net. However, some libraries do have a transition degradation table that shows how to degrade the transition across a net. If slew degradation is not enabled, then the library transition degradation tables are used unless the **disable\_library\_transition\_degradation** variable is set to **true**.

If neither slew degradation nor library transition degradation is enabled, the transition at the net driver will be the same transition at the load pin. Because all load pins on the same net have the same transition time, optimization with physical information attempts to fix transitions on a per net basis.

Regardless of the setting of this variable, slew degradation does not occur for multidriven nets. For multidriven nets, there can be cases of too much pessimism.

Regardless of the setting of this variable, slew degradation can only occur if there is either delay back-annotation for the net or physical locations for the pins of the net. Otherwise, the transition time calculation at the driver pin is too inaccurate to be degraded.

To determine the current value of this variable, use the **printvar enable\_slew\_degradation** command. For a list of all timing variables and their current values, use the **print\_variable\_group timing** command.

---

### SEE ALSO

[disable\\_library\\_transition\\_degradation\(3\)](#)

---

## enable\_special\_level\_shifter\_naming

Enables special naming for automatically-inserted level shifters.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### GROUP

mv

---

### DESCRIPTION

When this variable is set to **true**, automatically-inserted level shifters by the **insert\_level\_shifters**, **compile**, and other commands are specially named. The name uses the following template:

*<prefix> + <PD OR Design name> + "\_LS" + #*

The *<prefix>* is a user-specified prefix specified by the **level\_shifter\_naming\_prefix** variable. The *#* is a number internally generated to keep this name unique. The *<PD OR Design Name>* is the name of the power domain where the level shifter is being added, or the design name if the power domain is not defined.

---

### SEE ALSO

[level\\_shifter\\_naming\\_prefix\(3\)](#)

---

## estimate\_io\_latency

Uses estimated I/O latency in timing calculations for ports when set to **true**.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

timing

---

### DESCRIPTION

This variable uses estimated I/O latency in timing calculations for ports when the value is set to **true**.

For each input port the I/O latency for max case is defined as the minimum clock network latency for the clocks in the fanout set of the port. The I/O latency for min case is the maximum clock latency in the fanout set.

For each output port the I/O latency for max case is defined as the maximum clock network latency for the clocks in the fanin set of the port. The I/O latency for min case is the minimum clock latency in the fanin set.

The I/O latency is not added to external delay in timing calculations if the **network\_delay\_included** switch is used. The ideal clocks are not used for I/O latency calculation.

This variable is best used after clock tree synthesis.

To determine the current value of this variable, use the **printvar estimate\_io\_latency** command.

---

### SEE ALSO

[report\\_timing\(2\)](#)  
[set\\_clock\\_latency\(2\)](#)  
[set\\_propagated\\_clock\(2\)](#)



---

## exit\_delete\_command\_log\_file

Controls whether the file specified by the **command\_log\_file** variable is deleted after **design\_analyzer** or dc\_shell exits normally.

---

### TYPE

string

---

### DEFAULT

false

---

### DESCRIPTION

When this variable is set to **true**, the file specified by the **command\_log\_file** variable is deleted after **design\_analyzer** or dc\_shell exits normally. The default value is **false**. Set **exit\_delete\_command\_log\_file** to **false** to retain the file.

To determine the current value of this variable, use the **printvar exit\_delete\_command\_log\_file** command. For a list of all system variables and their current values, use **print\_variable\_group system**.

---

### SEE ALSO

[command\\_log\\_file\(3\)](#)

---

## exit\_delete\_filename\_log\_file

Controls whether the file specified by the **filename\_log\_file** variable is deleted after **design\_analyzer** or dc\_shell exits normally.

---

### TYPE

string

---

### DEFAULT

true

---

### DESCRIPTION

When this variable is set to **true** (the default value), the file specified by the **filename\_log\_file** variable is deleted after **design\_analyzer** or dc\_shell exits normally. Set **exit\_delete\_filename\_log\_file** to **false** to retain the file.

To determine the current value of this variable, use the **printvar exit\_delete\_filename\_log\_file** command. For a list of all system variables and their current values, use **print\_variable\_group system**.

---

### SEE ALSO

[filename\\_log\\_file\(3\)](#)

---

## extract\_max\_parallel\_computations

Sets the maximum degree of parallelism in multi-core extraction.

---

### TYPE

Integer

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
0 in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### GROUP

physopt

---

### DESCRIPTION

This application variable specifies the degree of parallelism in multi-core extraction. Increasing parallelism results in reduced runtime.

When set to 0, the number of cores used for extraction is specified directly by the value of the set\_host\_options command with the -max\_cores option value.

When set to 1, multicore extraction is disabled.

When the value is smaller than the -max\_cores value of the set\_host\_options command, the number of cores being used will not exceed this limit.

```
prompt> set extract_max_parallel_computations 4
prompt> extract_rc

EKL_MT: max_num_of_threads = 4
EKL_MT: total threadable CPU 1.74(= 0.44 + 0.44 + 0.43 + 0.43) seconds
EKL_MT: elapsed time 0 seconds
```

---

## SEE ALSO

`set_host_options(2)`  
`extract_rc(2)`

---

## **fanin\_fanout\_trace\_arcs**

Specifies the type of combinational arcs to trace during **all\_fanin** and **all\_fanout**.

---

### **TYPE**

string

---

### **DESCRIPTION**

This variable specifies the type of combinational arcs to trace during **all\_fanin** and **all\_fanout** commands, when that command's **-trace\_arcs** option is not used.

Allowed values are **timing**, which permits tracing only of valid timing arcs (that is, arcs which are neither disabled nor invalid due to case analysis); and **all**, which permits tracing of all combinational arcs regardless of either case analysis or arc disabling.

The default in DC/ICC is timing; the default in DC Explorer is all.

If the **all\_fanin/all\_fanout** command specifies option **-trace\_arcs**, then that option takes effect regardless of the value of this variable.

---

### **SEE ALSO**

[all\\_fanin\(2\)](#)  
[all\\_fanout\(2\)](#)

---

## filename\_log\_file

Specifies the name of the filename log file to be used in case a fatal error occurs during execution of **design\_analyzer** or dc\_shell.

---

### TYPE

string

---

### DEFAULT

filenames.log

---

### DESCRIPTION

This variable specifies the name of the filename log file to be used in case a fatal error occurs during execution of **design\_analyzer** or dc\_shell. The file specified by **filename\_log\_file** contains all filenames read in by **design\_analyzer** or dc\_shell, including .db, script, Verilog, VHDL, and include files for one invocation of the program. If there is a fatal error, you can easily identify the data files needed to reproduce the fatal error. If this variable is not specified, the default filename **filenames.log** is used. This file is deleted if the program exits normally, unless **exit\_delete\_filename\_log\_file** is set to **false**.

If the application has been invoked using the **-no\_log** switch, then the process ID of the application and the timestamp is appended to the filename log file in the following format:

filenames\_<process\_id>\_<timestamp>.log.

To determine the current value of this variable, use the **printvar filename\_log\_file** command. For a list of all system variables and their current values, use **print\_variable\_group system**.

---

### SEE ALSO

[exit\\_delete\\_filename\\_log\\_file\(3\)](#)

---

## find\_allow\_only\_non\_hier\_ports

Instructs the **find** command to search for ports in subdesigns.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

none

---

### DESCRIPTION

When this variable is set to **true**, the **find** command searches for top-level ports only, ignoring ports in subdesigns.

By default, the **find port** command will also fetch ports in the subdesigns.

For example, if cell *c* is an instance of design *SUB1*, and this variable is set to **false** the command **find port c/A** fetches the port *A* on design *SUB1*. With the variable set to **true**, the command **find port c/A** results in a warning message as shown below:

```
prompt> printvar find_allow_only_non_hier_ports  
find_allow_only_non_hier_ports = "false"  
  
prompt> find port c/A  
{"c/A"}  
  
prompt> find_allow_only_non_hier_ports = true  
"true"  
  
prompt> printvar find_allow_only_non_hier_ports  
find_allow_only_non_hier_ports = "true"  
  
prompt> find port c/A  
Warning: Can't find port 'c/A' in design 'SUB1'. (UID-95)
```

This variable is used to facilitate the netlist editing commands **connect\_net** and **disconnect\_net** which allow net and pin instances in addition to handling nets and pins in the current design.

---

## SEE ALSO

`connect_net(2)`  
`disconnect_net(2)`  
`find(2)`  
`get_ports(2)`  
`remove_port(2)`

---

## find\_converts\_name\_lists

Controls whether the **find** command converts the *name\_list* string to a list of strings before searching for design objects.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

system\_variables

---

### DESCRIPTION

When this variable is set to **true**, the **find** command converts the *name\_list* string to a list of strings before searching for design objects. In addition, when this variable is **true**, all commands that use the implicit **find** will convert appropriate strings to lists of strings before searching for objects. For example, **current\_instance** uses the implicit **find** command and would convert the string *instance* to a list of strings before searching for objects.

The **find\_converts\_name\_lists** variable provides backward compatibility with the premodification **find** command. When the variable is **false** (the default value), **find** executes according to its postmodification behavior; that is, strings are not converted to lists of strings.

To determine the current value of this variable, use the **printvar find\_converts\_name\_lists** command. For a list of all system variables and their current values, use **print\_variable\_group system**.

---

### SEE ALSO

**current\_instance(2)**  
**find(2)**

---

## find\_ignore\_case

Controls whether the **find** command is case-sensitive when matching object names.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

Normally, the **find** command is case-sensitive when matching names of objects. That is, for either an explicit or implicit invocation of the **find** command, **find** only matches objects whose names have the same case as the specified string.

When this variable is set to **true**, the **find** command performs case-insensitive string comparisons. This variable affects both implicit and explicit invocations of the **find** command.

To determine the current value of this variable, use the **list find\_ignore\_case** command. If the variable has not yet been defined, the **list** command will fail, indicating that the variable is undefined.

Use this variable only when necessary, as it may slightly increase the runtime of **find** operations.

---

### SEE ALSO

[find\(2\)](#)

---

## floorplan\_data\_attributes

Contains attributes related to floorplan data on different modules in separate views.

---

### DESCRIPTION

Contains attributes related to floorplan data on different modules in separate views.

Floorplan data attributes are read-only. You can use **get\_floorplan\_data** to determine value of an attribute, and use **report\_floorplan\_data** to get a report of all the floorplan data on module objects in a specified view. If you want to know the list of valid floorplan data names, you can use **list\_floorplan\_data**.

#### Floorplan Data Attributes

area

Specifies the area of a module. This attribute does not exist on a logical module.

The tool calculates the attribute based on cell boundary.

aspect\_ratio

Specifies the **height:width** ratio of a module. This attribute does not exist on a logical module.

hard\_macro\_area\_percentage

Specifies ratio of sum of **area** of hard macros in a module to top module's **physical\_area**.

height

Specifies the height of a module. This attribute only exists on soft macros or hard macros in **logical** view.

The tool calculates the attribute based on the **bbox** of a module.

macro\_area\_percentage

Specifies the ratio of sum of **area** of macros in a module to top module's **physical\_area**.

**Note** that the definition of **macro\_area\_percentage** in this document is different from that in **cell\_attributes.3**. Compared to the definition in **cell\_attributes.3**, the numerator of ratio remains while the denominator is **physical\_area** of top module instead of **physical\_area** of the specified module.

number\_of\_black\_box

Specifies the count of black boxes in a module. This attribute does not exist on **plan\_group**.

Whether a cell is a black box can be determined by the attribute **is\_black\_box**.

number\_of\_hard\_macro

Specifies the count of hard macros in a module.

Whether a cell is a hard macro can be determined by the attribute **is\_hard\_macro**.

number\_of\_io\_cell

Specifies the count of io cells in a module. This attribute does not exist on **plan\_group**.

The tool counts cells in when its **mask\_layout\_type** is **io\_pad**, **corner\_pad**, **pad\_filler**, or **flip\_chip\_pad**.

#### number\_of\_macro

Specifies the count of macros in a module. This attribute does not exist on **plan\_group**.

The tool counts cells in when its **mask\_layout\_type** is **macro**.

#### number\_of\_standard\_cell

Specifies the count of standard cells in a module.

The tool counts cells in when its **mask\_layout\_type** matches \***std**\*.

#### physical\_area

Specifies the physical area of a module.

The physical area of a hard macro is equal to its **area**.

In **one\_level** or **logical** view, the physical area of a soft macro is equal to its **area**. However, in **physical** view, physical area is the sum of **physical\_area** of macros and **area** of standard cells inside the specified soft macro.

The physical area of a plan group is sum of **area** of macros and standard cells in it.

For a top module or a logical module, rules for calculating **physical\_area** are applied as:

In a **one\_level** view, only children in the current level are counted and children should be either macro or standard cell. The physical area of a module in **one\_level** is sum of the **area** of the counted children.

In a **logical** view, the hierarchy tree in the module is traversed and the **area** of macros and standard cells in the tree will be added.

In the **physical** view, the hierarchy tree in the module is traversed and the **area** of standard cells and **physical\_area** of macros in the tree will be added.

#### physical\_area\_percentage\_in\_top\_design

Specifies the ratio of **physical\_area** of a module to top module's **physical\_area**.

#### utilization

Specifies the utilization of a module.

The tool calculates the attribute using **physical\_area:area** ratio of a module. This attribute does not exist on a logical module or a top module.

#### width

Specifies the width of a module. This attribute only exists on soft macros or hard macros in **logical** view.

The tool calculates the attribute based on the **bbox** of a module.

---

## SEE ALSO

`get_floorplan_data(2)`  
`list_floorplan_data(2)`  
`report_floorplan_data(2)`

---

## focalopt\_power\_critical\_range

Specifies the slack threshold for performing final stage leakage-power recovery with the **focal\_opt -power** command.

---

### TYPE

float

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

0 in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

This variable specifies the power critical range in design timing units. The power critical range sets the slack threshold for performing final stage leakage-power recovery. You can specify a positive number, a negative number, or zero.

If the worst slack of all the paths through a cell is greater than the specified value, the **focal\_opt -power** command performs final stage leakage-power recovery for that cell. Final stage leakage-power recovery preserves the timing QoR such that the resulting slack is greater than or equal to the specified value.

If a path has a slack value less than the specified value, none of the cells in that path are optimized.

By default, the power critical range value is zero, and leakage-power recovery is performed only those cells with positive slack (cells on nonviolating paths).

When you set this variable to a positive number, the command preserves timing QoR with positive slack and performs less leakage-power recovery. When you set this variable to a negative number, the command performs more aggressive leakage-power recovery and allows timing degradation.

This variable applies only to the **focal\_opt -power** command. This variable applies to all scenarios in the design.

---

### EXAMPLE

The following example defines the power critical range to be 10. If the timing unit for the design is picoseconds, this value means 10ps. The **focal\_opt -power** command performs leakage-power recovery on cells with a worst slack greater than 10ps and maintains a worst slack of at least 10ps.

```
prompt> set_app_var focalopt_power_critical_range 10
```

The following example defines the power critical range to be -10. If the timing unit for the design is picoseconds, this value means -

10ps. The **focal\_opt -power** command performs leakage-power recovery on cells with a worst slack greater than -10ps and can degrade the worst slack up to -10ps.

```
prompt> set_app_var focalopt_power_critical_range -10
```

---

## SEE ALSO

---

## fsm\_auto\_inferring

Determines whether or not to automatically extract the finite state machine during compile.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable determines whether the compiler performs automatic extraction of finite state machines (FSM) during **compile\_ultra**. If extraction of state machine was performed on a design previously, the compiler does not perform extraction again with the same encoding style.

---

### EXAMPLES

In the Presto flow, the compiler detects the FSM attributes from the HDL code and extracts the FSM during **compile\_ultra**, as shown in the following example:

```
prompt> set_app_var fsm_auto_inferring true
prompt> read -f verilog example.v
prompt> set_fsm_encoding_style one_hot
prompt> compile_ultra
```

---

### SEE ALSO

[set\\_fsm\\_encoding\(2\)](#)  
[set\\_fsm\\_state\\_vector\(2\)](#)  
[fsm\\_enable\\_state\\_minimization\(3\)](#)  
[fsm\\_export\\_formality\\_state\\_info\(3\)](#)

---

## fsm\_enable\_state\_minimization

Determines whether or not the state minimization is performed for all finite state machines (FSMs) in the design.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

When this variable is set to **true**, the compiler performs the state minimization after the state extraction.

---

### SEE ALSO

[fsm\\_auto\\_inferring\(3\)](#)  
[fsm\\_export\\_formality\\_state\\_info\(3\)](#)

---

## fsm\_export\_formality\_state\_info

Determines whether or not state machine encoding information is exported into the files that will be used by Formality.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

When this variable is set to **true**, the state encoding information before and after finite state machine extraction is exported into two files, <module\_name>.ref and <module\_name>.imp, which will be used for Formality verification. The default value for this variable is **false**.

---

### SEE ALSO

[fsm\\_auto\\_inferring\(3\)](#)  
[fsm\\_enable\\_state\\_minimization\(3\)](#)

---

## gen\_bussing\_exact\_implicit

Controls whether schematics generated using the **create\_schematic -implicit** command should contain implicit bus names instead of bus rippers.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

When this variable is set to **true**, it specifies that schematics generated using the **create\_schematic -implicit** command should contain no bus rippers. Instead, all bused connections are to be shown with implicit bus names.

Use this variable with the **-implicit** command-line option. By default, schematics generated using the **-implicit** option have rippers between any bus connections where the ripper connects to a pin in a column adjacent to the originating bus pin. Bused connections between cell pins more than one column away from each other are always shown disconnected with the **-implicit** option.

To determine the current value of this variable, use the **printvar gen\_bussing\_exact\_implicit** command. For a list of all schematic variables and their current values, use **print\_variable\_group schematic**.

---

### SEE ALSO

---

## gen\_cell\_pin\_name\_separator

Specifies the character used to separate cell names and pin names in the bus names generated by the **create\_schematic** command.

---

### TYPE

string

---

### DEFAULT

/ in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

If this variable is set, then its value is used to separate the cell and pin names in the bus names generated by **create\_schematic**. By default, a / (slash) is used to separate the cell and pin names, thus creating bus names such as U0/OUT[0:3].

To determine the current value of this variable, use the **printvar gen\_cell\_pin\_name\_separator** command. For a list of all schematic variables and their current values, use **print\_variable\_group schematic**.

---

### SEE ALSO

---

## gen\_create\_netlist\_busses

Controls whether **create\_schematic** creates netlist buses whenever it creates buses on the schematic.

---

### TYPE

Boolean

---

### DEFAULT

true in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

Controls whether the **create\_schematic** command creates netlist buses whenever it creates buses on the schematic. When the value is **true** (the default), the **create\_schematic** command creates netlist buses. Usually this occurs when **create\_schematic** creates buses to connect to bused pins on the schematic. But it might also occur when there are bused ports on the schematic.

To determine the current value of this variable, use the **printvar gen\_create\_netlist\_busses** command. For a list of all **schematic** variables and their current values, use **print\_variable\_group schematic**.

---

### SEE ALSO

---

## gen\_dont\_show\_single\_bit\_busses

Controls whether single-bit buses are generated in the schematic.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable is used in conjunction with the `gen_show_created_busses` variable. When `gen_show_created_busses` is set to `true` and `gen_dont_show_single_bit_busses` is also set to `true`, single-bit buses created by gen are not printed out. This suppresses messages about the creation of single-bit buses in the schematic.

To determine the current value of this variable, use the `printvar gen_dont_show_single_bit_busses` command. For a list of all schematic variables and their current values, use the `print_variable_group schematic` command.

---

### SEE ALSO

`create_bus(2)`

---

## gen\_match\_ripper\_wire\_widths

Controls whether the **create\_schematic** command generates rippers whose width always equals the width of the ripped net.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable controls whether the **create\_schematic** command generates rippers whose width always equals the width of the ripped net. When set to **true**, any rippers whose wire ends connect to scalar nets are of unit width.

By default, the **create\_schematic** command connects scalar nets to the wire ends of multibit rippers. In this case, all of the concerned bits of the ripper are assumed to be shorted together and connected to that scalar net.

To determine the current value of this variable, use the **printvar gen\_match\_ripper\_wire\_widths** command. For a list of all **schematic** variables and their current values, use **print\_variable\_group schematic**.

---

### SEE ALSO

---

## gen\_max\_compound\_name\_length

Controls the maximum length of compound names of bus bundles for the **create\_schematic -sgc** command.

---

### TYPE

integer

---

### DEFAULT

256 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable controls the maximum length of compound names of bus bundles for the **create\_schematic -sgc** command. The default length is 256, which is the maximum length supported by SGE. Any buses with names longer than this variable are decomposed into their individual members in the schematic. If any such buses connect to cells referencing library symbols, those library symbols are ignored and new gen-created symbols are used. Any buses that these gen-created symbols have whose compound names exceed this length are blown up into their individual members.

To determine the current value of this variable, use the **printvar gen\_max\_compound\_name\_length** command. For a list of all schematic variables and their current values, use the **print\_variable\_group schematic** command.

---

### SEE ALSO

---

## gen\_max\_ports\_on\_symbol\_side

Specifies the maximum allowed size of a symbol created by the **create\_schematic** command.

---

### TYPE

integer

---

### DEFAULT

0 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXNon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies the maximum allowed size of a symbol created by the **create\_schematic** command. For example, if this variable is set to 5, symbols with no more than 5 ports on any 1 side are created. If this variable is not set or is set to 0, all input ports are placed on the left side of the symbol and all inout and output ports are placed on the right side.

To determine the current value of this variable, use the **printvar gen\_max\_ports\_on\_symbol\_side** command. For a list of all **schematic** variables and their current values, use the **print\_variable\_group schematic** command.

---

## gen\_open\_name\_postfix

Specifies the postfix to be used by **create\_schematic -sgc** when creating placeholder net names for unconnected pins.

---

### TYPE

Boolean

---

### DEFAULT

"" in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

Specifies the postfix to be used by **create\_schematic -sgc** when creating placeholder net names for unconnected pins. The default is "".

The format of the net names is "%s%d%s", where the first "%s" is replaced by the value of **gen\_open\_name\_prefix**, the second "%s" is replaced by the value of **gen\_open\_name\_postfix**, and the "%d" is replaced by an integer whose value is generated automatically by **create\_schematic -sgc**.

For example, if **gen\_open\_name\_prefix** = "Open", and **gen\_open\_name\_postfix** = "\_net", then the names created by **create\_schematic** would be "Open1\_net", "Open2\_net", and so on.

The default values for **gen\_open\_name\_prefix** and for **gen\_open\_name\_postfix** are "Open" and "", respectively, so the default names created by **create\_schematic** are Open1", "Open2", and so on.

To determine the current value of this variable, type **printvar gen\_open\_name\_postfix**. For a list of all **schematic** variables and their current values, type **print\_variable\_group schematic**.

---

### SEE ALSO

[gen\\_open\\_name\\_prefix\(3\)](#)

---

## gen\_open\_name\_prefix

Specifies the prefix to be used by **create\_schematic -sgc** when creating placeholder net names for unconnected pins.

---

### TYPE

string

---

### DEFAULT

Open in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

Specifies the prefix to be used by **create\_schematic -sgc** when creating placeholder net names for unconnected pins. The default is "Open".

The format of the net names is "%s%d%s", where the first "%s" is replaced by the value of **gen\_open\_name\_prefix**, the second "%s" is replaced by the value of **gen\_open\_name\_postfix**, and the "%d" is replaced by an integer whose value is generated automatically by **create\_schematic -sgc**.

For example, if **gen\_open\_name\_prefix** = "Open", and **gen\_open\_name\_postfix** = "\_net", then the names created by **create\_schematic** would be "Open1\_net", "Open2\_net", and so on.

The default values for **gen\_open\_name\_prefix** and for **gen\_open\_name\_postfix** are "Open" and "", respectively, so the default names created by **create\_schematic** are Open1", "Open2", and so on.

To determine the current value of this variable, type **printvar gen\_open\_name\_prefix**. For a list of all **schematic** variables and their current values, type **print\_variable\_group schematic**.

---

### SEE ALSO

[gen\\_open\\_name\\_postfix\(3\)](#)

---

## gen\_show\_created\_busses

Controls whether a message is printed out every time a schematic bus is created from cell pins for which no equivalent net bus exists in the netlist.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### GROUP

schematic\_variables

---

### DESCRIPTION

When true, a message is printed out every time a schematic bus is created from cell pins for which no equivalent net bus exists in the netlist. The default is false.

To determine the current value of this variable, type **printvar gen\_show\_created\_busses**. For a list of all **schematic** variables and their current values, type **print\_variable\_group schematic**.

---

### SEE ALSO

---

## gen\_show\_created\_symbols

Controls whether **create\_schematic** prints a warning message every time it generates a new symbol for a cell because an appropriate symbol could not be found in the symbol libraries.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

Controls whether **create\_schematic** prints a warning message every time it generates a new symbol for a cell because an appropriate symbol could not be found in the symbol libraries. The default is false.

To determine the current value of this variable, use **printvar gen\_show\_created\_symbols**. For a list of all **schematic** variables and their current values, use the **print\_variable\_group schematic** command.

---

### SEE ALSO

---

## gen\_single\_osc\_per\_name

Controls whether more than one off-sheet connector with any particular name is drawn on any schematic sheet.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

When this variable is set to true, only one off-sheet connector with any particular name is drawn on any schematic sheet. In cases where there could potentially be more than one off-sheet connector with the same name on any schematic page, only one connector is drawn and the others just have their net segments show up as unconnected stubs.

To determine the current value of this variable use **printvar gen\_single\_osc\_per\_name**. For a list of all **schematic** variables and their current values, use the **print\_variable\_group schematic** command.

---

### SEE ALSO

---

## generic\_symbol\_library

Specifies the generic symbol library used for schematics.

---

### TYPE

string

---

### DEFAULT

generic.sdb in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies the .db file that contains generic symbols, templates, and layers used for schematics.

To determine the current value of this variable, use the **printvar generic\_symbol\_library** command. For a list of all schematic variables and their current values, use the **print\_variable\_group schematic** command.

---

## golden\_upf\_report\_missing\_objects

Enables reporting of missing objects during Golden UPF reapplication.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

mv

---

### DESCRIPTION

Setting this variable to true enables reporting of all missing objects when you reapply the golden UPF file to the design with the **load\_upf** command.

In the golden UPF flow, the synthesis and physical implementation tools can change or remove objects in the design due to optimization, grouping, ungrouping, or expansion of wildcard names. Therefore, when you reapply the same golden UPF to the modified design, missing objects are expected as a normal part in the flow.

For this reason, by default, the tool does not report missing objects during reapplication of the golden UPF to the design, except for missing control signals identified by the **set\_isolation\_control**, **set\_retention\_control** and **create\_power\_switch** commands. These signals are not expected to be changed or removed by synthesis or physical implementation tools.

To enable reporting of all missing objects under these conditions, set the **golden\_upf\_report\_missing\_objects** to true. In that case, during reapplication of the golden UPF with the **load\_upf** command, all missing objects are reported.

To determine the current value of this variable, use **printvar golden\_upf\_report\_missing\_objects** command. For a list of all mv variables and their current values, use the **print\_variable\_group mv** command.

---

### SEE ALSO

[load\\_upf\(2\)](#)

```
save_upf(2)
enable_golden_upf(3)
upf_name_map(3)
```

---

## gui\_analyze\_rtl\_logic\_level\_threshold

Sets the logic-level threshold value used to determine bin coloring in a logic-level histogram.

---

### TYPE

integer

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

0 in DC Explorer

---

### GROUP

None

---

### DESCRIPTION

The **gui\_analyze\_rtl\_logic\_level\_threshold** variable allows you to set a single threshold value between 1 and infinity for the timing paths in a logic-level histogram. If this variable is not set or is set to 0, the tool uses the technology library to determine individual threshold values for each path.

---

### SEE ALSO

[gui\\_analyze\\_rtl\\_paths\(3\)](#)

---

## gui\_analyze\_rtl\_paths

Controls the number of timing paths that the tool uses to determine which bins should be colored red in a logic-level histogram.

---

### TYPE

integer

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

10 in DC Explorer

---

### GROUP

None

---

### DESCRIPTION

The **gui\_analyze\_rtl\_paths** variable specifies the minimum number of timing paths that the tool uses to color bins red in a logic-level histogram. The default value is 10.

Starting with the bin that contains the paths with the most logic levels, the tool evaluates the paths in each bin from right to left. If the number of logic levels on at least one path exceeds its threshold value, the bin is colored red. The tool continues to color the bins red until it reaches the **gui\_analyze\_rtl\_paths** number of paths. After reaching this value, the tool colors the bins white until it finds a bin in which none of the paths contain more logic levels than their threshold values. The rest of the bins are colored green.

---

### SEE ALSO

[gui\\_analyze\\_rtl\\_logic\\_level\\_threshold\(3\)](#)

---

## gui\_online\_browser

Specifies the name of the browser used to invoke the online help system from the help menu of the product.

---

### TYPE

string

---

### DEFAULT

netscape

---

### GROUP

gui

---

### DESCRIPTION

This string variable holds the value of the default browser which is used to invoke online help system from Help menu of the application. The value the variable should be either **netscape**, **mozilla** or **firefox**.

If you specify a browser other than those listed above, the application defaults to the netscape browser.

Use the following command to determine the current value of the variable:

```
prompt> printvar gui_online_browser
```

---

### SEE ALSO

[gui\\_custom\\_setup\\_files\(3\)](#)

---

## hdl\_keep\_licenses

Controls whether HDL licenses that are checked out remain checked out throughout the tool's session or are released after use.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When this variable is set to **true** (the default value), HDL licenses that are checked out remain checked out throughout the tool's session. When this variable is **false**, HDL licenses are released during the execution of the **compile** command, after **compile** completes the subtasks that require the license.

To determine the current value of this variable, use the **printvar hdl\_keep\_licenses** command. For a list of all HDL variables and their current values, use **print\_variable\_group hdl**.

---

### SEE ALSO

---

## hdl\_preferred\_license

Selects an HDL license to check out, if none is currently checked out.

---

### TYPE

string

---

### DEFAULT

""

---

### DESCRIPTION

This variable selects an HDL license to check out, if none is currently checked out. Allowed values are **vhdl**, which selects the VHDL Compiler license or **verilog**, which selects the HDL Compiler license. The elaboration process requires an HDL license.

To determine the current value of this variable, use the **printvar hdl\_preferred\_license** command. For a list of all HDL variables and their current values, use **print\_variable\_group hdl**.

---

### SEE ALSO

---

## hdlin\_allow\_unpacked\_array\_concat\_on\_port

Controls whether concat with unpacked array operand(s) in instance port expression is allowed. Effective only for Presto HDL Compiler.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

hdl\_variables

---

### DESCRIPTION

Controls whether concat with unpacked array operand(s) in instance port expression is allowed, such as  $b[3:2]$  in  $.A(\{a, b[3:2], c\})$  shown in the following sample test case:

```
module top (
    input logic a,
    input logic b[3:2],
    input logic c,
    output logic d
);
    sub sub(.A(\{a, b[3:2], c\}), .B(d));
endmodule

module sub(
    input logic A[3:0],
    output logic B
);
    ...
endmodule
```

where,  $b[3:2]$  in the instance port expression  $\{a, b[3:2], c\}$  is an unpacked array.

The default setting is **false**, meaning that Presto does not allow the above case, and an error (*ELAB-929*) will be issued for the above case.

When **hdlin\_allow\_unpacked\_array\_concat\_on\_port** is turned on, Presto will allow it with a warning message (*ELAB-1991*) issued.

As a precaution, you should examine the RTL code to make sure the connection is as expected. For example, in the corresponding port declaration in module *sub*, the port *A* should also be declared as an unpacked array, instead of a packed array such as an integer or bit-vector.

---

## SEE ALSO

[ELAB-929\(n\)](#)  
[ELAB-1991\(n\)](#)

---

## hdlin\_always\_fsm\_complete

Set attribute:FSM\_COMPLETE for all of FSMs

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When this option is set true, all of FSMs will have attribute: FSM\_COMPLETE. Its default value is false.

---

### SEE ALSO

[hdlin\\_failsafe\\_fsm\(3\)](#)

---

## hdlin\_analyze\_verbose\_mode

Queries information about preprocessing of Verilog and SystemVerilog conditional compilation compiler directives and macro expansions.

---

### TYPE

integer

---

### DEFAULT

0

---

### DESCRIPTION

The **hdlin\_analyze\_verbose\_mode** variable lets you query information about preprocessing of the Verilog or SystemVerilog RTL, including macro expansions and conditional compilation compiler directives. You use this information to debug design issues, especially for designs with a large number of macros. To query the preprocessing information about conditional compilation compiler directives such as `ifdef, set this variable to 1. To query about these and additionally macro expansions, set the variable to 2. The default is 0.

The informational messages can be found in the log by looking for the message code (VER-7). For example,

```
Information: ./example.v:6: Analyzing `ifdef then clause because MYRTL is defined. (VER-7)
Information: ./example.v:7: Macro `MYMACRO expanded to 1'b0. (VER-7)
Information: ./example.v:8: Skipping `else clause. (VER-7)
```

---

### SEE ALSO

analyze(2)

---

## hdlin\_auto\_save\_templates

Controls whether HDL designs containing parameters are read in as templates.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When set to **true** this variable reads in HDL designs containing parameters as templates. HDL parameter files include Verilog modules with parameter declarations and VHDL entities with generic declarations.

When an HDL file is read in as a template, it can be manipulated with the **printvar -templates**, **remove\_template**, and **elaborate** commands. The template can also be built automatically when instantiated from another HDL design.

When the value is **false** (the default), HDL designs are read in and built instantly. This can be overridden for a design with a template pseudo comment.

For Verilog, place the following comment anywhere in the module:

```
// synopsys template
```

For VHDL, place the following comment in the entity after the **port** declaration:

```
-- synopsys template
```

To determine the current value of this variable, use the **printvar hdlin\_auto\_save\_templates** command. For a list of HDL variables and their current values, use the **print\_variable\_group hdl** command.

---

### SEE ALSO

[elaborate\(2\)](#)  
[template\\_parameter\\_style\(3\)](#)  
[template\\_separator\\_style\(3\)](#)

---

## hdlin\_autoread\_exclude\_extensions

Specifies the file extensions of files that you do not want the **analyze** command or **read\_file** command to analyze when using the **-autoread** option.

---

### TYPE

Tcl list of strings

---

### DEFAULT

""

---

### DESCRIPTION

This variable specifies the file extensions of files that you do not want the **analyze** and **read\_file** commands to analyze when you specify the **-autoread** option.

Use **hdlin\_autoread\_exclude\_extensions** to exclude files with certain extensions.

This Tcl variable supersedes the values of the **hdlin\_autoread\_verilog\_extensions**, **hdlin\_autoread\_sverilog\_extensions** and **hdlin\_autoread\_vhdl\_extensions** language extension variables.

The following examples show how the variable is used:

```
prompt> set hdlin_autoread_exclude_extensions { .inc .v_in .def }
prompt> set hdlin_autoread_exclude_extensions { .h .H .hh .c .C .cc }
prompt> set hdlin_autoread_exclude_extensions { .txt .doc }
```

To determine the current value of this variable, use the **printvar hdlin\_autoread\_exclude\_extensions** command.

---

### SEE ALSO

[analyze\(2\)](#)  
[read\\_file\(2\)](#)  
[hdlin\\_autoread\\_verilog\\_extensions\(3\)](#)  
[hdlin\\_autoread\\_sverilog\\_extensions\(3\)](#)  
[hdlin\\_autoread\\_vhdl\\_extensions\(3\)](#)

---

## hdlin\_autoread\_sverilog\_extensions

Specifies the file extensions of files analyzed as SystemVerilog source code by the **analyze** and **read\_file** commands with the **-autoread** option.

---

### TYPE

Tcl list of strings

---

### DEFAULT

".sv .sverilog"

---

### DESCRIPTION

This variable specifies the file extensions of files analyzed as SystemVerilog source code by the **analyze** and **read\_file** commands with the **-autoread** option. Set the value of this Tcl variable to a list of file extensions to specify which files will be inferred as SystemVerilog source files. When the **analyze** command or **read\_file** command collect SystemVerilog source files from the specified source code location, all files that end with one of the strings in this list are analyzed as SystemVerilog files.

If any of the **hdlin\_autoread\_sverilog\_extensions** values match any of the **hdlin\_autoread\_verilog\_extensions** or **hdlin\_autoread\_vhdl\_extensions** variable values, an AUTOREAD-205 error is issued.

To determine the current value of this variable, use the **printvar hdlin\_autoread\_verilog\_extensions** command.

---

### SEE ALSO

[analyze\(2\)](#)  
[elaborate\(2\)](#)  
[hdlin\\_autoread\\_exclude\\_extensions\(3\)](#)  
[hdlin\\_autoread\\_verilog\\_extensions\(3\)](#)  
[hdlin\\_autoread\\_vhdl\\_extensions\(3\)](#)

---

## hdlin\_autoread\_verilog\_extensions

Specifies the file extensions of files analyzed as Verilog source code by the **analyze** and **read\_file** commands with the **-autoread** option.

---

### TYPE

Tcl list of strings

---

### DEFAULT

".v"

---

### DESCRIPTION

This variable specifies the file extensions of files analyzed as Verilog source code by the **analyze** and **read\_file** commands with the **-autoread** option. Set the value of this Tcl variable to a list of file extensions to specify which files will be inferred as Verilog source files. When the **analyze** command or **read\_file** command collect Verilog source files from the specified source code location, all files that end with one of the strings in this list are analyzed as Verilog files.

If any of the **hdlin\_autoread\_verilog\_extensions** values match any of the **hdlin\_autoread\_sverilog\_extensions** or **hdlin\_autoread\_vhdl\_extensions** variable values, an AUTOREAD-205 error is issued.

To determine the current value of this variable, use the **printvar hdlin\_autoread\_verilog\_extensions** command.

---

### SEE ALSO

[analyze\(2\)](#)  
[elaborate\(2\)](#)  
[hdlin\\_autoread\\_exclude\\_extensions\(3\)](#)  
[hdlin\\_autoread\\_sverilog\\_extensions\(3\)](#)  
[hdlin\\_autoread\\_vhdl\\_extensions\(3\)](#)

---

## hdlin\_autoread\_vhdl\_extensions

Specifies the file extensions of files analyzed as VHDL source code by the **analyze** and **read\_file** commands with the **-autoread** option.

---

### TYPE

Tcl list of strings

---

### DEFAULT

".vhd .vhdl"

---

### DESCRIPTION

This variable specifies the file extensions of files analyzed as VHDL source code by the **analyze** and **read\_file** commands with the **-autoread** option. Set the value of this Tcl variable to a list of file extensions to specify which files will be inferred as VHDL source files. When the **analyze** command or **read\_file** command collect VHDL source files from the specified source code location, all files that end with one of the strings in this list are analyzed as VHDL files.

If the variable is not defined, or if it is set to an empty list, only files with the following extensions are inferred as VHDL source files: .vhd .vhdl

If any of the **hdlin\_autoread\_vhdl\_extensions** values match any of the **hdlin\_autoread\_verilog\_extensions** or **hdlin\_autoread\_sverilog\_extensions** variable values, an AUTOREAD-205 error is issued.

To determine the current value of this variable, use the **printvar hdlin\_autoread\_vhdl\_extensions** command.

---

### SEE ALSO

[analyze\(2\)](#)  
[elaborate\(2\)](#)  
[hdlin\\_autoread\\_exclude\\_extensions\(3\)](#)  
[hdlin\\_autoread\\_verilog\\_extensions\(3\)](#)  
[hdlin\\_autoread\\_sverilog\\_extensions\(3\)](#)

---

## hdlin\_check\_no\_latch

Controls whether a warning message is issued for latches inferred by incomplete combinational assignments.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable enables a warning message for latches inferred by incomplete combinational assignments.

The following SystemVerilog RTL shows two examples of incomplete combinational assignment:

```
always @(*) begin
    if (en) begin
        out1 = in1;
    end // no assignment for (!en)
end

always @(*)
case(in2)
    2'h0: out2= 10'b001;
    2'h1: out2= 10'b010;
    2'h2: out2= 10'b100;
    // no assignment for (in2 == 2'h3)
endcase
```

In both cases, the assignment is incomplete and the tool must implement latches to hold the current value when the unassigned condition occurs.

The tool always prints sequential inference messages for these latch cells:

```
Inferred memory devices in process
  in routine top line 5 in file
    '/proj/rtl/top.v'.
```

---

| Register Name | Type  | Width | Bus | MB | AR | AS | SR | SS | ST |
|---------------|-------|-------|-----|----|----|----|----|----|----|
| q1_reg        | Latch | 1     | N   | N  | N  | N  | -  | -  | -  |

---

But when the **hdlin\_check\_no\_latch** variable is set to **true**, the tool also issues an ELAB-395 warning message:

Inferred memory devices in process  
 in routine top line 5 in file  
 '/proj/rtl/top.v'.

| Register Name | Type  | Width | Bus | MB | AR | AS | SR | SS | ST |
|---------------|-------|-------|-----|----|----|----|----|----|----|
| q1_reg        | Latch | 1     | N   | N  | N  | N  | -  | -  | -  |

Warning: Latch inferred in design top read with 'hdlin\_check\_no\_latch' (ELAB-395)

If your design should not have any incomplete combinational assignments, add the following commands to your script prior to RTL read:

```
set_app_var hlin_check_no_latch true ;# the default is false
set_message_info -id ELAB-395 -stop_on ;# force an error when this message occurs
```

If incomplete combinational assignments are found, the RTL read will fail:

Inferred memory devices in process  
 in routine top line 5 in file  
 '/proj/rtl/top.v'.

| Register Name | Type  | Width | Bus | MB | AR | AS | SR | SS | ST |
|---------------|-------|-------|-----|----|----|----|----|----|----|
| q1_reg        | Latch | 1     | N   | N  | N  | N  | -  | -  | -  |

Severe Error: Latch inferred in design top read with 'hdlin\_check\_no\_latch' (ELAB-395)

Presto compilation completed successfully.

Current design is now '/proj/rtl/top.db:top'

Loaded 1 design.

Current design is 'top'.

Error: A Severe error has occurred. To ensure that the script does not continue,  
 the value of sh\_continue\_on\_error has been overridden to be false. Your script  
 is being interrupted. To see the Tcl call stack for the part of your script which  
 generated the Severe error use the error\_info command. (CMD-103)

Error: Severe error encountered

Use error\_info for more info. (CMD-013)

The default for this variable is **false**, which disables the ELAB-395 message (but does not prevent the inferred latch cells).

To determine the current value of this variable, use the **printvar hlin\_check\_no\_latch** command. For a list of HDL variables and their current values, use **print\_variable\_group hdl**.

## SEE ALSO

ELAB-395(n)

---

## hdlin\_elab\_errors\_deep

Specifies debug mode to clean RTL with elaboration, link, and internal errors.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

true in DC Explorer

---

### GROUP

hdl\_variables

---

### DESCRIPTION

This variable allows you to be in debug mode to clean RTL with elaboration errors, link errors, and internal errors, similar to DC Explorer.

HDL Compiler elaborates a design in a top-down hierarchical order. By default, this variable is **false** (unless using DC Explorer), so the elaboration failure of a certain module prohibits the elaboration of all child modules. This behavior is safe but less informative.

When this variable is set to **true** (as in DC Explorer), HDL Compiler continues to elaborate its child modules even if a module's elaboration fails. In this way, HDL Compiler can elaborate as many modules as possible in a single elaboration run. Thus, more RTL code elaboration problems can be detected in a single run, which improves efficiency.

This variable works for both the **elaborate** and **read** command.

To benefit from this variable, the designs must be free from syntax errors during the analyze process.

In Design Compiler, in **hdlin\_elab\_errors\_deep** mode, no designs are created after elaboration. So commands such as **current\_design** or **link** do not work in this debug mode.

In DC Explorer, even in **hdlin\_elab\_errors\_deep** mode (default), designs are created after elaboration. So commands such as **current\_design** or **link** works in this debug mode.

## SEE ALSO

---

## hdlin\_elaborate\_black\_box

Specify one or more modules to have the module body ignored during design elaboration.

---

### TYPE

string

---

### DEFAULT

""

---

### DESCRIPTION

The **hdlin\_elaborate\_black\_box** application variable allows the user to specify one or more modules to have the body ignored during elaboration.

The modules are specified by setting the application variable **hdlin\_elaborate\_black\_box** to a list of modules, e.g.

```
prompt> set_app_var hdlin_elaborate_black_box "mod1 mod2 ..."
```

Here mod1, mod2 are names of modules as coded in the RTL.

The warning message (ELAB-748) is generated during the **elaborate** or **read** command. An example of the message is shown below:

```
Warning: ./test.sv:521: The body of module 'mod1' is being discarded, because the module name is in hdlin_elaborate_black_box. (E
```

The valid module names are those coded in the RTL. The design names, e.g. those reported by **list\_designs**, may not work with this feature.

No messages are generated for specified names that do not match valid module names.

---

### SEE ALSO

[elaborate\(2\)](#)  
[read\(2\)](#)  
[list\\_designs\(2\)](#)  
[hdlin\\_elaborate\\_black\\_box\\_all\\_except\(3\)](#)

---

## hdlin\_elaborate\_black\_box\_all\_except

Specify one or more modules to not ignore the body of during design elaboration.

---

### TYPE

string

---

### DEFAULT

""

---

### DESCRIPTION

The **hdlin\_elaborate\_black\_box\_all\_except** application variable allows the user to specify one or more modules to not ignore the the body of during elaboration.

The modules are specified by setting the application variable **hdlin\_elaborate\_black\_box\_all\_except** to a list of modules, e.g.

```
prompt> set_app_var hdlin_elaborate_black_box_all_except "top mod1 ..."
```

Here top, mod1, mod2 are names of modules as coded in the RTL.

The warning message (ELAB-748) is generated during the **elaborate** or **read** command. An example of the message is shown below:

```
Warning: ./test.sv:521: The body of module 'mod2' is being discarded, because the module name is not in hdlin_elaborate_black_box_all_except
```

The valid module names are those coded in the RTL. The design names, e.g. those reported by **list\_designs**, may not work with this feature.

No messages are generated for specified names that do not match valid module names.

---

### SEE ALSO

[elaborate\(2\)](#)  
[read\(2\)](#)  
[list\\_designs\(2\)](#)  
[hdlin\\_elaborate\\_black\\_box\(3\)](#)

---

## hdlin\_enable\_assertions

Controls the tool's use of SystemVerilog Assertions.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

hdl\_variables

---

### DESCRIPTION

Setting **hdlin\_enable\_assertions** to **true** allows the **elaborate** and **read\_sverilog** commands to process a synthesis-friendly subset of SystemVerilog RTL Assertions. Facts added via assertions can contribute to optimization by ruling out machine states that cannot arise during normal operation of the design. This switch controls actions taken only during the elaborate phase, including elaborations that occur during linkage or compilation.

To be activated, an assertion statement must belong to a narrow category of synthesizable deferred immediate assertions. It must have a dedicated statement label that gives it a unique, lexically scoped name. It also must be analyzed in **sverilog** format (or by **read\_sverilog**).

The asserted expression should compare only one variable or signal to a compile-time constant, or else it should make a \$onehot or \$onehot0 claim about a collection of signal wires.

Consult the *HDL Compiler for SystemVerilog User Guide* for the exact definition of the subset currently supported by this release. All labeled assertions within this subset survive analysis,

To confirm that an assertion should be considered during optimization do the following:

- Set **hdlin\_enable\_assertions true** when it is being elaborated.
- Set the lexically scoped name of its statement label as an element of the **confirmed\_SVA()** array variable in the tool environment in which the assertion is elaborated. Set it to the value of **true**.

When the above conditions are met, the labeled and confirmed assertions encoded in the intermediate (or template) design files can begin to influence logic minimization done by the tool.

Note that either linking or elaborating designs with unresolved template references can cause subdesign elaborations whose confirmed assertions may also be exploited by the tool's optimizations. The following is an example that confirms 3 assertions named *assertion\_label1*, *global\_assertion1*, and *assumption\_about\_port*.

```
analyze -f sverilog my_file.sv
# The following lines can be brought in via a source command
set confirmed_SVA(module1.scope1.assertion_label1) true
set confirmed_SVA(module1.global_assertion1) true
set confirmed_SVA(module2.generated_scope[0].assumption_about_port) true

set hdlin_enable_assertions true
elaborate module2
```

---

## SEE ALSO

[elaborate\(2\)](#)  
[ELAB-333\(n\)](#)  
[ELAB-414\(n\)](#)

---

## hdlin\_enable\_configurations

Controls the configuration support by the tool.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

hdl\_variables

---

### DESCRIPTION

The **hdlin\_enable\_configurations** variable enables configuration support by the tool when set to **true**. The default value is **false**.

To specify a configuration, use the **analyze** command. To elaborate an entity with a specific configuration, use the **elaborate** command with the configuration name as the design name. For example, if file.vhdl contains the configuration named *my\_configuration*, read and elaborate the design as follows:

```
prompt> set hdlin_enable_configurations true
prompt> analyze -f vhdl file.vhdl
prompt> elaborate my_configuration
```

The **read** command ignores configurations.

Setting this variable to **true** entails more stringent link-time checks. If designs do not use configurations, it is advised not to turn on this switch.

For more information refer to the *HDL Compiler for VHDL User Guide*

---

### SEE ALSO

[analyze\(2\)](#)

elaborate(2)

---

## hdlin\_enable\_elaborate\_ref\_linking

Controls the hierarchical elaboration flow support by SystemVerilog.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

hdl\_variables

---

### DESCRIPTION

This variable, when set to **true**, enables hierarchical elaboration support by HDL Compiler SystemVerilog. It allows the **elaborate** command to include additional contextual linkage information embedded into the elaborate designs, such as typeparams, parameter, and interface specializations.

Later, during final top module elaboration, the switch allows the linker to reach and analyze this additional contextual linkage information stored in designs, helping the pre-elaborated designs to be matched with the top module instantiations, enabling the hierarchical elaboration in a bottom-up flow.

For more information, see the *HDL Compiler for SystemVerilog User Guide*

---

### SEE ALSO

[elaborate\(2\)](#)

---

## hdlin\_enable\_elaborate\_update

Reanalyzes out-of-date intermediate files if the source can be found.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable should be set to **true** before the **analyze** command is run.

---

## hdlin\_enable\_hier\_map

Enable HDL Compiler to generate **guide\_hier\_map** guidance in SVF.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This flow is available for cases where differences in logical hierarchy inference between Design Compiler and Formality causes mis-application of SVF constraints leading to a failure in verification.

For these cases, Design Compiler can issue a different style of SVF guidance with respect to the design hierarchy than the usual flow. Design Compiler produces a set of **guide\_hier\_map** guidances to capture a baseline for the logical hierarchy, before switching to the regular **guide\_instance\_map** guidances for any further changes to the logical hierarchy.

This variable must be set to **true** prior to any design read commands (**analyze**, **elaborate**, **read\_verilog**, **read\_file**, etc.) This variable setting will enable the **set\_verification\_top** command (see below for usage) and suppress **guide\_instance\_map** guidances that are normally generated in (V)HDL Compiler.

This flow also requires that the **set\_verification\_top** command be added to your design read flow. This command must be run after the final **elaborate** command of your design read step, and prior to any further steps such as **compile\_ultra**, grouping or ungrouping, etc.

This command generates the **guide\_hier\_map** guidances as the first guidances in the SVF file. Then subsequent SVF guidances will be consistent with this logical hierarchy baseline.

If **hdlin\_enable\_hier\_map** is set to **true** and no **set\_verification\_top** command is issued before SVF generation is terminated, an error message is issued.

---

### EXAMPLES

The following script shows the correct command ordering for this flow.

```
# Specify SVF output file
prompt> set_svf ./guidance/top.svf

# Enable GHM flow
```

```
prompt> set_app_var hdlin_enable_hier_map true
# Read design files
prompt> analyze -format sverilog {sub.sv top.sv}
prompt> elaborate top
prompt> current_design top

# Issue this command after reading last RTL file and before
# other commands that can modify netlist
prompt> set_verification_top
```

---

## SEE ALSO

[analyze\(2\)](#)  
[elaborate\(2\)](#)  
[read\\_verilog\(2\)](#)  
[read\\_file\(2\)](#)  
[set\\_svf\(2\)](#)  
[set\\_verification\\_top\(2\)](#)

---

## hdlin\_enable\_hier\_naming

Controls if the registers and instances in a design are named with their hierarchical path attached or not.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable controls if registers and instances are named in the hierarchical way or not. For example,

```
4 generate for (i=0; i < 2; i = i + 1 ) begin : mygenblk
5   always @(posedge clk or negedge rst) begin : myblk
6     reg myreg;
7     if( !rst ) begin
8       qout = 0;
9       myreg = 0;
10    end
11    else begin
12      qout = myreg;
13      myreg = datain;
14    end
15  end
16 end endgenerate
```

If **hdlin\_enable\_hier\_naming** is set to *true*, the registers inferred from the code on line 6 will be 'mygenblk[0].myblk.myreg\_reg' and 'mygenblk[1].myblk.myreg\_reg'.

To determine the current value of this variable, use the **printvar hdlin\_enable\_hier\_naming** command. For a list of HDL variables and their current values, use **print\_variable\_group hdl**.

---

### SEE ALSO

---

## hdlin\_enable\_ieee\_1735\_support

---

**TYPE**

Boolean

---

**DEFAULT**

true

---

**DESCRIPTION**

Setting this variable to *true* enables support in the analyze command for the decryption of Verilog and SystemVerilog encrypted envelopes in the style of IEEE Std 1735-2014.

---

**SEE ALSO**

---

## hdlin\_enable\_persistent\_macros

Controls whether a macro definition encountered during a Verilog or SystemVerilog analyze command is remembered in subsequent Verilog or SystemVerilog analyze commands.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

hdl\_variables

---

### DESCRIPTION

By default, each Verilog and SystemVerilog analyze command is independent, except for the intermediate files that are saved into the libraries defined by define\_design\_lib.

When the hdlin\_enable\_persistent\_macros application variable is enabled, the analyze command as its first action compiles the file of macro definitions specified by the hdlin\_persistent\_macros\_filename application variable (if the file exists) and then as its last action it overwrites that file with the current macro definitions (or creates the file if it doesn't exist yet).

For example, if the analyze command encounters `undef directives or macro redefinitions, those changes will be reflected in the file at the end of the analyze command.

Like the intermediate files that are saved into libraries, the macro definitions file is protected with Synopsys encryption.

It is recommended to remove any macros definition file that might be left over from a previous session by doing the following before the first analyze command.

```
file delete -force [get_app_var hdlin_persistent_macros_filename]
```

---

### SEE ALSO

hdlin\_persistent\_macros\_filename(3)

---

## hdlin\_enable\_relative\_placement

Enables RTL relative placement support.

---

### TYPE

string

---

### DEFAULT

rb

---

### DESCRIPTION

This variable determines whether and how the tool supports RTL relative placement. Valid values for **hdlin\_enable\_relative\_placement** are **mux**, **rb**, **rb;mux**, **mux;rb**, and **none**.

- When the value is **mux**, relative placement is enabled for MUX\_OPs.
- When the value is **rb**, relative placement is enabled for register banks.
- When the value is **rb;mux** or **mux;rb**, relative placement is enabled for register banks and MUX\_OPs.
- When the value is *none*, the tool disables relative placement for all of the structures.

Relative placement for MUX\_OPs is not supported if it violates the **hdlin\_mux\_rp\_limit** variable.

To determine the current value of this variable, use the **printvar hdlin\_enable\_relative\_placement** command. For a list of HDL variables and their current values, use **print\_variable\_group hdl**.

---

### SEE ALSO

[hdlin\\_mux\\_rp\\_limit\(3\)](#)

---

## hdlin\_enable\_rtldrc\_info

Controls whether RTL TestDRC creates file name and line number information for HDL constructs and instances for designs processed by subsequent shell commands.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

hdl\_variables

---

### DESCRIPTION

This variable controls whether RTL TestDRC creates file name and line number information for HDL constructs and instances for designs processed by subsequent shell commands.

In the Synopsys RTL Test Design Rule Checking (TestDRC) tool, this information must be created for the designs in order to view the links between GTECH and mapped designs and HDL code. This analysis information is created when you process designs using the **dft\_drc** shell command.

When set to **false** (the default), no file or line information is created.

---

### SEE ALSO

---

## hdlin\_enable\_upf\_compatible\_naming

Controls HDLC naming style settings to make it easier to apply the same UPF file across multiple tools at the RTL level.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable controls HDLC naming style settings to make it easier to apply the same UPF file across multiple tools at the RTL level. This will typically make it conform more closely to language standard naming conventions.

When **hdlin\_enable\_upf\_compatible\_naming** is set to *true*, it will have the following effects:

```
set hdlin_enable_hier_naming true  
set hdlin_field_naming_style "%s.%s"
```

When **hdlin\_enable\_upf\_compatible\_naming** is set to *false* (the default), it will respect the current settings of the above variables.

To determine the current value of this variable, use the **printvar hdlin\_enable\_upf\_compatible\_naming** command. For a list of HDL variables and their current values, use **print\_variable\_group hdl**.

---

### SEE ALSO

[hdlin\\_enable\\_hier\\_naming\(3\)](#)  
[hdlin\\_field\\_naming\\_style\(3\)](#)

---

## hdlin\_failsafe\_fsm

Enable Failsafe Finite State Machine support

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When this option is set true, Failsafe Finite State Machine will be enabled. Its default value is false.

---

### SEE ALSO

[hdlin\\_always\\_fsm\\_complete\(3\)](#)

---

## hdlin\_ff\_always\_async\_set\_reset

Controls whether the tool checks and reports asynchronous set and reset conditions of flip-flops.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

hdl\_variables

---

### DESCRIPTION

This variable, when set to **true** instructs the tool to check and report asynchronous set and reset conditions of flip-flops. Setting this variable to **false** disables this behavior.

Set this variable to **false** if you do not use asynchronous set or reset conditions, if you do not want asynchronous set or reset devices inferred, or if you want your design to be input faster.

The **async\_set\_reset** pragma can be used to overwrite this variable. See the *HDL Compiler for Verilog User Guide* or the *HDL Compiler for VHDL User Guide* for more details about the pragma.

To determine the current value of this variable, use the **printvar hdlin\_ff\_always\_async\_set\_reset** command. For a list of HDL variables and their current values, use **print\_variable\_group hdl**.

---

### SEE ALSO

---

## hdlin\_ff\_always\_sync\_set\_reset

Controls whether every constant 0 loaded on a flip-flop under the clock event is used for synchronous reset, and every constant 1 loaded on a flip-flop under the clock event is used for synchronous set.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable controls whether every constant 0 loaded on a flip-flop under the clock event is used for synchronous reset, and every constant 1 loaded on a flip-flop under the clock event is used for synchronous set. Setting the value to **true** for a design subsequently analyzed, results in this behavior.

For more details, see the the *HDL Compiler for Verilog User Guide*or the *HDL Compiler for VHDL User Guide*.

To determine the current value of this variable, use the **printvar hdlin\_ff\_always\_sync\_set\_reset** command. For a list of HDL variables and their current values, use **print\_variable\_group hdl**.

---

### SEE ALSO

---

## hdlin\_field\_naming\_style

Defines the parts of the net names that the tool generates corresponding to the fields in VHDL records or in SystemVerilog structs.

---

### TYPE

string

---

### DEFAULT

""

---

### DESCRIPTION

This variable defines the parts of the net names that the tool generates corresponding to the fields in VHDL records and SystemVerilog structs. By default, the **hdlin\_field\_naming\_style** is derived from the **bus\_naming\_style** and **bus\_dimension\_separator\_style**. But when these are "%s[%d]" and "]" or are "%s<%d>" and "><", then it is possible to specify an independent **hdlin\_field\_naming\_style**, such as "%s<%s>", "%s[%s]", or "%s.%s", in which the first %s stands for the name up to the field and the second %s stands for the field. The **hdlin\_field\_naming\_style** must be of the form "%sX%s" or "%sX%sY", where X and Y are (possibly identical) non-whitespace characters.

---

### SEE ALSO

[bus\\_naming\\_style\(3\)](#)

---

## hdlin\_generate\_naming\_style

Specifies the naming style for *generated* design instances in VHDL designs.

---

### TYPE

string

---

### DEFAULT

%s\_%d

---

### DESCRIPTION

This variable specifies the naming style for *generated* design instances. For example,

```
gen: for i in 0 to 1 generate
    U: CELL port map(a(i), z(i));
end generate gen;
```

If **hdlin\_generate\_naming\_style** is set to `%s_%d` (the default), the example results in instances named `U_0` and `U_1`.

To determine the current value of this variable, use the **printvar hdlin\_generate\_naming\_style** command. For a list of HDL variables and their current values, use **print\_variable\_group hdl**.

---

### SEE ALSO

---

## hdlin\_generate\_separator\_style

Specifies the separator string for instances generated in multiple-nested loops.

---

### TYPE

string

---

### DEFAULT

—

---

### DESCRIPTION

This variable specifies the separator string for instances generated in multiple-nested loops. For example:

```
L1: for I in 3 downto 0 generate
    L2: for J in I downto 0 generate
        U: MY_AND port map ( A, B, Z);
    end generate;
end generate;
```

If **hdlin\_generate\_separator\_style** is set to `__` (the default is `_`), the example results in instances named `U_3__3`, `U_3__2`, `U_3__1`, `U_3__0`, `U_2__2`, `U_2__1`, `U_2__0`, `U_1__1`, `U_1__0`, and `U_0__0`.

To determine the current value of this variable, use the **printvar hdlin\_generate\_separator\_style** command. For a list of HDL variables and their current values, use **print\_variable\_group hdl**.

The value of this variable affects only designs read in VHDL format.

---

### SEE ALSO

---

## hdlin\_ignore\_ghm\_errors

Controls whether the tool ignores errors in the **set\_verification\_top** verification guidance flow.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable controls whether the tool requires that the **set\_verification\_top** command be run after reading in RTL files.

The **set\_verification\_top** command is part of the recommended verification guidance creation flow, which is described in the **hdlin\_enable\_hier\_map** man page.

By default, the tool requires that the **set\_verification\_top** command be run after reading all RTL files but prior to any design modification commands. This ensures that correct verification guidance is created.

If needed, you can disable this requirement by setting the **hdlin\_ignore\_ghm\_errors** application variable to **false**. However, be aware that this might result in incorrect guidance.

This variable has no effect when the **hdlin\_enable\_hier\_map** variable is set to its default of **false**, which results in the legacy verification guidance creation flow.

To determine the current value of this variable, use the **printvar hdlin\_ignore\_ghm\_errors** command.

---

### SEE ALSO

**set\_verification\_top(2)**  
**hdlin\_enable\_hier\_map(3)**

---

## hdlin\_infer\_function\_local\_latches

Controls whether the HDL Compiler infers latches inside functions and tasks.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

hdl\_variables

---

### DESCRIPTION

This variable controls whether the HDL Compiler infers latches inside functions and tasks.

When the value of this variable is **true**, latches inside function and task bodies can be inferred, according to the same rules used in always blocks.

When the value is **false** (the default), no latches are inferred in functions or tasks.

---

### SEE ALSO

---

## hdlin\_infer\_local\_sync\_enable\_only

Controls which controls are fed into synch\_enable pins and which are fed into next\_state pins.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

hdl\_variables

---

### DESCRIPTION

When the value of this variable is **true** and a particular coding style has been used, HDL Compiler produces a netlist in which the control signals local to sequential blocks feed into synch\_enable pins, while external ones feed into next\_state pins.

---

### SEE ALSO

---

## hdlin\_infer\_multibit

Specifies inference of multibit components for an entire design.

---

### TYPE

string

---

### DEFAULT

default\_none

---

### DESCRIPTION

This variable specifies inference of multibit components for an entire design. The allowed values for the **hdlin\_infer\_multibit** variable are default\_all, default\_none, and never.

The never setting prevents inference of multibit components from HDL regardless of directives (Verilog) or attributes (VHDL).

The default\_all setting infers multibit components on all bused registers except where directives or attributes indicate otherwise.

The default\_none setting specifies that only attributes or directives are used to infer multibit components. This is the default for the **hdlin\_infer\_multibit** variable.

For details, see the *HDL Compiler for Verilog User Guide* or the *HDL Compiler for VHDL User Guide*.

To determine the current value of this variable, use the **printvar hdlin\_infer\_multibit** command. For a list of HDL variables and their current values, use **print\_variable\_group hdl**.

---

### SEE ALSO

---

## hdlin\_infer\_mux

Determines whether and how the tool infers a MUX\_OP.

---

### TYPE

string

---

### DEFAULT

default

---

### DESCRIPTION

This variable determines whether and how the tool infers a MUX\_OP. Allowed values for **hdlin\_infer\_mux** are **all**, **none**, and **default**.

When the value is **all**, the tool attempts to infer a MUX\_OP for a signal or variable assigned in a case or if statement and for an expression using the ?: operator.

When the value is **none**, the tool does not attempt to infer any MUX\_OPs for a Verilog or VHDL design.

When the value is **default**, the tool attempts to infer a MUX\_OP for a case or if statement and for the ?: operator, when the statement is in a process associated with the **infer\_mux** attribute or directive. A MUX\_OP cannot be inferred if it violates the **hdlin\_mux\_size\_limit** variable.

Note that the **infer\_mux\_override** directive will force the MUX\_OP inference, ignoring the **hdlin\_infer\_mux** setting.

For details, refer to the *HDL Compiler for Verilog User Guide* or the *HDL Compiler for VHDL User Guide*.

Note that **hdlin\_infer\_mux** only changes MUX\_OP inference for if and case statements and ?: operations. It does not affect array read operations. For MUX\_OP inference of array read operations see the **hdlin\_mux\_for\_array\_read\_sparseness\_limit** variable man page.

---

### SEE ALSO

`hdlin_mux_for_array_read_sparseness_limit(3)`  
`hdlin_mux_size_limit(3)`

---

## hdlin\_interface\_port\_ABI

Chooses a linkage convention for SystemVerilog ports of type interface or modport.

---

### TYPE

integer

---

### DEFAULT

2

---

### DESCRIPTION

The **hdlin\_interface\_port\_ABI** variable is effective only when HDL Compiler (Presto) parses the source code of an **interface** or **module** declaration in SystemVerilog format (**-f sverilog**) during an **analyze** or **read** command. Its setting selects the linkage conventions to be used when interface instances or ports connect across a subdesign port. Because this setting is recorded when the interface is analyzed, its author can determine interface-specific aspects the ABI conventions once for all users, independent of any other interfaces they might also use. Since the setting is also recorded by modules that form and pass along arrays of interface instances, it allows a module which creates arrays to specify the conventions for connecting them to its subdesigns.

The memory elements and signal wires synthesized specifically for each interface instance connect to physical input, output, or inout ports at every hierarchical boundary where that interface instance connects to other design elements through an interface port or modport. The "Application Binary Interface" (ABI) is a set of conventions for which connections to make, their positional order and port names, and how to treat the contents of arrayed interface ports. Both designs being connected must agree on the ABI of their actual and formal interface ports. This agreement occurs automatically when both interface clients are elaborated using identical versions of the interface, analyzed with the same choice of ABI setting. Usually it suffices to analyze the interface once into a design library (such as "WORK") shared by all its clients as they are elaborated.

The integer value of **hdlin\_interface\_port\_ABI** encodes a bit vector with one bit position for each ABI feature. Its default value is 3'b010.

#### bit[0] Canonical Bounds (ABI 3'b??0 vs 3'b??1)

Bit 0 only affects arrayed ports (of subdesign reference cells) whose elements are instances (or modports) of some interface definition. The ABI bit[0] of the current module controls, not the ABI of the interface or the down design. The effect is noticeable only when the interface array actual port expression has bounds that differ from the canonical bounds for unpacked arrays (such as [n] or [0:n-1]) and the actual port is passed by **.portname(...)**. In these cases, the array index values are explicit in the port names being matched by Design Compiler's linker.

- An interface array connected from a module whose ABI value is **0** in bit position 0 (this is the default) uses the actual array expression's bounds to invent port names of the reference cell. Note that different instantiations of the same down design might then require distinct formal port names, and these will be produced by multiple elaborations of the down design.
- An interface array connected from a module whose ABI value is **1** in bit position 0 uses canonical bounds to invent port names of the reference cell. Note that part-selects of unpacked arrays always produce canonical bounds, so this option avoids the primary source of multiple elaboration due to bounds-matching.

Note that with either setting, formal port names can differ from the internal net names to which they connect. In fully linked designs, this produces net names in the down design that are taken from their connectivity with the top design. The canonical setting exactly resembles the names produced during linkage for all other forms of bused ports.

### **bit[1] Demoted Modports (ABI 3'b?0? vs 3'b?1?)**

Bit 1 affects only those port connections where the formal interface port specifies a modport and the actual interface instance does not.

When the value in bit position 1 is **1** (the default), these connections are successfully linked per the IEEE-1800 standard definition. This is accomplished by adding dummy (unused) formal ports to a special elaboration of the design that correspond in name and position to all interface content that lies outside the given formal modport. This elaboration uses a different **-param** string than that produced for a design reference with matching modport specifications for this interface.

When the value in bit position 1 is **0**, no special elaboration is created to accommodate formal-only modport selection; no dummy formal ports are added. In general, this will prevent linkage of an actual interface instance to a formal modport selected by the down design.

Note that the default (demote) setting allows interface modport connections to be made using `*` and `.portname` forms as the actual port. The cost of this convenience is the introduction of unused design ports.

### **bit[2] API-style (ABI 2'b0?? vs 3'b1??)**

Bit positions 2 and above are reserved for future extensions of the interface port ABI. Premature use of these settings is not supported.

---

## SEE ALSO

`analyze(2)`

---

## hdlin\_interface\_port\_downto

Controls the HDLC canonicalization of GTECH ports inferred from a SystemVerilog RTL arrayed interface port declaration.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable controls the HDLC canonicalization of GTECH ports inferred from a SystemVerilog RTL arrayed interface port declaration.

When the variable is set to **false** (the default), the GTECH ports will be in little-endian style with the leftmost ports indexed with 0. When the variable is set to **true**, the GTECH ports will instead be in big-endian style with the rightmost ports indexed with 0.

It is recommended that an entire SystemVerilog design either consistently declare all arrayed interface ports with the C-style [N] syntax (that means [0:N-1]) or consistently declare all of them as [N-1:0] but also enable this variable.

---

### SEE ALSO

---

## hdlin\_intermediate\_file\_method

Specifies how HDL Compiler stores information about analyzed RTL files.

---

### TYPE

string

---

### DEFAULT

legacy

---

### DESCRIPTION

This variable controls how the **analyze** command stores the data from analyzed RTL files, which is subsequently used by the **elaborate** command.

The **hdlin\_intermediate\_file\_method** variable can be set as follows:

- **legacy** - The data is stored as multiple files (named after module, interfaces or packages names) in the directory defined by the **define\_design\_lib** command.
- **compact** - The data is stored in a single file (named "default.hdllib") in the directory defined by the **define\_design\_lib** command.
- **none** - The data is stored in memory instead of on disk.

For the values of **legacy** and **compact**, the data remains persistent and available for use by elaboration in subsequent sessions.

For the value of **none**, all RTL analysis and elaboration must be performed in a single session. However, runtime can improve significantly (versus storing files on disk) if the filesystem performance is poor.

If the **hdlin\_auto\_save\_templates** application variable is set to **true**, then this variable also affects the **read\_verilog** and **read\_sverilog** commands.

This variable applies only to Verilog and SystemVerilog RTL analysis; it is not yet implemented for VHDL RTL analysis.

---

### SEE ALSO

[analyze\(2\)](#)  
[define\\_design\\_lib\(2\)](#)  
[elaborate\(2\)](#)  
[hdlin\\_auto\\_save\\_templates\(3\)](#)

```
read_sverilog(2)
read_verilog(2)
read_file(2)
```

---

## hdlin\_keep\_signal\_name

Determines whether HDL Compiler attempts to keep a signal name.

---

### TYPE

string

---

### DEFAULT

all\_driving

---

### DESCRIPTION

The **hdlin\_keep\_signal\_name** variable is available only in HDL Compiler (Presto Verilog) and HDL Compiler (Presto VHDL). For this discussion, these tools will be referred to as Presto. The original HDL and VHDL compilers do not support **hdlin\_keep\_signal\_name**.

The value of **hdlin\_keep\_signal\_name** determines whether Presto attempts to keep a signal name. This includes preserving cells between the signal and the input or output port. The **hdlin\_keep\_signal\_name** variable provides Presto with guideline information for keeping a signal name, but it is not intended to be a 100% guarantee for keeping a signal. In some Presto optimizations, such as removing redundant code, the signal name may be optimized away, even if the signal is associated with the **keep\_signal\_name** attribute or directive. The allowed values are **all**, **none**, **user**, **user\_driving**, and **all\_driving**, as described below. The **user** and **user\_driving** values require the **keep\_signal\_name** directive.

#### none

Presto does not attempt to keep any signals. This value overrides the **keep\_signal\_name** directive.

#### all

Presto attempts to preserve a signal if the signal is not removed by optimizations. Dangling and driving nets are considered. This value does not guarantee that a signal is kept. The **all** value generally preserves fewer signals than the **user** value. For example, if there are 3 sequential nets named *N1*, *N2*, and *N3*, the **all** value may keep only *N1*. Setting **hdlin\_keep\_signal\_name** to the value of **user** and setting the **keep\_signal\_name** directive on *N1*, *N2*, and *N3* generally keeps *N1*, *N2*, *N3*.

This value may cause the **check\_design** command to issue LINT-2 and LINT-3 warnings:

Warning: In design '...', net '...' has no drivers.  
Logic 0 assumed. (LINT-3)

Warning: In design '...', net '...' driven by pin '  
(no pin)' has no loads. (LINT-2)

#### all\_driving

Presto attempts to preserve a signal if the signal is not removed by optimizations and the signal is in an output path. Only driving nets are considered. This value does not guarantee that a signal is kept. For signals that are not in an input path (do not have drivers), Presto connects the input to ground, assuming logic 0 (ground) for the driver.

**user**

This value works with the **keep\_signal\_name** directive. Presto attempts to preserve a signal if the signal is not removed by optimizations, and that signal is labeled with the **keep\_signal\_name** directive. Dangling and driving nets are considered. Although not guaranteed, Presto usually keeps the specified signal for this configuration.

**user\_driving**

This value works with the **keep\_signal\_name** directive. Presto attempts to preserve a signal if the signal is not removed by optimizations, the signal is in an output path, and the signal is labeled with the **keep\_signal\_name** directive. Only driving nets are considered. Although not guaranteed, Presto usually keeps the specified signal for this configuration. For signals that are not in an input path (do not have drivers), Presto connects the input to ground, assuming logic 0 (ground) for the driver.

## EXAMPLES

In Example 1, you use the **hdlin\_keep\_signal\_name** variable and the **keep\_signal\_name** directive to control what signals Presto attempts to preserve.

## Example 1 - Verilog

```
module test (a, b, T, A, c);
input [3:0] a;
input [7:0] b;
input T;
input A;
output reg [7:0] c;
wire d, e;
//synopsys async_set_reset "A"
//synopsys keep_signal_name "e"

assign e = ( a[3] & ~a[2] & a[1] & ~a[0] );
assign d = ( a[3] & ~a[2] & a[1] & ~a[0] );

always @(T or b or A or d)
if (A)
  c = 8'h0;
  else if (T & d)
    c = b;
endmodule
```

The internal wire `e` is not kept if the line `//synopsys keep_signal_name "e"` is removed, and **hdlin\_keep\_signal\_name** is either **none**, **user**, **user\_driving**, or **all\_driving**. However, `e` is kept if **hdlin\_keep\_signal\_name** is **all**. Also, `e` is kept if **hdlin\_keep\_signal\_name** is **user** and `//synopsys keep_signal_name` is attached to "`e`".

In Example 2, by default Presto attempts to preserve the `test1` and `test2` signals because they are in output paths. Note that the `test2` signal is not in an input path; Presto does not try to keep the `test3` signal because it is not in an output path. Presto optimizes away the `syn1` and `syn2` signals.

## Example 2 - Verilog

```
module test12 (in1, in2, in3, in4, out1,out2 );
input [3:0] in1;
input [7:0] in2;
input in3;
input in4;
output reg [7:0] out1,out2;

wire test1,test2, test3, syn1,syn2;

//synopsys async_set_reset "in4"
```

```

assign test1 = ( in1[3] & ~in1[2] & in1[1] & ~in1[0] );
//test1 signal is in an input and output path
assign test2 = syn1+syn2;
//test2 signal is in a output path, but it is not in an input path
assign test3 = in1 + in2;
//test3 signal is in an input path, but it is not in an output path
always @ (in3 or in2 or in4 or test1)
out2 = test2+out1;
always @ (in3 or in2 or in4 or test1)
if (in4)
  out1 = 8'h0;
else
if (in3 & test1)
  out1 = in2;
endmodule

```

One way to keep the test3 signal is to set **hdlin\_keep\_signal\_name** to **user** and place the **keep\_signal\_name** directive on test3, as shown in Example 3.

#### Example 3 - Verilog

```

module test12 (in1, in2, in3, in4, out1,out2 );
  input [3:0] in1;
  input [7:0] in2;
  input in3;
  input in4;
  output reg [7:0] out1,out2;

  wire test1,test2, test3, syn1,syn2;
  //synopsys keep_signal_name "test3"

  //synopsys async_set_reset "in4"

  assign test1 = ( in1[3] & ~in1[2] & in1[1] & ~in1[0] );
  //test1 signal is in an input and output path
  assign test2 = syn1+syn2;
  //test2 signal is in a output path, but it is not in an input path
  assign test3 = in1 + in2;
  //test3 signal is in an input path, but it is not in an output path
  always @ (in3 or in2 or in4 or test1)
  out2 = test2+out1;
  always @ (in3 or in2 or in4 or test1)
  if (in4)
    out1 = 8'h0;
  else
  if (in3 & test1)
    out1 = in2;
endmodule

```

Table 1 shows how the variable settings affect the preservation of signal test3, with and without the directive applied to it. Asterisks (\*) indicate that Presto does not attempt to keep the signal and might remove it.

Table 1 Variable and Directive Matrix for Signal test3

| hdlin_keep_signal_name | = all    | = none | = user   | = user_driving | = all_driving |
|------------------------|----------|--------|----------|----------------|---------------|
| keep_signal_name is    | attempts | *      | *        | *              | *             |
| not set on test3       | to keep  |        |          |                |               |
| keep_signal_name is    | attempts | *      | attempts | *              | *             |
| set on test3           | to keep  |        | to keep  |                |               |

Table 2 shows how the variable settings affect the preservation of signal test2, with and without the directive applied to it. Asterisks (\*)

indicate that Presto does not attempt to keep the signal and might remove it.

Table 2 Variable and Directive Matrix for Signal test2

|                          |          |      |          |              |             |
|--------------------------|----------|------|----------|--------------|-------------|
| hdlin_keep_signal_name = | all      | none | user     | user_driving | all_driving |
| <hr/>                    |          |      |          |              |             |
| keep_signal_name is      | attempts | *    | *        | *            | attempts    |
| not set on test2         | to keep  |      |          | to keep      |             |
| <hr/>                    |          |      |          |              |             |
| keep_signal_name is      | attempts | *    | attempts | attempts     | attempts    |
| set on test2             | to keep  |      | to keep  | to keep      | to keep     |
| <hr/>                    |          |      |          |              |             |

Table 3 shows how the variable settings affect the preservation of signal test1, with and without the directive applied to it. Asterisks (\*) indicate that Presto does not attempt to keep the signal and might remove it.

Table 3 Variable and Directive Matrix for Signal test1

|                          |          |      |          |              |             |
|--------------------------|----------|------|----------|--------------|-------------|
| hdlin_keep_signal_name = | all      | none | user     | user_driving | all_driving |
| <hr/>                    |          |      |          |              |             |
| keep_signal_name is      | attempts | *    | *        | *            | attempts    |
| not set on test1         | to keep  |      |          | to keep      |             |
| <hr/>                    |          |      |          |              |             |
| keep_signal_name is      | attempts | *    | attempts | attempts     | attempts    |
| set on test1             | to keep  |      | to keep  | to keep      | to keep     |
| <hr/>                    |          |      |          |              |             |

To determine the current value of this variable, use the following command:

```
prompt> printvar hdlin_keep_signal_name
```

Use the following command to get a list of HDL variables and their current values in DB (dcsh) mode :

```
prompt> print_variable_group hdl
```

Use the following command to get a list of HDL variables and their current values in XG and DB (Tcl) mode:

```
prompt> print_variable_group
```

## SEE ALSO

[enable\\_keep\\_signal\(3\)](#)

---

## hdlin\_latch\_always\_async\_set\_reset

Uses every constant 0 loaded on a latch for asynchronous reset and uses every constant 1 loaded on a latch for asynchronous set for a design subsequently analyzed.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable, when set to **true**, instructs the tool to use every constant 0 loaded on a latch for asynchronous reset, and to use every constant 1 loaded on a latch for asynchronous set, for a design subsequently analyzed.

The default value is **false**.

For more details, see the *HDL Compiler for Verilog User Guide* or the *HDL Compiler for VHDL User Guide*.

To determine the current value of this variable, use the **printvar hdlin\_latch\_always\_async\_set\_reset** command. For a list of HDL variables and their current values, use **print\_variable\_group hdl**.

---

### SEE ALSO

---

## hdlin\_legacy\_naming

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

In unified compile flow, names of registers, ports etc. conform to the language standard naming conventions.

When `hdlin_legacy_naming` is set to true, default value of `hdlin_enable_upf_compatible_naming` is set to false.

When `hdlin_legacy_naming` is set to false (the default), it will have the following effects:

```
set hdlin_enable_upf_compatible_naming true  
set hdlin_enable_hier_naming true  
set hdlin_field_naming_style "%s.%s"
```

To determine the current value of this variable, use the `printvar hdlin_legacy_naming` command. For a list of HDL variables and their current values, use `print_variable_group hdl`.

---

### SEE ALSO

`hdlin_enable_hier_naming(3)`  
`hdlin_field_naming_style(3)`

---

## hdlin\_module\_arch\_name\_splitting

Controls whether Presto HDL Compiler recognizes a special format of Verilog module names, which allows users to specify both a module and an implementation architecture.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

During an **analyze** or **read** command, when the **hdlin\_module\_arch\_name\_splitting** value is **true**, and a Verilog module name contains the special separator string " \_\_ " (two underscores), Presto HDL Compiler interprets the module name as specifying both a module and a specific architecture or implementation for that module. The portion of the original module name before the separator string becomes the new module name, and the portion after the string becomes the architecture.

For example, a module named *mod\_\_impl* would be renamed to *mod* and marked as having architecture *impl*.

If **hdlin\_module\_arch\_name\_splitting** is set to **false** (the default), the renaming never occurs and modules always retain their original names. If the variable is set to **true**, the " \_\_ " is used to divide the module name into module and architecture as described above.

This capability exists to allow the creation of synthetic libraries using Verilog, with multiple architectures per module.

To determine the current value of this variable, use the **printvar hdlin\_module\_arch\_name\_splitting** command. For a list of HDL variables and their current values, use **print\_variable\_group hdl**.

---

### SEE ALSO

---

## hdlin\_module\_name\_limit

Specifies the length threshold for compressing elaborated module names when the **hdlin\_shorten\_long\_module\_name** variable is set to **true**.

---

### TYPE

integer

---

### DEFAULT

256

---

### DESCRIPTION

This variable specifies the length threshold for whether the Presto HDL Compiler compresses names for elaborated modules when the **hdlin\_shorten\_long\_module\_name** variable is set to **true**.

When **hdlin\_shorten\_long\_module\_name** is **true**, if the name of an elaborated module is longer than the value of **hdlin\_module\_name\_limit** (default 256), then a compressed name is used that is easier for downstream tools to handle. The initial part of the name is still recognizable, but the tail of the name is replaced with numbers.

To determine the current value of this variable, use the **printvar hdlin\_module\_name\_limit** command. For a list of HDL variables and their current values, use **printvar\_variable\_group hdl**.

---

### SEE ALSO

[hdlin\\_shorten\\_long\\_module\\_name\(3\)](#)

---

## hdlin\_mux\_for\_array\_read\_sparseness\_limit

Prevents inference of a sparse multiplexer for array read operations when the percentage of MUX\_OP data inputs that are connected is below **hdlin\_mux\_for\_array\_read\_sparseness\_limit**.

---

### TYPE

integer

---

### DEFAULT

90

---

### DESCRIPTION

This variable prevents inference of a sparse multiplexer for array read operations when the percentage of MUX\_OP data inputs that are connected is below **hdlin\_mux\_for\_array\_read\_sparseness\_limit**.

For array read operations, HDL Compiler can infer a MUX\_OP or a SELECT\_OP. MUX\_OPs can be mapped to MUX cells in the technology library but SEL\_OPs cannot be mapped in this manner. MUX cells might be desirable for lowering congestion or implementing specific switching behavior. For an array read operation, if the array size is not a power of 2, HDL Compiler uses a MUX\_OP whose size is the next power of 2. The unused data inputs are disconnected. This is called a sparse multiplexer.

The **hdlin\_mux\_for\_array\_read\_sparseness\_limit** variable guides the HDL Compiler to choose the right cell for an array read operation. This value corresponds to the lowest percentage of MUX\_OP data inputs that must be connected. If the percentage is below this limit, HDL Compiler infers a SELECT\_OP instead, whose number of data inputs does not need to be a power of 2, and therefore gives lower area.

The default percentage is 90. This means that if at least 90% of MUX\_OP data inputs are connected, a MUX\_OP is inferred. If this percentage is below 90%, a SELECT\_OP is inferred instead.

The following are examples of code that will not infer a MUX\_OP:

VHDL

```
-----
signal a : bit_vector (0 to 99);
signal x: bit;
...
x <= a(i);
```

Verilog

```
-----
reg [0:99] a;
reg x;
...
x = a[i];
```

In both examples, a MUX\_OP of 128 data inputs is required, but only 100 would be connected. This gives a percentage of  $100/128 \times 100$ ; that is, only 78% of MUX\_OP data inputs are connected. As this is below 90%, a SELECT\_OP will be inferred.

Note that this variable prevents sparse MUX\_OP inference for array read operations only. Inference of MUX\_OP for if, case, and ?: operations is governed by the **hdlin\_infer\_mux**, **hdlin\_mux\_size\_limit** and **hdlin\_mux\_oversize\_ratio** variables.

---

## SEE ALSO

`hdlin_infer_mux(3)`  
`hdlin_mux_oversize_ratio(3)`  
`hdlin_mux_size_limit(3)`

---

## hdlin\_mux\_oversize\_ratio

Prevents inference of a sparse multiplexer, when the ratio of MUX\_OP data inputs to unique data inputs is above the **hdlin\_mux\_oversize\_ratio**.

---

### TYPE

integer

---

### DEFAULT

100

---

### DESCRIPTION

This variable prevents inference of a sparse multiplexer, when the ratio of MUX\_OP data inputs to unique data inputs is above the **hdlin\_mux\_oversize\_ratio**.

The default ratio is 100.

Here are examples of code that infer a sparse MUX\_OP:

VHDL

```
---
```

```
case sel is
  when "0001" => z <= data(3);
  when "0010" => z <= data(2);
  when "0100" => z <= data(1);
  when "1000" => z <= data(0);
  when others => z <= 'X';
end case;
```

Verilog

```
-----
case (sel)
  4'b0001: z = data[3];
  4'b0010: z = data[2];
  4'b0100: z = data[1];
  4'b1000: z = data[0];
  default: z = 1'bx;
endcase
```

When a MUX\_OP is inferred from each of the previous examples, the mux oversize ratio is calculated. These examples infer a 16-to-1 MUX\_OP, with 4 unique data inputs. The oversize ratio is 4. Setting **hdlin\_mux\_oversize\_ratio** to 3 prevents either example from inferring a MUX\_OP. A setting of 4 or greater allows these examples to infer a MUX\_OP.

To determine the current value of this variable, use the **printvar hdlin\_mux\_oversize\_ratio** command. For a list of HDL variables and

their current values, use **print\_variable\_group hdl**.

---

## SEE ALSO

`hdlin_infer_mux(3)`  
`hdlin_mux_size_limit(3)`

---

## hdlin\_mux\_rp\_limit

Limits the minimum bit width and minimum number of inputs for a relative placement multiplexer.

---

### TYPE

string

---

### DEFAULT

128x4

---

### DESCRIPTION

This variable limits the minimum bit width and minimum number of inputs for a relative placement multiplexer.

The value is  $mxn$  where  $m$  is the minimum bit width and  $n$  is the minimum number of inputs for the multiplexer. The default value is 128x4, meaning that HDL Compiler does not generate relative placement MUX\_OPs for multiplexers specified with fewer than 4 inputs and a bit width of less than 128.

The time it takes to process a relative placement MUX is proportional to the value of **hdlin\_mux\_rp\_limit** squared. For example, the time it takes to process a 128x64 MUX for relative placement is approximately four times that for processing a 128x32 MUX.

To determine the current value of this variable, use the **printvar hdlin\_mux\_rp\_limit** command. For a list of HDL variables and their current values, use **print\_variable\_group hdl**.

---

### SEE ALSO

[hdlin\\_enable\\_relative\\_placement\(3\)](#)

---

## hdlin\_mux\_size\_limit

Limits the number of inputs of an inferred multiplexer.

---

### TYPE

integer

---

### DEFAULT

32

---

### DESCRIPTION

This variable limits the number of inputs of an inferred multiplexer. The default is value is 32. HDL Compiler does not generate MUX\_OPs for multiplexers specified with more than the maximum number of 32 inputs. The size of a multiplexer can be impounded by nested if or case statements.

The time taken to process a MUX is proportional to the value of **hdlin\_mux\_size\_limit** squared. Extreme care must be taken when setting the limit to a figure larger than 32. If the design appears to hang with a limit greater than 32, lower the limit and try again. There is an additional, nonpractical, internal limit of 1073741824 for the size of a inferred mux.

For details, refer to the *HDL Compiler for Verilog User Guide* or the *HDL Compiler for VHDL User Guide*.

To determine the current value of this variable, use the **printvar hdlin\_mux\_size\_limit** command. For a list of HDL variables and their current values, use **print\_variable\_group hdl**.

---

### SEE ALSO

[hdlin\\_infer\\_mux\(3\)](#)

---

## hdlin\_mux\_size\_min

Sets the lower bound for the number of inputs required to infer a multiplexer.

---

### TYPE

integer

---

### DEFAULT

2

---

### DESCRIPTION

This variable sets the lower bound for the number of inputs required to infer a multiplexer. The default value is 2. HDL Compiler does not generate MUX\_OPs for multiplexers specified with less than this minimum number of inputs.

To determine the current value of this variable, use the **printvar hdlin\_mux\_size\_min** command. For a list of HDL variables and their current values, use **printvar\_variable\_group hdl**.

---

### SEE ALSO

[hdlin\\_infer\\_mux\(3\)](#)  
[hdlin\\_mux\\_oversize\\_ratio\(3\)](#)  
[hdlin\\_mux\\_size\\_limit\(3\)](#)

---

## hdlin\_mux\_size\_only

Controls which MUX\_OP cells receive the **size\_only** attribute in HDL Compiler.

---

### TYPE

integer

---

### DEFAULT

1

---

### DESCRIPTION

To ensure that MUX\_OP GTECH cells are mapped to MUX technology cells, you must apply a **size\_only** attribute to the cells to prevent logic decomposition in later optimization steps. Beginning with the B-2008.09-SP3 release, you can control which MUX\_OP cells receive the **size\_only** attribute by using the **hdlin\_mux\_size\_only** variable. The following options are valid for **hdlin\_mux\_size\_only**:

0

Specifies that no cells receive the **size\_only** attribute.

1

Specifies that all MUX\_OP cells directly inferred by an RTL **infer\_mux** pragma and that are on set and reset signals receive the **size\_only** attribute.

2

Specifies that all MUX\_OP cells directly inferred by an RTL **infer\_mux** pragma receive the **size\_only** attribute.

3

Specifies that all MUX\_OP cells directly or indirectly inferred and that are on set and reset signals receive the **size\_only** attribute.

4

Specifies that all MUX\_OP cells directly or indirectly inferred receive the **size\_only** attribute.

A MUX\_OP is "directly inferred" when it results from an **infer\_mux** pragma applied to a specific RTL statement or operator.

A MUX\_OP is "indirectly inferred" when it results from an **infer\_mux** pragma on a named block or from the **hdlin\_infer\_mux** variable being set to **all**.

To determine the current value of this variable, use the **printvar hdlin\_mux\_size\_only** command. For a list of HDL variables and their current values, use **printvar\_variable\_group hdl**.

Note that all MUX\_OP cells inferred using the **infer\_mux\_override** directive will receive the **size\_only** attribute.

---

## SEE ALSO

`set_size_only(2)`  
`hdlin_infer_mux(3)`

---

## hdlin\_netlist\_unloaded\_signals

Controls whether Presto optimizes away the unloaded signals before netlisting.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

hdl\_variables

---

### DESCRIPTION

This variable controls whether Presto optimizes away unloaded signals before netlisting.

When set to **true**, Presto netlists unloaded signals. The purpose is for Presto to report pruned registers accurately when these redundant netlist is removed later.

When set to **false** (the default), Presto optimizes away unloaded signals before netlisting. So Presto will not create the redundant logic first and then remove. The early optimization may cause missing report pruned registers.

---

### SEE ALSO

[hdlin\\_report\\_sequential\\_pruning\(3\)](#)

---

## hdlin\_persistent\_macros\_filename

Controls the name of the file to remember macro definitions encountered during a Verilog or SystemVerilog analyze command in subsequent Verilog or SystemVerilog analyze commands when the hdlin\_enable\_persistent\_macros application variable is enabled.

---

### TYPE

string

---

### DEFAULT

syn\_auto\_generated\_macro\_file.sv

---

### GROUP

hdl\_variables

---

### DESCRIPTION

By default, each Verilog and SystemVerilog analyze command is independent, except for the intermediate files that are saved into the libraries defined by define\_design\_lib.

When the hdlin\_enable\_persistent\_macros application variable is enabled, the analyze command as its first action compiles the file of macro definitions specified by the hdlin\_persistent\_macros\_filename application variable (if the file exists) and then as its last action it overwrites that file with the current macro definitions (or creates the file if it doesn't exist yet).

For example, if the analyze command encounters `undef directives or macro redefinitions, those changes will be reflected in the file at the end of the analyze command.

Like the intermediate files that are saved into libraries, the macro definitions file is protected with Synopsys encryption.

It is recommended to remove any macros definition file that might be left over from a previous session by doing the following before the first analyze command.

```
file delete -force [get_app_var hdlin_persistent_macros_filename]
```

---

### SEE ALSO

hdlin\_enable\_persistent\_macros(3)

---

## hdlin\_preserve\_sequential

Controls whether the **elaborate** and **read** commands retain unloaded sequential cells in the design.

---

### TYPE

string

---

### DEFAULT

none

---

### DESCRIPTION

This variable instructs the **elaborate** command or the **read** command to retain unloaded sequential cells in the design. The default value is **none**. The following values are allowed:

none or false

No unloaded sequential cells are preserved.

all or true

All unloaded sequential cells are preserved, excluding unloaded sequential cells that are used solely as loop variables.

all+loop\_variables or true+loop\_variables

All unloaded sequential cells are preserved, including unloaded sequential cells that are used solely as loop variables.

ff

Only flip-flop cells are preserved, excluding unloaded sequential cells that are used solely as loop variables.

ff+loop\_variables

Only flip-flop cells are preserved, including unloaded sequential cells that are used solely as loop variables.

latch

Only unloaded latch cells are preserved, excluding unloaded sequential cells that are used solely as loop variables.

latch+loop\_variables

Only unloaded latch cells are preserved, including unloaded sequential cells that are used solely as loop variables.

When elaborating an RTL-level design description, HDL Compiler (Presto) infers a sequential cell (a latch or flip-flop) for any Verilog **reg** or VHDL **variable** objects that are conditionally assigned or are assigned under a clock edge. However, if the design never reads the values of these objects or never uses the values to compute any output of the design, the HDL Compiler (Presto) tool, by

default, does not retain sequential cells for these objects. These sequential cells have no loads or there is no path from them to the outputs, and so the tool does not need them to implement the design.

You may want to preserve unnecessary sequential cells, however, to improve observability of the design. The **hdlin\_preserve\_sequential** variable controls which unloaded sequential cells remain in the design.

The **+loop\_variables** option affects which sequential cells are inferred when the value of **hdlin\_preserve\_sequential** is not set as **false** or **none**, and the **+loop\_variables** option is not specified, the tool treats index variables as special and no sequential cells are inferred.

If you do not want variables treated in this special way, specify **+loop\_variables** for the variable values.

In the following example module, the bits of **fail** would ordinarily not exist as sequential cells after elaboration of the design. However, note the following:

- If you set the value of **hdlin\_preserve\_sequential** as **all**, **true**, or **ff**, the tool infers sequential cells for **fail**, and since the **+loop\_variables** option is not specified, the tool treats **i** in the example as special, because **i** is used only as a loop variable. Therefore, the tool does not infer sequential cells for **i**.
- If you set the value of **hdlin\_preserve\_sequential** as **all+loop\_variables**, **true+loop\_variables**, or **ff+loop\_variables**, the tool infers sequential cells for **fail**, and since the **+loop\_variables** option is specified, the tool treats **i** the same way as it treats all other variables and assigns **i** to sequential cells.
- If you set the value of **hdlin\_preserve\_sequential** as **none** (the default), **false**, or **latch**, the tool does not assign either **fail** or **i** to sequential cells in the design.

Example 1:

```
module test (clk,rst,error);
parameter N = 8;
input clk,rst,error;
reg [N-1:0] fail;
integer i, j;

always @(posedge clk or posedge rst)
if (rst)
  fail <= {N-1{1'b0}};
else
  for ( i = 0; i < N; i = i + 1 )
    fail[i] <= fail[i] | error;
endmodule // test
```

Table 1 shows how the variable settings affect the sequential cell inferring for **fail** and **i** in Example 1.

Asterisks (\*) indicate that Presto infers the sequential cells.

Table 1 Variables and Sequential Cell Inferring Matrix for module test

| hdlin_preserve_sequential             | all/true/ff | none/false/latch |      |       |
|---------------------------------------|-------------|------------------|------|-------|
| option "+loop_variables" is specified | true        | false            | true | false |
| reg [7:0] fail                        | *           | *                |      |       |
| reg [31:0] i                          | *           |                  |      |       |

Important: The process of elaboration might preserve unloaded sequential cells, but the cells are deleted by the **compile** command (by default). To preserve the cells throughout the compile process, set the value of the **compile\_delete\_unloaded\_sequential\_cells** variable as **false**.

If there are other variables in your design that cause sequential elements to be inferred, but that you do not want in the final design, specify the preservation of sequential cells on a variable-by-variable basis, using the Verilog **preserve\_sequential** pragma in a declaration.

For more information on the **preserve\_sequential** pragma, see the *HDL Compiler for Verilog User Guide* or the *HDL Compiler for*

*VHDL User Guide.*

To determine the current value of this variable, use the **printvar hdlin\_preserve\_sequential** command. For a list of HDL variables and their current values, use **printvar\_variable\_group hdl**.

---

## SEE ALSO

`elaborate(2)`  
`read(2)`  
`compile_delete_unloaded_sequential_cells(3)`

---

## **hdlin\_presto\_cell\_name\_prefix**

Sets the internal cell name prefix for Presto HDL Compiler.

---

### **TYPE**

string

---

### **DEFAULT**

C

---

### **GROUP**

hdl\_variables

---

### **DESCRIPTION**

This variable sets the internal cell name prefix for HDL Compiler. Use the **hdlin\_presto\_cell\_name\_prefix** variable to specify the cell name prefix. If you do not specify the variable, HDL Compiler generates the cell name with a "C" prefix.

The cell name prefix is only applied to cells whose names are not determined by another HDL Compiler cell naming convention.

The default value for the **hdlin\_presto\_cell\_name\_prefix** variable is C.

To determine the current value of this variable, use the **printvar hdelin\_presto\_cell\_name\_prefix** command. For a list of HDL variables and their current values, use **printvar\_variable\_group hdl**.

---

### **SEE ALSO**

---

## **hdlin\_presto\_net\_name\_prefix**

Sets the internal net name prefix for Presto HDL Compiler.

---

### **TYPE**

string

---

### **DEFAULT**

N

---

### **GROUP**

hdl\_variables

---

### **DESCRIPTION**

This variable sets the internal net name prefix. The net name generated by Synopsys DB always has the prefix "n". The net name generated by Presto has the prefix "N" by default. Use this variable to set the Presto net name prefix to avoid inconsistent net names. The default value for the **hdlin\_presto\_net\_name\_prefix** variable is N.

To determine the current value of this variable, use the **printvar hdlin\_presto\_net\_name\_prefix** command. For a list of HDL variables and their current values, use **printvar\_variable\_group hdl**.

---

### **SEE ALSO**

---

## hdlin\_prohibit\_nontri\_multiple\_drivers

Controls whether the HDL Compiler tool issues an error or warning message when it finds multiple drivers of a net.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable controls whether the HDL Compiler tool issues an error or warning message when it finds multiple drivers of a net. The variable supports Verilog and SystemVerilog input formats.

Multiple drivers occur when a reg variable is driven by more than one always block or a wire variable is driven by more than one continuous assignment or input port and all of the drivers are not tristates.

Before the 2001.08 release, the tool does not issue an error message for multiple-driver nets. After version 2001.08, the tool issues an error message by default. You can convert this ELAB-366 error message to an ELAB-365 warning by setting this variable to **false**. However, this setting is provided primarily for backward compatibility and is not recommended. You should inspect such warnings carefully. Setting the **hdlin\_prohibit\_nontri\_multiple\_drivers** variable to **false** can result in invalid designs.

In simulation, if a reg variable is driven by more than one always block, the definition depends on which block executed most recently. In synthesis, because all blocks are concurrently executing at all times, this behavior is not possible and invalid designs can result if the drivers are shorted together. Therefore, the tool issues an error message if any bits of any variables are driven by more than one process.

The Verilog standard prohibits a multiple-driven wire variable, although some simulators permit this behavior. The tool issues an ELAB-366 error message in this situation. If you want multiple-driven wire variables, set the **hdlin\_prohibit\_nontri\_multiple\_drivers** variable to **false**. Note that this variable setting might cause invalid designs.

Multiple drivers are permitted on tri nets, although a warning is issued if all the drivers are not tristate devices.

To determine the current value of this variable, use the **printvar hdlin\_prohibit\_nontri\_multiple\_drivers** command. For a list of all HDL variables and their current values, use the **print\_variable\_group hdl** command.

---

### SEE ALSO

---

## hdlin\_report\_sequential\_pruning

Controls reporting about removal of tentatively inferred sequentials.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

The **hdlin\_report\_sequential\_pruning** variable lets you control whether HDL Compiler should issue a message when it detects that a sequential element that has already been tentatively inferred, but that is not actually required for proper functioning of the design being elaborated, is removed.

An RTL-level design description in Verilog or VHDL may contain variables for which a sequential cell would ordinarily be inferred (either because they are assigned under a clock edge, or because they are conditionally assigned) but whose values are never read, or whose values are not used in computing any output of the design. Because their values are not used (that is, they have no loads, or no path to the outputs), by default HDL Compiler will attempt not to infer sequential cells for these variables.

But if it does infer them, it will then try to prune them before the end of elaborate.

In some circumstances designers wish to retain these sequential cells. Unloaded sequential cells can be inferred by two methods. First, if `hdlin_preserve_sequential` is "all", then a sequential cell will be inferred for any variable that is conditionally assigned or assigned under a clock, regardless of whether its value is used or not. Second, if `hdlin_preserve_sequential` is not set, but some variables are marked with the "preserve\_sequential" pragma, only those variables will receive sequential cells even if they have no loads.

---

### SEE ALSO

`hdlin_preserve_sequential(3)`  
`elaborate(2)`

---

## hdlin\_reporting\_level

Determines which information Presto HDL Compiler prints in the report.

---

### TYPE

string

---

### DEFAULT

basic

---

### DESCRIPTION

This variable controls the amount of output information to be included in the Presto elaboration report.

The following information is under control:

- **floating\_net\_to\_ground** prints the report for floating net connects to ground. This variable is best used in conjunction with the **set hdlin\_keep\_signal\_name user** command and is not guaranteed to report all nets. Use the **check\_design** command for detecting unconnected pins and ports.
- **fsm** prints the report for inferred state variables.
- **inferred\_modules** prints the report for inferred sequential elements.
- **mux\_op** prints the report for MUX\_OPs.
- **syn\_cell** prints the report for synthetic cells.
- **tri\_state** prints the report for inferred tristate elements.

The **hdlin\_reporting\_level** variable can be set to 4 base settings: **none**, **basic**, **comprehensive**, and **verbose**, as shown in the following table:

Table 1 Base Settings

| Information included in report  none   basic   comprehensive   verbose |       |       |      |         |
|------------------------------------------------------------------------|-------|-------|------|---------|
| floating_net_to_ground                                                 | false | false | true | true    |
| fsm                                                                    | false | false | true | true    |
| inferred_modules                                                       | false | true  | true | verbose |
| mux_op                                                                 | false | true  | true | true    |
| syn_cell                                                               | false | false | true | true    |
| tri_state                                                              | false | true  | true | true    |

In addition to the base settings above, you can also modify the base settings to have fine grain control of individual reports by either adding (+) or subtracting (-) specific report(s) from the base setting with the following keywords:

```
floating_net_to_ground  
fsm  
syn_cell  
mux_op  
inferred_modules  
tri_state
```

---

## EXAMPLES

The following example uses **comprehensive-fsm**:

```
set hdlin_reporting_level comprehensive-fsm
```

The generated report shows the following settings:

```
floating_net_to_ground true  
fsm false  
inferred_modules true  
mux_op true  
syn_cell true  
tri_state true
```

The following example uses **verbose-mux\_op-tri\_state**:

```
set hdlin_reporting_level verbose-mux_op-tri_state
```

The generated report shows the following settings:

```
floating_net_to_ground true  
fsm true  
inferred_modules verbose  
mux_op false  
syn_cell true  
tri_state false
```

The following example shows two commands that generate equivalent reports:

```
set hdlin_reporting_level basic+floating_net_to_ground+syn_cell+fsm
```

```
set hdlin_reporting_level comprehensive
```

To determine the current value of this variable, use the **printvar hdlin\_reporting\_level** command. For a list of HDL variables and their current values, use **printvar\_variable\_group hdl**.

---

## SEE ALSO

---

## hdlin\_shorten\_long\_module\_name

Controls whether the Presto HDL Compiler compresses long names for elaborated modules.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

hdl\_variables

---

### DESCRIPTION

This variable controls whether the Presto HDL Compiler compresses long names for elaborated modules.

When the value of this variable is **true**, if the name of an elaborated module is longer than the value of **hdlin\_module\_name\_limit** (default 256), then a compressed name is used that is easier for downstream tools to handle. The initial part of the name is still recognizable, but the tail of the name is replaced with numbers.

When the value is **false** (the default), the names of elaborated modules are uncompressed, even if they exceed the length specified by **hdlin\_module\_name\_limit**.

To determine the current value of this variable, use the **printvar hdlin\_module\_name\_limit** command. For a list of HDL variables and their current values, use **printvar\_variable\_group hdl**.

---

### SEE ALSO

[hdlin\\_module\\_name\\_limit\(3\)](#)

---

## hdlin\_strict\_verilog\_reader

Controls whether the Verilog Netlist Reader enforces strict IEEE-1364 language specification compliance.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

hdl\_variables

---

### DESCRIPTION

This variable controls whether the Verilog Netlist Reader errors or not on illegal verilog, like repeated identifiers.

When the value of this variable is **true**, constructs usually accepted by the verilog reader, such as instantiations with the same name as a wire, will trigger an error.

When the value is **false** (the default), no error is issued.

---

### SEE ALSO

---

## hdlin\_subprogram\_default\_values

Determines which value the compiler will use as the default value for variables, 'LEFT of its type or 0s.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

hdl\_variables

---

### DESCRIPTION

This variable determines which value the compiler will use as the default value for variables, 'LEFT of its type or 0s.

When this variable is set to **true**, 'LEFT of the type of variable is used as its default value. If you set this variable to **false** (the default), 0s are used.

---

### SEE ALSO

---

## hdlin\_sv\_blackbox\_modules

Specify one or more SystemVerilog modules to be ignored during design read.

---

### TYPE

string

---

### DEFAULT

""

---

### DESCRIPTION

The **hdlin\_sv\_blackbox\_modules** allows the user to specify one or more SystemVerilog modules to be ignored during design read.

The modules are specified by setting the variable **hdlin\_sv\_blackbox\_modules** to a list of modules, e.g.

prompt> set hdlin\_sv\_blackbox\_modules "mod1 mod2 ..."

Here mod1, mod2 are names of modules as coded in the RTL.

The warning message (VER-746) is generated during **read\_sverilog** or **analyze -f sverilog** command. An example of the message is shown below:

Warning: mod1.v:2: The declaration of module 'mod1' is being ignored, because the module name is in hdlin\_sv\_blackbox\_modules. (VER-746)

If the tool tries to link the modules (during **elaborate**or **link** commands), **LINK-35 message is generated**:

Warning: All references to module 'mod1' are ignored and treated as black boxes. (LINK-35)

The valid module names are those coded in the RTL. The design names, e.g. those reported by **list\_designs**, **may not work with this feature**.

No messages are generated for specified names that do not match valid module names.

---

### SEE ALSO

[read\\_sverilog\(2\)](#)  
[analyze\(2\)](#)  
[elaborate\(2\)](#)  
[link\(2\)](#)

```
list_designs(2)
```

---

## hdlin\_sv\_enable\_rtl\_attributes

Enable SystemVerilog user attributes.

---

### TYPE

boolean

---

### DEFAULT

FALSE

---

### DESCRIPTION

The **hdlin\_sv\_enable\_rtl\_attributes** SystemVerilog allows users to specify their own attributes on cell, port, pin, and module. For example:

```
module top (
    (* user_attr = "true" *) input TOPIN,
    (* user_attr = "top port" *) output TOPOUT);
    (* my_attr="P" *) BOT U_BOT ((* Pin_Attr = 0 *) .BOTIN(TOPIN), .BOTOUT(TOPOUT));
endmodule
```

```
dc_shell> report_attributes [get_ports *]
Design      Object      Type      Attribute Name      Value
-----
```

| Design | Object | Type   | Attribute Name | Value    |
|--------|--------|--------|----------------|----------|
| top    | TOPIN  | string | user_attr      | true     |
| top    | TOPOUT | string | user_attr      | top port |

```
dc_shell> report_attributes [get_cells *]
Design      Object      Type      Attribute Name      Value
-----
```

| Design | Object | Type   | Attribute Name | Value |
|--------|--------|--------|----------------|-------|
| top    | U_BOT  | string | my_attr        | P     |

---

### SEE ALSO

analyze(2)  
elaborate(2)  
link(2)

---

## hdlin\_sv\_enforce\_standalone\_generate\_blocks

Enforce that standalone generate blocks will be banned in SystemVerilog and Verilog-2005

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

hdl\_variables

---

### DESCRIPTION

Enforce that generate blocks have either a loop or conditional construct according to the SystemVerilog and Verilog-2005 LRM, i.e. the standalone generate block will be banned. Setting this variable to false will reduce the severity of using a standalone generate from an error (VER-946) to a warning (VER-945).

---

### SEE ALSO

[hdlin\\_vrlg\\_std\(3\)](#)  
[hdlin\\_sverilog\\_std\(3\)](#)  
VER-945(n)  
VER-946(n)

---

## hdlin\_sv\_interface\_only\_modules

Enable HDL Compiler to read SystemVerilog designs as interface only

---

### TYPE

string

---

### DEFAULT

""

---

### DESCRIPTION

This option lists System Verilog designs as interface only. HDL Compiler parses the module interface of the listed designs, skipping the module content, and creates a black box for each module.

During elaboration, HDL compiler issues a warning message that the module content is discarded and ignored.

Here is an example:

```
prompt> set hdlin_sv_interface_only_modules {my_module1 my_module2} prompt> analyze -f sverilog top.sv
```

```
Warning: ./rtl/top.sv:21: The body of module 'my_module1' is being discarded, because the module name is in  
hdlin_sv_interface_only_modules. (VER-747)
```

---

## hdlin\_sv\_packages

Specifies how SystemVerilog packages should be analyzed.

---

### TYPE

string

---

### DEFAULT

dont\_chain

---

### DESCRIPTION

Specifies which semantics the **analyze** or **read\_file** command should apply when a **-format sverilog** source file declares a package. The setting affects the analyze step of SystemVerilog package declarations or references; it has no effect during **elaborate**. The allowed values for **hdlin\_sv\_packages** are **dont\_chain** (the default) and **chain**.

The default behavior is as described in Clause 26 of IEEE Std 1800-2012, the standard for SystemVerilog. Overriding the default to **chain** changes how an **import** statement treats names imported into the topmost (global) scope of a package\_declaration:

- The default **dont\_chain** setting enforces the IEEE standard and prevents imported names from being re-exported to clients of the package being declared.
- The **chain** setting instead re-exports names that are imported into the global scope of a package; they may all be imported by the intermediate package's clients. An imported name and its definition that are re-exported (or chained) will not collide or interfere with copies of themselves in those cases where several intermediate packages redistribute content they acquired from a common source package (provided they all acquire it from a compatible analyzed version of the same source file).

Example: By default, output dont\_chain will get 1 and output chain will get 0, but if the application option is overridden to **chain**, then output dont\_chain will get 0 and output chain will get 1.

```
package A; localparam N = 44; endpackage
package B; localparam N = 77; endpackage
package C; import B::N; endpackage
import A::*;
module VER934 import C::*; (output dont_chain, chain);
  assign dont_chain = (N == 44);
  assign chain = (N == 77);
endmodule
```

The analyzed result, a file named *package\_identifier.pvk*, always contains a full copy of all imported content. A package's .pvk file can stand alone; it does not require its clients to access the .pvk files that supplied its imported ingredients (unlike source-level file inclusion).

The chaining issue only concerns whether imported names become explicitly visible to an intermediate package's clients as do objects explicitly declared at the outermost level of the intermediate package. Because a wildcard "import intermediate\_pkg::\*;" encumbers all

of the exportable names found in "intermediate\_pkg", the selection of **chain** or **dont\_chain** can alter the outcome of name resolutions when several packages are combined in a downstream client.

The setting of **hdlin\_sv\_packages** at the time a package is analyzed is compiled into a visibility property on the imported, global names in the resulting .pvk file. This is an independent property that can be different at each level of a supply chain; it is not an inherited property of the name itself. A VER-934 informational message always indicates how this property is being set for those names where it might eventually matter.

To determine the current value of this variable, use the **report\_app\_var hlin\_sv\_packages** command. For a list of HDL variables and their current values, use **print\_variable\_group hdl**.

---

## SEE ALSO

[analyze\(2\)](#)  
[read\\_file\(2\)](#)  
[VER-20\(n\)](#)  
[VER-21\(n\)](#)  
[VER-934\(n\)](#)

---

## hdlin\_sv\_tokens

Specifies whether a tokens file should be written out during the analysis of SystemVerilog designs.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When **hdlin\_sv\_tokens** is turned on, the lexical tokens that are sent to the parser during analysis of a SystemVerilog design (such as with an **analyze -f sverilog** or a **read\_sverilog** command) will also be saved to an output file in the work directory.

When using complex macros or nested conditional compilation directives, it might help to see what the actual RTL will be after preprocessing, for example, to understand a syntax error.

When the value of **hdlin\_sv\_tokens** is overridden and set to **true**, an expanded version of the source files is written to an output file *tokens.n*/*n*.sv, instead of being sent to the parser. In the output file, conditional compilation directives will already have been taken into account and all macro invocations will already have been expanded. The first tokens file written out in a particular work directory will be *tokens.1*.sv, the next *tokens.2*.sv, the next *tokens.3*.sv, and so on.

Although the output file is legal SystemVerilog, it is formatted in a way that is intended to be conveniently human readable, by using standard line directives to indicate the original source files and line numbers. This makes it relatively easy to track down the source of an error using the file name and line number in the error message. For example, if the error message refers to line 321 of the file "my\_file.sv", then look for *line 321 "my\_file.sv"* in the output file.

The only comments preserved are those that are sent to the parser, because they are in more than mere comments, such as synthesis pragmas and embedded scripts.

If any of the source files are encrypted, then the output file is not created.

---

### SEE ALSO

[analyze\(2\)](#)  
[read\\_sverilog\(2\)](#)

---

## hdlin\_sv\_union\_member\_naming

Controls the naming styles for elements associated with the union data type in SystemVerilog.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

hdl\_variables

---

### DESCRIPTION

By default, the tool uses simple names for elements inferred from unions in SystemVerilog. Setting this variable to **true** enables the tool to use the name of the first union member as a reference for the port, net, and cell names associated with the union data type. For example,

```
1 typedef union packed {
2   byte   field1;
3   logic [7:0] field2;
4 } packet;
5
6 module test (input packet p1, output packet p2, input clk);
7   always_ff @ (posedge clk)
8     p2.field1 = p1.field2;
9 endmodule
```

When you set this variable to **false**, the following names are inferred:

Ports and nets: p1[7], p1[6], ..., p1[0]  
Cells: p2\_reg[7], p2\_reg[6], ..., p2\_reg[0]

When you set this variable to **true**, the following names are inferred:

Ports and nets: p1[field1][7], p1[field1][6], ..., p1[field1][0]  
Cells: p2\_reg[field1][7], p2\_reg[field1][6], ..., p2\_reg[field1][0]

When you use the **read\_saif** command to read in a SAIF file generated from a FSDB, setting this variable to **true** might increase the

acceptance of the annotated switching activity.

---

## SEE ALSO

---

## hdlin\_sverilog\_std

Controls whether HDLC SystemVerilog enforces SystemVerilog 2005 or SystemVerilog 2009 or SystemVerilog 2012.

---

### TYPE

integer

---

### DEFAULT

2012

---

### GROUP

hdl\_variables

---

### DESCRIPTION

This variable controls whether HDLC SystemVerilog is to enforce SystemVerilog 2005 or SystemVerilog 2009 or SystemVerilog 2012.

- If the variable is set to 2012, SystemVerilog 2012 is enforced. There is no Verilog 2012.
- If the variable is set to 2009, SystemVerilog 2009 is enforced. There is no Verilog 2009.
- If the variable is set to 2005 (the default), SystemVerilog 2005 is enforced.

The SystemVerilog 2009 standard merged two previous standards, Verilog 2005 and SystemVerilog 2005, which defined extensions to it. Those two standards were designed to be used as one language, so merging the base Verilog language and the SystemVerilog extensions into a single standard provides all information regarding syntax and semantics in a single document. Additionally, there are many extensions beyond SystemVerilog 2005 in SystemVerilog 2009.

The SystemVerilog 2012 standard adds extensions beyond SystemVerilog 2009.

---

### SEE ALSO

[hdlin\\_vrlg\\_std\(3\)](#)

---

## hdlin\_tic\_tic\_discards\_whitespace

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

As described in section 22.5.1 of IEEE Std 1800-2017, a `` (double backtick) in a SystemVerilog macro definition "delimits lexical tokens without introducing white space, allowing identifiers to be constructed from arguments."

Enabling this application variable (default is **false**) causes the nonstandard behavior that any whitespace surrounding the `` will be discarded when the macro is invoked.

For example, when this variable is enabled, analyzing the following RTL:

```
`define M(arg) assign ``arg = 1;  
module test(output out);  
`M(out)  
endmodule
```

results in the following messages:

```
Warning: ./top.sv:3: The 'white space before `` syntax is non-standard.  
Those spaces are discarded (VER-730)  
Error: ./top.sv:3: Syntax error at or near token '='  
      in macro "M"  
      called from file "./top.sv" (line 3). (VER-294)
```

---

### SEE ALSO

---

## hdlin\_unified\_rtl\_read

Enable Synopsys unified frontend

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This is the main control variable that decides which flow analyze/elaborate commands will use.

When **hdlin\_unified\_rtl\_read** is true, analyze/elaborate commands will use Synopsys unified frontend for reading the RTL files.

When **hdlin\_unified\_rtl\_read** is false (the default), analyze/elaborate commands will use Legacy frontend for reading the RTL files.

To determine the current value of this variable, use the **printvar hdlin\_unified\_rtl\_read** command. For a list of HDL variables and their current values, use **print\_variable\_group hdl**.

---

### SEE ALSO

hdlin\_vcs\_home(3)  
analyze(2)  
elaborate(2)  
read\_verilog(2)  
read\_file(2)  
set\_svf(2)  
set\_verification\_top(2)

---

## hdlin\_upcase\_names

Controls whether identifiers in the Verilog source code are converted to uppercase letters or left in their original case.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable controls whether identifiers in the Verilog source code are converted to uppercase letters or left in their original case.

The default setting of this variable is **false**, which means that all names are left the way they are.

Setting the variable to **true** causes conversion of all identifiers in the Verilog code (variables, ports, and so on) to uppercase letters.

---

### SEE ALSO

---

## hdlin\_v2005\_replication\_semantics

Controls the treatment of zero replication constants in Verilog-1995 and Verilog-2001.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

hdl\_variables

---

### DESCRIPTION

Until Verilog-2005 it was non-standard for the first operand in a replication operation to be zero, but, instead of issuing an error, HDL Compiler would implement `{0{expression}}` as 1'b0, regardless of the size or value of the second operand. By default, the tool now implements a zero replication constant according to the rules of Verilog-2005, even if the Verilog standard is overridden back to 1995 or 2001, in which case overriding this variable to **false** restores the older behavior. Overriding this variable has no effect when the standard is 2005. Because the older style of implementing a non-standard zero replication constant is likely to mismatch with simulation, an ELAB-364 warning is issued when it happens.

For example, in Verilog-2001 by default

```
1 module test(input [1:0] in, output [3:0] out);
2   assign out = { {2{in}}, {0{in}} };
3 endmodule
```

is implemented the same as

```
1 module test(input [1:0] in, output [3:0] out);
2   assign out = {2{in}};
3 endmodule
```

but when the variable is overridden to **false** it is implemented the same as

```
1 module test(input [1:0] in, output [3:0] out);
2   assign out = { in[0], in, 1'b0 };
3 endmodule
```

and an ELAB-364 warning is issued.

---

## SEE ALSO

[hdlin\\_vrlg\\_std\(3\)](#)

---

## hdlin\_vcs\_home

VCS\_HOME to take vcs binaries, when using unified frontend flow

---

### TYPE

String

---

### DEFAULT

""

---

### DESCRIPTION

Users must set this variable to the path of a compatible version of VCS installation that tool should use.

To determine the current value of this variable, use the **printvar hdlin\_vcs\_home** command. For a list of HDL variables and their current values, use **print\_variable\_group hdl**.

---

### SEE ALSO

hdlin\_unified\_rtl\_read(3)  
analyze(2)  
elaborate(2)  
read\_verilog(2)  
read\_file(2)  
set\_svf(2)  
set\_verification\_top(2)

---

## hdlin\_verification\_priority

Instructs the tool to prioritize formal verification over QoR while reading the RTL files.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### GROUP

hdl\_variables

---

### DESCRIPTION

Setting this variable to **true** adjusts optimization inside of the tool to prioritize formal verification compatibility over QoR. This variable only affects optimizations done during the reading and elaboration of RTL files. To control optimization during later stages, see the man page for the **set\_verification\_priority** command.

Set this variable in response to a hard verification from your formal verification tool.

---

### SEE ALSO

[set\\_verification\\_priority\(2\)](#)

---

## hdlin\_vhdl93\_concat

Controls the concatenation behavior the tool uses to conform to the VHDL '93 Standard or the VHDL '87 Standard.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

hdl\_variables

---

### DESCRIPTION

The **hdlin\_vhdl93\_concat** variable controls the concatenation behavior the Presto VHDL Compiler uses to conform to the VHDL '93 Standard or the VHDL '87 Standard. If you set the value of this variable as **true** (the default), the tool follows the VHDL '93 Standard. If you set the value as **false**, the tool follows the VHDL '87 Standard.

---

### SEE ALSO

---

## hdlin\_vhdl\_mixed\_language\_instantiation

Controls if mixed language instantiations are to be used in VHDL.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable controls if mixed language instantiations are to be used in VHDL.

When you set the **hdlin\_vhdl\_mixed\_language\_instantiation** variable to true, HDL Compiler allows VHDL direct entity instantiations of a lower-level design that is not VHDL. Furthermore, if VHDL configurations are enabled, you can configure (standalone or architecture embedded) a lower-level design that is not VHDL to be used for a VHDL component; that is, you can configure the components inside this lower-level design.

All parameters have to be mapped explicitly in the generic mappings, though one or more are set to the default. Additionally, you cannot map literals in the generic mappings; that is, literal constants, such as 11, should be replaced with local constants like my\_bit\_vector\_constant.

To see the current setting of this variable, use the **printvar hdlin\_vhdl\_mixed\_language\_instantiation** command. For a list of HDL variables and their current settings, use the **print\_variable\_group hdl** command.

---

### SEE ALSO

---

## hdlin\_vhdl\_std

Controls whether HDL Compiler follows the VHDL 2008 standard, the 1993 standard, or the 1987 standard.

---

### TYPE

integer

---

### DEFAULT

2008

---

### DESCRIPTION

This variable determines the standard that the HDL Compiler is to follow in your design.

- If this variable is set to 2008 (the default), the compiler uses the VHDL 2008 standard.
  - If this variable is set to 1993, the compiler uses the VHDL 1993 standard.
  - If this variable is set to 1987, the compiler uses the VHDL 1987 standard.
- 

### SEE ALSO

[hdlin\\_sverilog\\_std\(3\)](#)  
[hdlin\\_vrlg\\_std\(3\)](#)

---

## hdlin\_vhdl\_syntax\_extensions

Enables VHDL language features that are currently outside of the supported synthesizable subset.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable enables VHDL language features that are currently outside of the supported synthesizable subset. Use of these language constructs must be accompanied by thorough verification.

The following features are currently enabled:

- Deferred constant definition: a constant declaration not accompanied by an assignment expression.
  - Arrays of base type Boolean: use Boolean as the range type of an array.
  - Impure functions: a function specification contains the reserved word impure.
- 

### SEE ALSO

---

## **hdlin\_vrlg\_std**

Controls whether Presto Verilog enforces Verilog 1995, Verilog 2001, or Verilog 2005.

---

### **TYPE**

integer

---

### **DEFAULT**

2005

---

### **GROUP**

hdl\_variables

---

### **DESCRIPTION**

This variable controls whether Presto Verilog enforces Verilog 1995, Verilog 2001, or Verilog 2005.

- If this variable is set to the value of 2005 (the default), Verilog 2005 is enforced.
  - If the variable is set to 2001, Verilog 2001 is enforced.
  - If the variable is set to 1995, Verilog 1995 is enforced.
- 

### **SEE ALSO**

[hdlin\\_sverilog\\_std\(3\)](#)

---

## hdlin\_while\_loop\_iterations

Places an upper bound on the number of times a loop is unrolled to prevent potential infinite loops.

---

### TYPE

string

---

### DEFAULT

4096

---

### DESCRIPTION

This variable places an upper bound on the number of times a loop is unrolled to prevent potential infinite loops. Loop unrolling occurs until the loop terminates. If you know that your loop will execute more times than the limit allows and that your loop will terminate at some point, increase the value of this variable.

To determine the current value of this variable, use the **printvar hlin\_while\_loop\_iterations** command. For a list of HDL variables and their current values, use the **print\_variable\_group hdl** command.

---

### SEE ALSO

---

## hdlout\_internal\_busses

Controls the way in which the **write -format verilog** command and the **write -format vhdl** command write out internal bused nets by parsing the names of the nets.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When the **hdlout\_internal\_busses** variable is set to the value of **true**, it controls the way in which the **write -format verilog** command and the **write -format vhdl** command write out internal bused nets by parsing the names of the nets.

When writing out VHDL files, be sure to set the **vhdlout\_single\_bit** variable and the **vhdlout\_preserve\_hierarchical\_types** variable to "user" or "vector." Set the **bus\_inference\_style** variable and the **bus\_naming\_style** variable to the naming style. For more information, see the man pages for the **bus\_inference\_style** and **bus\_naming\_style** variables.

When writing out Verilog files, set the **verilogout\_single\_bit** variable to **false** (the default). Set the **bus\_inference\_style** variable and the **bus\_naming\_style** variable to the naming style. For more information, see the man pages for the **bus\_inference\_style** and **bus\_naming\_style** variables.

To determine the current value of this variable, use the **printvar hdlout\_internal\_busses** command. For a list of all **io** variables and their current values, use the **print\_variable\_group io**.

---

### SEE ALSO

**bus\_inference\_style(3)**  
**bus\_naming\_style(3)**

---

## **hier\_dont\_trace\_ungroup**

Disables ungroup tracing set on the design with the **ungroup** command.

---

### **TYPE**

Boolean

---

### **DEFAULT**

0

---

### **DESCRIPTION**

This variable disables ungroup tracing set on the design with the **ungroup** command. When **hier\_dont\_trace\_ungroup** is set to **0** (the default), the **ungroup** command places on the design being ungrouped a string attribute that describes the ungroup operation. Other tools (for example, RTL Analyzer) can later use the attribute to recreate the ungroup operation and trace between the mapped and GTECH (generic) circuits.

Setting **hier\_dont\_trace\_ungroup** to **1** disables ungroup tracing and can increase the efficiency of **ungroup** and other commands.

---

### **SEE ALSO**

[ungroup\(2\)](#)

---

## high\_fanout\_net\_pin\_capacitance

Specifies the pin capacitance to use for computing the loading of high-fanout nets.

---

### TYPE

float

---

### DEFAULT

1

---

### DESCRIPTION

This variable specifies the pin capacitance to use for computing the loading of high-fanout nets.

The tool computes the pin capacitance for high-fanout nets by multiplying the capacitance specified with the **high\_fanout\_net\_pin\_capacitance** variable times the high-fanout threshold.

For best results, you should specify a large value for the pin capacitance to cause violations on all constrained high-fanout nets. This forces the tool to replace the nets with buffer trees during compilation.

To determine the current value of this variable, use the **printvar high\_fanout\_net\_pin\_capacitance** variable. For a list of all timing variables and their current values, use the **print\_variable\_group timing** variable.

---

### SEE ALSO

[high\\_fanout\\_net\\_threshold\(3\)](#)

---

## high\_fanout\_net\_threshold

Specifies the minimum number of loads for a net to be classified as a high-fanout net.

---

### TYPE

integer

---

### DEFAULT

1000

---

### DESCRIPTION

This variable specifies the minimum number of loads for a net to be classified as a high-fanout net.

Delays and loads of high-fanout are computed using a simplified model assuming a fixed fanout number. The rationale behind this is that delays of high-fanout nets are expensive to compute but such nets are often unconstrained (as in the case of global reset nets, scan enable nets, and so on). Those high-fanout nets that actually are constrained should eventually be replaced by buffer trees. So detailed delay calculations on such nets are expensive and usually unnecessary.

Setting the threshold to 0 (or to a very large number) ensures that no nets will be treated as high-fanout nets. However, be aware that forcing fully accurate delay calculations on high-fanout can significantly increase compilation runtime in some cases.

The pin capacitance for high-fanout nets is computed by multiplying the capacitance specified by the **high\_fanout\_net\_pin\_capacitance** variable times the high-fanout threshold plus the number of net drivers. If there are delay annotations remaining from an earlier flow step, these annotations will be used instead of the high-fanout net model.

The simplified net delay model is used only when computing data delays. Propagated clock latencies are always computed using the full accuracy net delay model.

To determine the current value of this variable, use the **printvar high\_fanout\_net\_threshold** command. For a list of all timing variables and their current values, use **print\_variable\_group timing**.

---

### SEE ALSO

[high\\_fanout\\_net\\_pin\\_capacitance\(3\)](#)

---

## **hlo\_resource\_allocation**

Sets the default resource sharing type to be used by the **compile** command, if the **resource\_allocation** attribute is not set.

---

### **TYPE**

string

---

### **DEFAULT**

constraint\_driven in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### **DESCRIPTION**

This variable sets the default resource sharing type to be used by the **compile** command, if the **resource\_allocation** attribute is not set. This variable has no effect in **compile\_ultra**.

Allowed values are as follows:

**constraint\_driven** (the default)

Directs **compile** to share resources so that the timing constraints are met, or not made worse, by sharing.

**area\_only**

Directs **compile** to share operators without regard for timing constraints. All arithmetic expression trees are balanced.

**area\_no\_tree\_balancing**

Directs **compile** to share operators without regard to timing constraints. Arithmetic expression trees are not balanced.

**none**

Directs **compile** to do no resource sharing, so that each operation is implemented with separate circuitry.

**true**

Equivalent to **constraint\_driven**; provided for backward compatibility with v2.0.

**false**

Equivalent to **none**; provided for backward compatibility with v2.0.

You can override the value of **hlo\_resource\_allocation** for the current design by using the **set\_resource\_allocation** command to set the **resource\_allocation** attribute.

To determine the current value of this variable, use the **printvar hlo\_resource\_allocation** command. For a list of all HDL variables and their current values, use **print\_variable\_group hdl**.

---

## SEE ALSO

[compile\(2\)](#)  
[set\\_resource\\_allocation\(2\)](#)  
[design\\_attributes\(3\)](#)  
[synthetic\\_library\(3\)](#)

---

## html\_log\_enable

Enables the HTML log generation in dc\_shell.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### GROUP

system\_variables

---

### DESCRIPTION

This variable enables the HTML log generation in dc\_shell, which then can be viewed in the file that the variable html\_log\_filename points to.

---

### SEE ALSO

[html\\_log\\_filename\(3\)](#)

---

## html\_log\_filename

Changes the file name of the starting HTML file.

---

### TYPE

String

---

### DEFAULT

default.html in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### GROUP

system\_variables

---

### DESCRIPTION

This variable changes the file name of the starting HTML file that is generated if the HTML log generation is enabled in dc\_shell.

---

### SEE ALSO

[html\\_log\\_enable\(3\)](#)

---

## icc2\_link\_ddc\_transfer

Enables the DDC based transfer from Design Compiler topographical to ICC2.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXTnon-topographical mode

false in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

Setting the **icc2\_link\_ddc\_transfer** variable to **true** enables DDC based transfer through the ICC2Link from Design Compiler topographical to ICC2.

This variable works only in topographical mode.

To determine the current value of this variable, use **printvar icc2\_link\_ddc\_transfer** command.

---

### SEE ALSO

`set_icc2_options(2)`

---

## **icc2\_link\_processes\_inherit\_parent\_process\_group**

When set, any new processes spawned by ICC2 Link will inherit the parent process group.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

icc2

---

### **DESCRIPTION**

During ICC-II Link, DC spawns processes which may not have a parent process. When this variable is set to true, the ICC-II Link processes will never be orphaned. Instead, these spawned process will inherit the parent process group.

---

## ignore\_clock\_input\_delay\_for\_skew

Controls how clock skew calculations handle the input delay on clocks.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable controls how clock skew calculations handle the input delay on clocks.

Normally, you should use the **set\_input\_delay** command only on data ports, and use the **set\_clock\_latency** command on clock ports. In cases where the **set\_input\_delay** command has been used on a clock port, the default behavior differs between PrimeTime and the synthesis timing engine used by Design Compiler and IC Compiler.

By default (**false**), the synthesis timing engine uses the input delay values set on the clocks with the **set\_input\_delay** command when computing the skew values.

When set to **true**, the synthesis timing engine ignores the input delay values set on the clocks with the **set\_input\_delay** command when computing the skew values of clocked registers, which is compatible with the default PrimeTime behavior.

Set this variable to **true** when correlating synthesis and Primetime results.

---

### SEE ALSO

`set_input_delay(2)`  
`set_clock_latency(2)`

---

## ignore\_tf\_error

Sets the flag for the tool to ignore unrecognized attributes in the technology file.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

Setting the **ignore\_tf\_error** variable to **true** allows the tool to ignore unrecognized attributes when reading the technology file. Unrecognized attributes will still be reported using the TFCHK-009 error message. However, a TFCHK-096 informational message will be reported at the end of the technology file reading to indicate that these errors were ignored.

Since the technology file contains many attributes that are required for correct functionality of the tool, set this variable only after it has been verified that all of the unrecognized attributes in the technology file are safe to ignore.

---

### SEE ALSO

[create\\_mw\\_lib\(2\)](#)

---

## in\_gui\_session

This read-only variable is "true" when the GUI is active and "false" when the GUI is not active.

---

### TYPE

*Boolean*

---

### DEFAULT

false

---

### DESCRIPTION

This variable can be used in writing Tcl code that depends on the presence the graphical user interface (GUI). The read-only variable has the value "true" if **gui\_start** has been invoked and the GUI is active. Otherwise, the variable has the value "false" (default).

---

### SEE ALSO

`printvar(2)`  
`gui_start(2)`  
`gui_stop(2)`

---

## initial\_target\_library

Specifies the list of technology libraries of components to be used for the first part of leakage power optimization in **place\_opt**.

---

### TYPE

list

---

### DEFAULT

"" in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

Leakage power can be optimized for multi-vth designs in two different flows in **place\_opt**. One way is to use all of the target libraries throughout optimization. The other is to use a subset of target libraries in the first part of the optimization steps and all the libraries in the second part. The **initial\_target\_library** variable specifies the list of technology libraries of components to be used for the first part of leakage power optimization in **place\_opt**.

---

### SEE ALSO

---

## insert\_test\_design\_naming\_style

Specifies how the **insert\_dft** command names new designs created during the addition of test circuitry.

---

### TYPE

string

---

### DEFAULT

%s\_test\_%d

---

### DESCRIPTION

This variable specifies how the **insert\_dft** command names new designs created during the addition of test circuitry. When **insert\_dft** modifies a design by adding test circuitry, it creates the design with a new, unique name. The new name is derived from the original design name and the format specified by this variable.

This variable must contain only one %s (percent s) and %d (percent d) character sequence. The percent sign has special meaning in the formatting process. To use a percent sign in the design name, two are needed in the variable setting (%%).

When **insert\_dft** generates a new design name, it replaces %s with the original design name and %d with an integer. The integer is one that ensures the new name is unique. A single percent sign is substituted for %%.

For example, if this variable is set to `%s_test_%d`, and the original design name is *my\_design*, the new design name is *my\_design\_test\_1*.

If the **insert\_dft** command is repeated (for example, with a different test methodology), the new design name is *my\_design\_test\_2*.

To determine the current value of this variable, use the **printvar insert\_test\_design\_naming\_style** command. For a list of **insert\_dft** variables and their current values, use **print\_variable\_group insert\_dft**.

---

### SEE ALSO

[insert\\_dft\(2\)](#)

---

## layer\_attributes

Contains attributes related to layer.

---

## DESCRIPTION

Contains attributes related to layer.

You can use **get\_attribute** to determine value of an attribute, and use **report\_attribute** to get a report of all attributes on specified object. Specified with **list\_attribute -class layer -application**, the definition of attributes can be listed.

### Layer Attributes

#### data\_type\_details

Specifies detail information of data types on a layer.

The data type of **data\_type\_details** is string.

This attribute is read-only.

#### data\_types

Specifies data types on a layer.

The data type of **data\_types** is string.

This attribute is read-only.

#### defaultWidth

Specifies the default width of any dimension of an object on a layer.

The data type of **defaultWidth** is float.

This attribute is read-only.

#### fatContactThreshold

Specifies the threshold for using a fat wire contact on a layer instead of the default contact.

The data type of **fatContactThreshold** is float.

This attribute is read-only.

#### fatFatMinSpacing

Specifies the minimum distance required between wires on a layer when the widths of both wires are greater than or equal to **fatWireThreshold**.

The data type of **fatFatMinSpacing** is float.

This attribute is read-only.

#### fatThinMinSpacing

Specifies the minimum distance required between wires on a layer when the width of one of the wires is greater than or equal to **fatWireThreshold**.

The data type of **fatThinMinSpacing** is float.

This attribute is read-only.

#### fatWireThreshold

Specifies the threshold for using the fat wire spacing rule instead of the default spacing rule on a layer.

The data type of **fatWireThreshold** is float.

This attribute is read-only.

#### isDefaultLayer

Specifies the layer used for routing when there are multiple layers with the same **mask\_name** value.

The data type of **isDefaultLayer** is integer.

This attribute is read-only.

#### is\_routing\_layer

Specifies whether layer is a routing layer.

The data type of **is\_routing\_layer** is boolean.

This attribute is read-only.

#### layerNumber

Defines the number that identifies a layer.

The data type of **layerNumber** is integer.

This attribute is read-only.

#### layer\_number

Defines the number that identifies a layer.

The data type of **layer\_number** is integer.

This attribute is read-only.

#### layer\_type

Specifies type of a layer.

The data type of **layer\_type** is string.

This attribute is read-only.

#### mask\_name

Specifies the physical layer associated with the specified layer object.

The data type of **mask\_name** is string.

This attribute is read-only.

#### maxCurrDensity

Specifies the floating-point number representing in amperes per centimeter the maximum current density a layer can carry.

The data type of **maxCurrDensity** is double.

This attribute is read-only.

#### maxStackLevel

Defines the maximum number of vias that can stack at the same point.

The data type of **maxStackLevel** is integer.

This attribute is read-only.

#### minArea

Specifies the minimum area rule of any dimension of an object on a layer.

The data type of **minArea** is float.

This attribute is read-only.

#### minSpacing

Specifies the minimum separation distance between the edges of objects on a layer, if the objects are on different nets.

The data type of **minSpacing** is float.

This attribute is read-only.

#### minWidth

Specifies the minimum width of any dimension of an object on a layer.

The data type of **minWidth** is float.

This attribute is read-only.

#### name

Specifies name of a layer object.

The data type of **name** is string.

This attribute is read-only.

#### object\_class

Specifies object class name of a layer, which is **layer**.

The data type of **object\_class** is string.

This attribute is read-only.

#### pitch

Specifies the predominant separation distance between the centers of objects on a layer.

The data type of **pitch** is float.

This attribute is read-only.

#### preferred\_direction

Specifies the preferred routing direction for a layer.

The data type of **preferred\_direction** is string.

This attribute is read-only.

#### unitMaxCapacitance

Specifies the maximum capacitance of a layer.

The data type of **unitMaxCapacitance** is double.

This attribute is read-only.

**unitMaxHeightFromSub**

Specifies the maximum distance of a layer.

The data type of **unitMaxHeightFromSub** is double.

This attribute is read-only.

**unitMaxResistance**

Specifies the maximum resistance of a layer.

The data type of **unitMaxResistance** is double.

This attribute is read-only.

**unitMaxSideWallCap**

Specifies the maximum sidewall capacitance of a layer.

The data type of **unitMaxSideWallCap** is double.

This attribute is read-only.

**unitMaxThickness**

Specifies the maximum thickness of a layer.

The data type of **unitMaxThickness** is double.

This attribute is read-only.

**unitMinCapacitance**

Specifies the minimum capacitance of a layer.

The data type of **unitMinCapacitance** is double.

This attribute is read-only.

**unitMinHeightFromSub**

Specifies the minimum distance of a layer.

The data type of **unitMinHeightFromSub** is double.

This attribute is read-only.

**unitMinResistance**

Specifies the minimum resistance of a layer.

The data type of **unitMinResistance** is double.

This attribute is read-only.

**unitMinSideWallCap**

Specifies the minimum sidewall capacitance of a layer.

The data type of **unitMinSideWallCap** is double.

This attribute is read-only.

**unitMinThickness**

Specifies the minimum thickness of a layer.

The data type of **unitMinThickness** is double.

This attribute is read-only.

#### unitNomCapacitance

Specifies the nominal capacitance of a layer.

The data type of **unitNomCapacitance** is double.

This attribute is read-only.

#### unitNomHeightFromSub

Specifies the nominal distance of a layer.

The data type of **unitNomHeightFromSub** is double.

This attribute is read-only.

#### unitNomResistance

Specifies the nominal resistance of layer.

The data type of **unitNomResistance** is double.

This attribute is read-only.

#### unitNomSideWallCap

Specifies the nominal sidewall capacitance of a layer.

The data type of **unitNomSideWallCap** is double.

This attribute is read-only.

#### unitNomThickness

Specifies the nominal thickness of a layer.

The data type of **unitNomThickness** is double.

This attribute is read-only.

#### visible

Specifies a layer's visibility.

The data type of **visible** is integer.

This attribute is read-only.

---

## SEE ALSO

`get_attribute(2)`  
`list_attributes(2)`  
`report_attribute(2)`  
`set_attribute(2)`

---

## **lbo\_cells\_in\_regions**

Puts new cells at specific locations within a cluster.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### **DESCRIPTION**

Location based optimization (LBO) puts new cells at specific locations within a cluster. When this variable is set to **true**, LBO converts the specific location into a preferred region for the cell, by putting X\_BOUNDS and Y\_BOUNDS attributes on the cell when it is written to the PDEF file.

The proper setting for this variable depends on the engineering change order (ECO) capabilities of the back-end tools being used. Ideally the back-end tool is able to support putting the new cells exactly where the **reoptimize\_design** command wants them to go. If tools do not support that level of ECO, set this variable to **true** so that the PDEF file will at least contain regions into which the cells can be placed.

To determine the current value of this variable, use the **printvar lbo\_cells\_in\_regions** command. For a list of all **links\_to\_layout** variables and their current values, use **print\_variable\_group links\_to\_layout**.

---

### **SEE ALSO**

---

## level\_shifter\_naming\_prefix

Specifies a prefix for level shifter names.

---

### TYPE

string

---

### DEFAULT

""

---

### GROUP

mv

---

### DESCRIPTION

When the `enable_special_level_shifter_naming` variable is set to `true`, level shifters that are automatically inserted by the `insert_level_shifters`, `compile` and other commands are specially named. The name follows the template `<prefix> + <PD OR Design name> + " _LS" + #`. The `<prefix>` is a user-specified prefix using the `level_shifter_naming_prefix` variable. The `<PD OR Design Name>` is the name of power domain where the level shifter is being added, or the design name if the power domain is not defined

---

### SEE ALSO

`enable_special_level_shifter_naming(3)`

---

## lib\_cell\_using\_delay\_from\_ccs

Controls whether the tool uses information from CCS tables instead of NLDM library timing information for cases with mixed CCS and NLDM libraries.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When this variable is set to **true** and the library contains both CCS timing and NLDM timing, the tool replaces the NLDM library timing with the timing information derived from CCS. When the variable is set to **false** and the library contains both CCS timing and NLDM timing, the tool uses the NLDM library timing from library NLDM data. This variable only works when it is set before library loading.

For the current value of this variable, use the **printvar lib\_cell\_using\_delay\_from\_ccs** command.

---

### SEE ALSO

[lib\\_pin\\_using\\_cap\\_from\\_ccs\(3\)](#)

---

## lib\_pin\_using\_cap\_from\_ccs

Controls whether the tool uses the pin caps derived from CCS in cases with mixed CCS and NLDM libraries.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When this variable is set to **true** and the library contains both CCS timing and NLDM timing, the tool uses the pin caps derived from CCS. When the variable is set to **false** and the library contains both CCS timing and NLDM timing, the tool uses the NLDM library pin cap. This variable only works when it is set before library loading.

For the current value of this variable, use the **printvar lib\_pin\_using\_cap\_from\_ccs** command.

---

### SEE ALSO

[lib\\_cell\\_using\\_delay\\_from\\_ccs\(3\)](#)

---

## lib\_use\_thresholds\_per\_pin

Causes pin-specific trip-point values in the Synopsys library to override library default trip-point values.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

Setting this variable to **false** causes Synopsys Library default trip-point values to override values defined for each library pin in the Synopsys library.

This variable is provided for backward compatibility. This variable allows you to use library defaults for all library pins instead of pin specific trip\_point values.

The following variables are affected:

```
lib_thresholds_per_lib
rc_input_threshold_pct_rise
rc_input_threshold_pct_fall
rc_output_threshold_pct_rise
rc_output_threshold_pct_fall
rc_slew_derate_from_library
rc_slew_lower_threshold_pct_fall
rc_slew_lower_threshold_pct_rise
rc_slew_upper_threshold_pct_fall
rc_slew_upper_threshold_pct_rise
```

To determine the current value of this variable, use the **printvar lib\_use\_thresholds\_per\_pin** command. For a list of all timing variables and their current values, use **print\_variable\_group timing**.

---

### SEE ALSO

```
rc_input_threshold_pct_fall(3)
rc_input_threshold_pct_rise(3)
rc_output_threshold_pct_fall(3)
rc_output_threshold_pct_rise(3)
rc_slew_derate_from_library(3)
```

```
rc_slew_lower_threshold_pct_fall(3)
rc_slew_lower_threshold_pct_rise(3)
rc_slew_upper_threshold_pct_fall(3)
rc_slew_upper_threshold_pct_rise(3)
```

---

## libgen\_max\_differences

Specifies to the **read\_lib** command the maximum number of differences to list between the v3.1 format description of a library cell and its statetable description.

---

### TYPE

integer

---

### DEFAULT

-1 in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Specifies to the **read\_lib** command the maximum number of differences to list between the v3.1 format description of a library cell and its statetable description. The default value of -1 allows all differences to be listed.

For example, if **libgen\_max\_differences** = 5, **read\_lib** lists only up to 5 differences between a library cell's v3.1 format description and its statetable description.

To see the value of this variable, type **printvar libgen\_max\_differences**. For a list of all **io** variables and their values, type **print\_variable\_group io**.

---

### SEE ALSO

**read\_lib(2)**

---

## library\_attributes

Contains attributes placed on libraries.

---

## DESCRIPTION

Contains attributes that can be placed on a library.

To set library attributes, use the **set\_attribute** command. To determine the value of an attribute, use the **get\_attribute** command. To remove attributes, use the **remove\_attribute** command.

For more details on library attributes, see the *Library Compiler Reference Manual*. For information on all attributes, refer to the **attributes** manual page.

### Library Attributes

default\_fanout\_load

Fanout load of input pins in a library.

default\_inout\_pin\_cap

Capacitance of inout pins.

default\_inout\_pin\_fall\_res

Fall resistance of inout pins.

default\_inout\_pin\_rise\_res

Rise resistance of inout pins.

default\_input\_pin\_cap

Capacitance of input pins.

default\_intrinsic\_fall

Intrinsic fall delay of timing arcs.

default\_intrinsic\_rise

Intrinsic rise delay of a timing arc.

default\_max\_fanout

Maximum fanout of pins.

default\_max\_transition

Maximum transition of pins.

default\_min\_porosity

Minimum porosity of designs.

default\_output\_pin\_cap

Capacitance of output pins.

default\_output\_pin\_fall\_res

Fall resistance of output pins.

default\_output\_pin\_rise\_res

Rise resistance of output pins.

default\_slope\_fall

Fall sensitivity factor of a timing arc.

default\_slope\_rise

Rise sensitivity factor of a timing arc.

k\_process\_drive\_fall

Process scale factor applied to the fall resistance of timing arcs.

k\_process\_drive\_rise

Process scale factor applied to the rise resistance of timing arcs.

k\_process\_intrinsic\_fall

Process scale factor applied to the intrinsic fall delay of timing arcs.

k\_process\_intrinsic\_rise

Process scale factor applied to the intrinsic rise delay of timing arcs.

k\_process\_pin\_cap

Process scale factor applied to pin capacitance of timing arcs.

k\_process\_slope\_fall

Process scale factor applied to the fall slope sensitivity of timing arcs.

k\_process\_slope\_rise

Process scale factor applied to the rise slope sensitivity of timing arcs.

k\_process\_wire\_cap

Process scale factor applied to the wire capacitance of timing arcs.

k\_process\_wire\_res

Process scale factor applied to the wire resistance of timing arcs.

k\_temp\_drive\_fall

Scale factor applied to timing arc fall resistance due to temperature variation.

k\_temp\_drive\_rise

Scale factor applied to timing arc rise resistance due to temperature variation.

k\_temp\_intrinsic\_fall

Scale factor applied to the intrinsic fall delay of a timing arc due to temperature variation.

k\_temp\_intrinsic\_rise

Scale factor applied to the intrinsic rise delay of a timing arc due to temperature variation.

**k\_temp\_pin\_cap**

Scale factor applied to pin capacitance due to temperature variation.

**k\_temp\_slope\_fall**

Scale factor applied to timing arc fall slope sensitivity due to temperature variation.

**k\_temp\_slope\_rise**

Scale factor applied to timing arc rise slope sensitivity due to temperature variation.

**k\_temp\_wire\_cap**

Scale factor applied to wire capacitance due to temperature variation.

**k\_temp\_wire\_res**

Scale factor applied to wire resistance due to temperature variation.

**k\_volt\_drive\_fall**

Scale factor applied to timing arc fall resistance due to voltage variation.

**k\_volt\_drive\_rise**

Scale factor applied to timing arc rise resistance due to voltage variation.

**k\_volt\_intrinsic\_fall**

Scale factor applied to the intrinsic fall delay of a timing arc due to voltage variation.

**k\_volt\_intrinsic\_rise**

Scale factor applied to the intrinsic rise delay of a timing arc due to voltage variation.

**k\_volt\_pin\_cap**

Scale factor applied to pin capacitance due to voltage variation.

**k\_volt\_slope\_fall**

Scale factor applied to timing arc fall slope sensitivity due to voltage variation.

**k\_volt\_slope\_rise**

Scale factor applied to timing arc rise slope sensitivity due to voltage variation.

**k\_volt\_wire\_cap**

Scale factor applied to wire capacitance due to voltage variation.

**k\_volt\_wire\_res**

Scale factor applied to wire resistance due to voltage variation.

**nom\_process**

Nominal process value used for library characterization. Fixed at 1.0 for most technology libraries.

**nom\_temperature**

Nominal ambient temperature used for library characterization. Usually 25 degrees Celsius. Multipliers use the nominal value to determine the change in temperature between nominal and operating conditions.

**nom\_voltage**

Nominal source voltage value used in library element characterization. Typically 5 volts for a CMOS library. Multipliers use the nominal value to determine the change in voltage between nominal and operating conditions.

#### no\_sequential\_degenerates

When *true*, disables mapping to degenerated flip-flops or latches (that is, devices that have some input pins connected to 0 or to 1). The default for the attribute is *false\P* or *nonexistence*, implying that degenerate devices will be allowed by default in the library. This attribute may be overridden on a component-by-component basis by using the attribute on library cells.

#### sequential\_bridging

When *true*, enables **Design Compiler** to take a multiplexed flip-flop and bridge (that is, connect) the output to the input to get a desired functionality. The default for the attribute is *false* or nonexistent, implying that bridging will be disabled by default in the library. Bridging is required for mapping in cases where there is no flip-flop with internal feedback in the target library but one is desired in the HDL. This attribute may be overridden on a component-by-component basis by using the attribute on library cells.

NOTE: Setting this attribute to *true* can result in an increase in run times and memory consumption for Design Compiler. The increased run times depend on the number of flip-flops in the target library or libraries which have the attribute set.

---

## SEE ALSO

[get\\_attribute\(2\)](#)  
[remove\\_attribute\(2\)](#)  
[set\\_attribute\(2\)](#)  
[attributes\(3\)](#)

---

## library\_cell\_attributes

Contains attributes that can be placed on a library cell.

---

## DESCRIPTION

Contains attributes that can be placed on a library cell.

To set an attribute, use the command identified in the individual description of that attribute. To determine the value of an attribute, use the **get\_attribute** command. To remove attributes, use the **remove\_attribute** command. If an attribute is "read-only," you cannot set it.

For a more detailed explanation of an attribute, refer to the manual pages of the appropriate **set** command. For information on all attributes, refer to the **attributes** manual page.

### Library Cell Attributes

**dont\_touch**

Identifies library cells to be excluded from optimization. Values are *true* (the default) or *false*. Library cells with the **dont\_touch** attribute set to *true* are not modified or replaced during **compile**. Setting **dont\_touch** on a hierarchical cell sets the attribute on all cells below it. Set with **set\_dont\_touch**.

**dont\_use**

Disables the specified library cells so that they are not added to a design during **compile**. Set with **set\_dont\_use**.

**no\_sequential\_degenerates**

When *true*, disables mapping to versions of this latch or flip flop that have some input pins connected to 0 or to 1. Set with **set\_attribute**. This attribute may also be set on the library itself, and that value will apply as the default for all registers in the library which do not have the attribute set individually.

**preferred**

Specifies the preferred library gate to use during technology translation when there are other gates with the same function in the target library. Set with **set\_prefer**.

**scan**

When *true*, specifies that the instances of the library cell are always replaced by equivalent scan cells during **insert\_dft**. When *false*, instances are not replaced. Set with **set\_scan**.

**sequential\_bridging**

When *true*, enables Design Compiler to take a multiplexed flip-flop and bridge (that is, connect) the output to the input to get a desired functionality. The default is *false*, so this attribute must be set in order to enable the functionality. Bridging is required for mapping in cases where there is no flip-flop with internal feedback in the target library but one is desired in the HDL. Set with **set\_attribute**. This attribute may also be set on the library itself, and that value will apply as the default for all registers in the library which do not have the attribute set individually.

NOTE: Setting this attribute to *true* can result in an increase in run times and memory consumption for Design Compiler. The increased run times depend on the number of flip-flops in the target library or libraries for which this attribute has been set.

## SEE ALSO

`get_attribute(2)`  
`remove_attribute(2)`  
`set_attribute(2)`  
`attributes(3)`

---

## libsetup\_max\_auto\_opcond\_message

Controls the number of inferred operating condition messages issued.

---

### TYPE

int

---

### DEFAULT

10

---

### GROUP

mv

---

### DESCRIPTION

This variable controls the total number of LIBSETUP-751 messages to be reported. By default, the integer variable is set to 10 and only first 10 LIBSETUP-751 messages are reported. The variable only has an effect if the operating conditions for pad/macro/switch cells have been inferred. The variable can be set to any integer number to control the message reporting.

---

### EXAMPLE

```
set libsetup_max_auto_opcond_message 14      # reports 14 LIBSETUP-751 messages
set libsetup_max_auto_opcond_message 0        # doesn't report LIBSETUP-751
set libsetup_max_auto_opcond_message 100       # reports 100 LIBSETUP-751 messages
```

---

### SEE ALSO

LIBSETUP-751(n)

LIBSETUP-754(n)

---

## link\_allow\_design\_mismatch

Allows the tool to modify the netlist to circumvent design mismatches during the link process.

This variable is supported only by DC Explorer.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

true in DC Explorer

---

### DESCRIPTION

This variable allows DC Explorer to modify the netlist to circumvent design mismatches and to successful link the design during the link process. Formal verification is not validated.

This variable is supported only by DC Explorer. It is ignored by the Design Compiler tool and Design Compiler topographical mode.

To determine the current setting of this variable, use the **printvar link\_allow\_design\_mismatch** command. For a list of all system variables and their current settings, use the **print\_variable\_group** system command.

---

### SEE ALSO

[report\\_design\\_mismatch\(2\)](#)

---

## link\_allow\_physical\_variant\_cells

Allows the Design Compiler tool to map physical variant cells to their master cell in the library during linking.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When the **link\_allow\_physical\_variant\_cells** variable is set to true, the Design Compiler tool maps physical variant cells in a netlist or a DEF file to the master cell in the library. During linking, identifies the master library cells of these physical variant cells from the library and maps the physical variant cells to their master library cell.

---

## link\_allow\_pin\_name\_synonym

Allows the tool to link a cell containing pin names that do not match the pin names of the target library cell during the link process.

This variable is supported only in DC Explorer.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

Setting this variable to true allows the tool to link a cell when a pin name does not match the pin name of the target library cell. If the design has an instance of a subdesign with ports a, b, and z, but the link library provides the matching cell that has a target cell with ports a, b, and sum, the link process fails by default. However, when you set this variable to true and use the **set\_pin\_name\_synonym z sum** command to indicate that the z and sum ports are equivalent, the link process succeeds. Note that link\_allow\_design\_mismatch must also be set to true to enable this feature.

This variable is supported only in DC Explorer. It is ignored by Design Compiler and Design Compiler topographical mode.

To determine the current setting of this variable, use the **printvar link\_allow\_pin\_name\_synonym** command. For a list of all system variables and their current values, use **print\_variable\_group system**.

---

### SEE ALSO

[set\\_pin\\_name\\_synonym\(2\)](#)

---

## link\_allow\_upf\_design\_mismatch

Allows the usage of design data with inconsistencies or errors so that an approximate analysis can be completed in the tool.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

true in DC Explorer

---

### GROUP

mv

---

### DESCRIPTION

This variable, when set to **true** (the default), allows the tool to accept design data containing inconsistencies or errors that would otherwise prevent completion of tasks in the tool.

A **true** setting allows inconsistent data in the following ways:

- **mv\_no\_main\_power\_violations** variable: behavior as if set to false (irrespective of actual setting)
- **mv\_use\_std\_cell\_for\_isolation** variable: behavior as if set to true (irrespective of actual setting)
- **link** command allows selection of cells with PVT parameters that fail to meet requirements

When this variable is set to **false**, each individual feature is controlled by the setting of the feature-specific variable, and the **link** command requires PVT parameters to be correct.

---

### SEE ALSO

[mv\\_no\\_main\\_power\\_violations\(3\)](#)  
[mv\\_use\\_std\\_cell\\_for\\_isolation\(3\)](#)



---

## link\_force\_case

Controls the case-sensitive or case-insensitive behavior of the **link** command.

---

### TYPE

string

---

### DEFAULT

check\_reference in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

case\_insensitive in DC Explorer

---

### DESCRIPTION

Controls the case-sensitive or case-insensitive matching policy to be used on HDL identifiers considered during a **link** command. The value of this variable can be set to **check\_reference** (the default), **case\_sensitive**, or **case\_insensitive**.

By default, the reference and the design cells to be linked are checked to ascertain the alphabet-case matching policy of the HDL input format that created that particular cell. Then, the least-sensitive matching rule is applied to determine whether the design cell resolves the reference. For example, a VHDL reference is linked case-insensitively and a Verilog reference is linked case-sensitively, while mixed language linkage candidates match case-insensitively. To override this behavior, you can set the value of the **link\_force\_case** variable to either **case\_sensitive** or **case\_insensitive**.

The appropriate matching policy applies to all the HDL identifiers that must be matched by the link: design template, port, and parameter names. It does not apply to the (canonical forms of) data values in any parameter override, which (for string data) are always case-sensitive. It also does not apply to library and architecture identifiers, which are always case-insensitive. When link candidates are built by elaboration, case-forcing does not change the HDL identifiers of the design or reference cells that are built.

Setting this variable to either the **case\_sensitive** or the **case\_insensitive** value can lead to results which are inconsistent with the default rules, since a forced rule applies throughout the linked hierarchy.

To determine the value of this variable, use the **printvar link\_force\_case** command.

---

### SEE ALSO

[link\(2\)](#)

---

## link\_library

Specifies the list of design files and libraries used during linking.

---

### TYPE

list

---

### DEFAULT

\* your\_library.db

---

### DESCRIPTION

This variable specifies the list of design files and libraries used during linking. The **link** command looks at the files and tries to resolve references in the order of the specified files. A "\*" entry in the value of this variable indicates that the **link** command is to search all the designs loaded in dc\_shell while trying to resolve references. If file names do not include directory names, files are searched for in the directories in **search\_path**. The default is {"\* your\_library.db}. Change *your\_library.db* to reflect your library name.

To determine the current value of this variable, use the **printvar link\_library** command. For a list of all system variables and their current values, use the **print\_variable\_group system** command.

---

### SEE ALSO

[link\(2\)](#)

---

## link\_portname\_allow\_period\_to\_match\_underscore

Enables the linker to allow a period (.) as an alternative to an underscore (\_) when doing port name matching.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

During linking, if named port mapping is used in the cell instance statement, the linker resolves port connections based on the port names. If the linker is unable to find a matching port name, and the **link\_portname\_allow\_period\_to\_match\_underscore** variable is set to **true**, the linker replaces, for comparison purposes, the "." characters in the port name from the cell instance statement with the "\_" character to see if there is a match. This variable has no effect when positional port mapping is used instead.

The following Verilog example shows the effect of this variable on the **link** command:

```
module top ( B , A, Y);
  input A,B;
  output Y;
  wire Y;
  mid mid1 (.B.X (B), .A(A), .Y(Y));
endmodule

module mid (B_X, A, Y);
  input B_X;
  input A;
  output Y;
  assign Y = B_X & A;
endmodule
```

The following scenarios assume that you have already read in the Verilog file and are running the **link** command.

Scenario 1:

**link\_portname\_allow\_period\_to\_match\_underscore** set to **false**

The linker attempts to resolve the port connections but is unable to find a port with the name "B.X" in the port list of the mid design. This causes the linker to issue a LINK-1 error.

Error: Can't find inout port 'B.X' on reference to 'mid' in 'top'. (LINK-1)

This is expected because the instantiation of mid1 uses B.X as the port name but the actual port name is B\_X.

Scenario 2:

**link\_portname\_allow\_period\_to\_match\_underscore** set to **true**

The linker first attempts to resolve the port connections but fails to resolve the "B.X" port name as in the previous scenario. However, since the **link\_portname\_allow\_period\_to\_match\_underscore** variable is set to **true**, the linker takes "B.X" and replaces all '.' characters with the '\_' character. For this comparison, the linker will compare "B\_X" against "B\_X". In this case, the port names match and the design links successfully.

---

## SEE ALSO

[link\(2\)](#)

---

## link\_portname\_allow\_square\_bracket\_to\_match\_underscore

Enables the linker to allow a square bracket([]) as an alternative to an underscore (\_) when doing port name matching.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

During linking, the linker resolves port connections based on port names when named port mapping is used in cell instantiation. In the default mode, the linker looks for an exact match of the port names. Setting the **link\_portname\_allow\_square\_bracket\_to\_match\_underscore** variable to **true**, allows the linker to also match the "[]" characters with the "\_" character. This variable has no effect when positional port mapping is used. This variable should be used only for matching modport arrays.

The following SystemVerilog example shows the effect of this variable on the **link** command. **Note** - this example requires another related variable **link\_portname\_allow\_period\_to\_match\_underscore** to also be set to true. This is because this example contains both "[]" and "." characters in the original portname.

```
interface AA;
    wire valid;
    wire ready;

    modport slave (input valid, output ready);
    modport master (output valid, input ready);

    endinterface

    module subblk (
        AA.master aa_master[0:3],
        AA.slave aa_slave[0:3]
    );
        // subblk logic
        assign aa_master[0].valid=aa_slave[0].valid & aa_slave[1].valid ;
        assign aa_master[1].valid=aa_slave[1].valid & aa_slave[2].valid ;
        assign aa_master[2].valid=aa_slave[2].valid & aa_slave[3].valid ;
        assign aa_master[3].valid=aa_slave[3].valid & aa_slave[0].valid ;
    endmodule

```

```
module top ( input clk_a, input reasrt_n);
  AA aa_vec[0:3] ();
  subblk U_subblk (.aa_master(aa_vec.master), .aa_slave(aa_vec.slave));
endmodule
```

The following scenarios assume that you have already read in the SystemVerilog file and are running the **link** command.

Scenario 1:

**link\_portname\_allow\_square\_bracket\_to\_match\_underscore** set to **false**  
**link\_portname\_allow\_period\_to\_match\_underscore** set to **false**

The linker attempts to resolve the port connections but is unable to find a port with the name "aa\_master[0].valid" in the port list of the subblk design. This causes the linker to issue a LINK-1 error.

Error: Can't find inout port 'aa\_master[0].valid' on reference to 'subblk' in 'top'. (LINK-1)

This is expected because the instantiation of 'subblk' uses 'aa\_master[0].valid' as the port name but the actual port name is 'aa\_master\_0\_\_valid'.

Scenario 2:

**link\_portname\_allow\_square\_bracket\_to\_match\_underscore** set to **true**  
**link\_portname\_allow\_period\_to\_match\_underscore** set to **true**

The linker now matches all '.', and '['] characters with the '\_' character, and "aa\_master[0].valid" matches "aa\_master\_0\_\_valid", and the design links successfully.

---

## SEE ALSO

[link\\_portname\\_allow\\_period\\_to\\_match\\_underscore\(3\)](#)  
[link\(2\)](#)

---

## link\_preserve\_dangling\_pins

Connects dangling pins to dummy cells during optimization to prevent the pin logic from being removed.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

false in DC Explorer

---

### DESCRIPTION

Setting this variable to true allows the tool to connect dangling pins to dummy cells during optimization so that the pin logic does not get removed. This prevents constant propagation because of the removal of the pin logic.

---

### SEE ALSO

[link\\_allow\\_design\\_mismatch\(3\)](#)

## logic\_level\_report\_group\_format

Controls the format of the columns to be displayed during the Logic level path report section of the **report\_logic\_levels** command.

### TYPE

string

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

%slack %ll %lthresh %startpoint %endpoint in DC Explorer

### DESCRIPTION

This variable controls the format of the columns to be displayed during the **report\_logic\_levels** command.

The default specification is shown in the DEFAULT section above. The headings and order of the columns displayed correspond to the keywords specified in the syntax. For example, "%slack" specifies the WNS column, "%ll" the LOGIC LEVELS column, and so on.

**Table 1**  
**Default Output Format**

| LOGIC   | WNS | LEVELS | THRESHOLD                  | START POINT               | END POINT |
|---------|-----|--------|----------------------------|---------------------------|-----------|
| -2.3006 | 13  | 5      | REG_BLK/DATA_OUT_reg[0]/CK | UPC_BLK/DATA_OUT_reg[7]/D |           |
| -2.2972 | 11  | 5      | REG_BLK/DATA_OUT_reg[0]/CK | UPC_BLK/DATA_OUT_reg[3]/D |           |
| -2.2899 | 10  | 5      | REG_BLK/DATA_OUT_reg[0]/CK | UPC_BLK/DATA_OUT_reg[3]/D |           |
| -2.2891 | 11  | 5      | REG_BLK/DATA_OUT_reg[0]/CK | UPC_BLK/DATA_OUT_reg[9]/D |           |
| -2.2879 | 2   | 5      | REG_BLK/DATA_OUT_reg[0]/CK | UPC_BLK/DATA_OUT_reg[5]/D |           |

There are 10 possible columns that can be displayed; only 5 are displayed in the default format. You can create a customized output format by specifying any number of the available columns.

Following are the available columns and their header values.

|              |                  |
|--------------|------------------|
| %slack       | WNS              |
| %ll_buf_inv  | ALL LOGIC LEVELS |
| %ll          | LOGIC LEVELS     |
| %lthresh     | THRESHOLD        |
| %startpoint  | START POINT      |
| %endpoint    | END POINT        |
| %clockcycles | CLOCK CYCLES     |

|           |             |
|-----------|-------------|
| %startclk | START CLOCK |
| %endclk   | END CLOCK   |
| %infeas   | INFEASIBLE  |

---

## EXAMPLES

The following example sets the group format to report all the columns

```
prompt> set logic_level_report_group_format "%slack %ll_buf_inv %ll \
%llthreshold %startpoint %endpoint %clockcycles %startclk %endclk %infeas"
```

---

## SEE ALSO

```
set_analyze_rtl_logic_level_threshold(2)
report_logic_levels(2)
logic_level_report_summary_format(3)
```

## **logic\_level\_report\_summary\_format**

Controls the format of the columns to be displayed during the Summary section of the **report\_logic\_levels** command.

### **TYPE**

string

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

%group %period %wns %num\_paths %max\_level in DC Explorer

### **DESCRIPTION**

This variable controls the format of the columns to be displayed during the **report\_logic\_levels** command.

The default specification is shown in the DEFAULT section above. The headings and order of the columns displayed correspond to the keywords specified in the syntax. For example, "%group" specifies the GROUP column, "%period" the REQUIRED PERIOD column, and so on.

**Table 1**  
**Default Output Format**

| GROUP           | REQUIRED PERIOD | NUM OF WNS | MAX PATHS | LEVEL |
|-----------------|-----------------|------------|-----------|-------|
| All Path Groups | n/a             | n/a        | 2310      | 13    |
| CLOCK           | 0.0100          | -2.3289    | 1600      | 13    |
| custom_group1   | 0.0100          | -2.3174    | 166       | 12    |
| custom_group2   | 0.0100          | -2.3006    | 544       | 13    |

There are 8 possible columns that can be displayed; only 5 are displayed in the default format. You can create a customized output format by specifying any number of the available columns.

Following are the available columns and their header values.

|            |                    |
|------------|--------------------|
| %wns       | WNS                |
| %group     | GROUP              |
| %period    | REQUIRED PERIOD    |
| %std_dev   | STANDARD DEVIATION |
| %num_paths | NUM OF PATHS       |
| %max_level | MAX LEVEL          |
| %min_level | MIN LEVEL          |

```
%avg_level    AVERAGE LEVEL
```

---

## EXAMPLES

The following example sets the summary format to report all the columns

```
prompt> set logic_level_report_summary_format "%wns %group %period %std_dev \
%num_paths %max_level %min_level %avg_level"
```

---

## SEE ALSO

```
set_analyze_rtl_logic_level_threshold(2)
report_logic_levels(2)
logic_level_report_group_format(3)
```

---

## ltl\_obstruction\_type

Controls the routing blockage type for the named obstructions, without the route type being specified.

---

### TYPE

Boolean

---

### DEFAULT

placement\_only in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable controls the routing blockage type for the named obstructions, without the route type being specified. When the setting is **placement\_only** (the default), the obstructions are treated as placement obstructions only and routing wires can still go through. When the setting is **routing\_none**, the obstructions are treated as routing blockages and no routing wires are allowed.

To determine the current value of this variable, use the **printvar ltl\_obstruction\_type** command. For a list of all **links\_to\_layout** variables and their current values, use **print\_variable\_group links\_to\_layout**.

---

### SEE ALSO

[lbo\\_cells\\_in\\_regions\(3\)](#)

---

## **magnet\_placement\_disable\_overlap**

Controls whether the **magnet\_placement** command can move pre-placed cells during magnet placement.

---

### **TYPE**

Boolean

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXT non-topographical mode

false in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

By default, the **magnet\_placement** command moves the available pre-placed cells in the chip area during magnet placement.

If the **magnet\_placement\_disable\_overlap** variable is set to true, the location of pre-placed cells is kept. The **magnet\_placement** command looks for other legal locations to place magnet objects. If no legal location is found, the magnet objects are not pulled closer to the specified magnet.

---

### **SEE ALSO**

[get\\_magnet\\_cells\(2\)](#)  
[magnet\\_placement\(2\)](#)

---

## **magnet\_placement\_fanout\_limit**

Sets the threshold of the high-fanout nets during the **magnet\_placement** command.

---

### **TYPE**

integer

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXTnon-topographical mode

1000 in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

The **magnet\_placement\_fanout\_limit** variable controls whether the nets with high fanout are pulled during magnet placement. If the net has more fanouts than the specified threshold value, the cells on the net are not pulled.

---

### **SEE ALSO**

[get\\_magnet\\_cells\(2\)](#)  
[magnet\\_placement\(2\)](#)

---

## magnet\_placement\_stop\_after\_seq\_cell

Controls whether sequential cells are pulled towards a specified magnet during magnet placement.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXT non-topographical mode

false in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

This variable controls whether sequential cells are pulled towards a specified magnet during magnet placement.

When **false** (the default), sequential cells are not pulled towards a specified magnet when you run the **magnet\_placement** command with the **-stop\_by\_sequential\_cells** option.

When **true**, sequential cells are pulled towards a specified magnet when you run the **magnet\_placement** command with the **-stop\_by\_sequential\_cells** option.

By default, the magnet placement operation terminates before sequential cells when you run the **magnet\_placement** command with the **-stop\_by\_sequential\_cells** option.

---

### SEE ALSO

`get_magnet_cells(2)`  
`magnet_placement(2)`

---

## mcmm\_high\_capacity\_effort\_level

Controls the behavior of multicorner-multimode (MCMM) scenario reduction.

---

### TYPE

Float. Valid range is between 0 and 10.

---

### DEFAULT

0 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### GROUP

MCMM

---

### DESCRIPTION

This variable controls how aggressively the multicorner-multimode scenario reduction feature reduces the number of dominant scenarios.

By default, any scenario with a violation that is worst across all scenarios is included in the dominant set of scenarios. As you increase the value of this variable, scenario reduction adjusts its criteria for comparing the slack of a violating object across different scenarios. This allows for further reduction of the dominant scenario set, but implies that a few violations will not be fixed during optimization.

If you set this variable to a value smaller than 0, scenario reduction is performed using an effort level of 0. If you set this variable to a value larger than 10, scenario reduction is performed using an effort level of 10.

See the man page for the **get\_dominant\_scenarios** command for more information about scenario reduction.

---

### SEE ALSO

[all\\_active\\_scenarios\(2\)](#)  
[all\\_scenarios\(2\)](#)  
[set\\_active\\_scenarios\(2\)](#)



---

## **mux\_auto\_inferring\_effort**

Specifies the MUX inferring effort level.

---

### **TYPE**

integer

---

### **DEFAULT**

2 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### **DESCRIPTION**

The **mux\_auto\_inferring\_effort** variable controls the MUX inferring effort of Design Compiler FPGA. Valid values are **0** through **6**. The default value is **2**. The larger the integer value, the more MUX is inferred.

---

## **mv\_align\_library\_pg\_pins**

Set this variable to get a consistent ordering of power pins across multicorner-multimode libraries.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true

---

### **GROUP**

none

---

### **DESCRIPTION**

When this variable is set to true, all libraries across multicorner-multimode will have a consistent ordering of power pin.

---

### **SEE ALSO**

---

## **mv\_allow\_force\_ls\_with\_iso\_violations**

Allows the insertion of level-shifters specified by means of a **set\_level\_shifter -force\_shift** strategy, despite an Isolation violation.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true

---

### **DESCRIPTION**

This variable controls the insertion of level-shifters specified by **set\_level\_shifter -force\_shift** strategies on paths with Isolation violation. This behavior is true by default.

To prevent the tool from inserting **-force\_shift** level-shifters on nets with isolation violation, set this variable to **false**.

---

### **SEE ALSO**

`set_level_shifter(2)`  
`insert_mv_cells(2)`

---

## **mv\_allow\_ls\_on\_leaf\_pin\_boundary**

Allows level-shifter insertion on leaf pin (such as macro cell pin) boundaries.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

mv

---

### **DESCRIPTION**

This variable controls whether or not to allow level-shifter insertion on leaf pin boundaries that are not power domain boundaries. For example, When a macro cell is operating at a voltage different from its surrounding logic, and you want level shifters to be inserted at the interface, the recommended flow is to define a power domain around the macro cell by specifying the macro cell as the root cell of a power domain.

If you do not define the macro cell as the root cell, level shifters are not inserted at the interface, because the interface is not a power domain boundary. By default, level shifters are only inserted at power domain boundaries.

If you are unable to define a power domain around the macro cell, but still require level shifters to be inserted, or if you need level shifters at the interface of any kind of leaf cell, use this variable to enable the non-default behavior.

---

### **SEE ALSO**

compile\_ultra(2)

---

## **mv\_allow\_ls\_per\_macro\_fanout**

Set this variable to insert level shifter on each macro fanout load pin on a level shifter violating path.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

none

---

### **DESCRIPTION**

When this variable is set to true, each macro fanout load pin will get level shifter, even when macro pins have same related supply. DC always try to insert minimum number of level shifters on a violating path. So a path ending with multiple macro loads will get single level shifter if all have same related supply. But with this variable set to true each load will get one level shifter.

---

### **SEE ALSO**

---

## **mv\_allow\_pg\_pin\_reconnection**

Allows command connect\_supply\_net to reconnect pg pins.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

mv

---

### **DESCRIPTION**

This variable controls whether or not to allow reconnection on PG pins. By default, the connect\_supply\_net command errors out when connecting a supply net to a PG pin, which already has a supply net connection.

By setting this variable to true, the connect\_supply\_net command reconnects the new supply net to the PG pin and the previous connection is discarded.

---

### **SEE ALSO**

connect\_supply\_net(2)

---

## **mv\_allow\_upf\_cells\_without\_upf**

Enable the processing of pre-instantiated isolation cells without UPF context.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

mv

---

### **DESCRIPTION**

When this variable is set to true, it allows compilation of designs which have pre-instantiated PM cells.

Currently, this kind of flow is supported only if there isn't any UPF command nor context, and only for pre-instantiated isolation cells.

**mv\_allow\_upf\_cells\_without\_upf** cannot be set to true if there are power domains defined in any design, and consequently no power domain can be created while this variable is set to true.

---

### **SEE ALSO**

---

## **mv\_allow\_va\_beyond\_core\_area**

Allows a voltage areas to be created outside of the core area.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

mv

---

### **DESCRIPTION**

This variable, when set to **true**, allows voltage areas to be created even when the specified voltage area is not fully enclosed inside core area. The default is **false**, which requires any new voltage areas to be created inside the core area.

---

### **SEE ALSO**

[create\\_voltage\\_area\(2\)](#)

---

## **mv\_disable\_voltage\_area\_aware\_detour\_routing**

This variable determines whether virtual routes used in analysis and optimization need to consider voltage areas as blockages. By default, a net from one voltage area (or the default voltage area) needs to detour around other voltage areas. Set this variable to **true** to ignore the presence of voltage areas.

---

### **TYPE**

Boolean

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **SEE ALSO**

---

## **mv\_input\_enforce\_simple\_names**

Enforces the use of simple names for restricted commands as per the IEEE 1801 (UPF) standard.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true

---

### **GROUP**

mv

---

### **DESCRIPTION**

This variable controls the use of hierarchical names for the arguments of certain restricted commands that require simple names as per the IEEE 1801 (UPF) standard.

The default value of this variable is true. So, by default, the tool accepts only simple names and errors out when you use hierarchical names for the arguments of certain restricted commands. This variable is honored when you specify the UPF input in ASCII and .ddc file formats.

---

### **SEE ALSO**

[mv\\_output\\_enforce\\_simple\\_names\(3\)](#)

---

## **mv\_insert\_level\_shifters\_on\_ideal\_nets**

Directs automatic level-shifter insertion to insert level shifters on ideal nets.

---

### **TYPE**

string

---

### **DEFAULT**

""

---

### **GROUP**

none

---

### **DESCRIPTION**

When this variable is set to "all", automatic level-shifter insertion inserts level shifters on all ideal nets that need level shifters.

By default, automatic level-shifter insertion does not insert level shifters on ideal nets.

Note that if a net is also a clock net, automatic level-shifter insertion does not insert any level shifter on it, unless the variable **auto\_insert\_level\_shifters\_on\_clocks** is set to "all" or contains the net name.

---

### **SEE ALSO**

[auto\\_insert\\_level\\_shifters\(3\)](#)  
[auto\\_insert\\_level\\_shifters\\_on\\_clocks\(3\)](#)  
[create\\_clock\(2\)](#)  
[set\\_ideal\\_network\(2\)](#)

---

## **mv\_make\_primary\_supply\_available\_for\_always\_on**

Allows the primary supply of a power domain to be used for buffering always-on feedthrough nets passing through the domain.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true

---

### **GROUP**

mv

---

### **DESCRIPTION**

This variable determines whether always-on synthesis can use the primary supplies of a power domain for buffering feedthrough nets that pass through the domain.

By default, the variable is set to **true**, which allows the primary supplies of a power domain to be used for buffering always-on feedthrough nets, as long as doing so does not introduce electrical violations. Buffers ordinarily used in the power domain are used as much as possible to get the best possible QoR.

If the variable is set to **false**, feedthrough nets are marked as always-on nets with the related supply from driver or loads, requiring that any buffers used on the feedthrough net be compatible with the driver or load domains. This option is provided mainly for backward compatibility with previous releases of the tool, which always had this requirement.

---

### **SEE ALSO**

[get\\_always\\_on\\_logic\(2\)](#)  
[analyze\\_mv\\_design\(2\)](#)

---

## **mv\_mtcmos\_detour\_obstruction**

Allows the connection of power switch cells to bypass obstructions.

---

### **TYPE**

Boolean

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **GROUP**

mv

---

### **DESCRIPTION**

This variable controls whether or not to detour obstructions such as blockages and macro cells when connecting power switch cells.  
This variable setting is applicable only when you use the **connect\_power\_switch** command with the **-mode fishbone** option.

---

### **SEE ALSO**

---

## **mv\_no\_always\_on\_buffer\_for\_redundant\_isolation**

Allows normal buffers to be used at nets driving the data input of redundant isolation cells.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

mv

---

### **DESCRIPTION**

This variable controls whether or not always-on buffers are used on the nets driving the data-input pins of redundant isolation cells. If the variable is set to **true**, always-on buffer or inverter cells are avoided on these nets in favor of regular buffer or inverter cells supplied by the local power of the net's power domain. By default, any necessary buffering is done using the global driver supply of the net.

---

### **SEE ALSO**

`set_isolation(2)`  
`set_isolation_control(2)`

---

## **mv\_no\_cells\_at\_default\_va**

Controls whether the tool can place new buffers at the default voltage area.

---

### **TYPE**

Boolean

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

This variable, when set to **false** (the default), allows the tool to place new buffers at the default voltage area.

When this variable is set to **true**, the buffers created during optimization are not allowed to be placed at the default voltage area.

Set this variable to **true** for a physically abutted design where there is no space in the default voltage area, or in other situations to prevent the tool from inserting new buffers at the default voltage area.

This variable is honored by the **place\_opt**, **clock\_opt**, and **route\_opt** commands.

---

### **SEE ALSO**

---

## **mv\_no\_main\_power\_violations**

Selects Standard Cell Main Rail (SCMR) as the main power supply for level shifters.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

false in DC Explorer

---

### **GROUP**

mv

---

### **DESCRIPTION**

This variable controls whether or not level shifters use SCMR as their main power supply. By default, level shifters must get their main power supply from SCMR.

To allow the tool to select other power sources as the main power supply for level shifters, set this variable to **false**.

---

### **SEE ALSO**

[check\\_mv\\_design\(2\)](#)  
[compile\(2\)](#)  
[insert\\_mv\\_cells\(2\)](#)

---

## **mv\_output\_enforce\_simple\_names**

Enforces the use of simple names for restricted commands as per the IEEE 1801 (UPF) standard.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true

---

### **GROUP**

mv

---

### **DESCRIPTION**

This variable controls the printing of hierarchical names for the arguments of certain restricted commands in the UPF file or on the standard output device. The IEEE 1801 standard requires that the arguments of these commands accept only simple names.

The default value of this variable is true. So, by default, these restricted commands print only simple names for the arguments in the UPF file or on the standard output. The tool inserts the **set\_scope** command appropriately to set the current scope at the proper hierarchy. This ensures that the use of a simple name is sufficient. After printing, the original scope is returned.

---

### **SEE ALSO**

[mv\\_input\\_enforce\\_simple\\_names\(3\)](#)

---

## **mv\_output\_upf\_line\_indent**

Sets the number of indentation spaces inserted at the beginning of each line when **save\_upf** splits long commands onto multiple lines.

---

### **TYPE**

integer

---

### **DEFAULT**

2

---

### **DESCRIPTION**

When line splitting for the **save\_upf** command is enabled, this variable specifies the number of spaces added to the beginning of each line written, except for the first line of each command (which is not indented).

Line splitting for the **save\_upf** command is controlled by the **mv\_output\_upf\_line\_width** variable.

When line splitting for the **save\_upf** command is disabled, the **mv\_output\_upf\_line\_indent** variable has no effect.

---

### **SEE ALSO**

`save_upf(2)`  
`mv_output_upf_line_width(3)`

---

## **mv\_output\_upf\_line\_width**

Specifies whether the **save\_upf** command writes out long commands as multiple lines, and if so, the threshold for splitting lines.

---

### **TYPE**

Integer

---

### **DEFAULT**

0

---

### **DESCRIPTION**

When this variable is set to 0, line splitting for **save\_upf** is turned off. The command writes out each UPF command as a single line, regardless of its length.

If this variable is set to a positive value, every command that is longer than that threshold is written out in multiple lines, each line containing no more than the specified number of characters, and linked by the backslash character at the end of each continuing line. You cannot set this variable to a negative number.

The second and subsequent lines of a UPF command are indented (offset to the right) by the number of spaces determined by the **mv\_output\_upf\_line\_indent** variable.

---

### **SEE ALSO**

`save_upf(2)`  
`mv_output_upf_line_indent(3)`

---

## **mv\_skip\_opcond\_checking\_for\_unloaded\_level\_shifter**

Skips operating condition checking for level-shifter cells with unconnected output pins.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

mv

---

### **DESCRIPTION**

This variable controls the checking of operating condition on level-shifter cells with unconnected output pins.

By default, operating condition checking is performed on all level-shifter cells in the design.

For the tool to skip operating condition checking for level-shifter cells with unconnected output pins, set this variable to **true**.

---

### **SEE ALSO**

`check_mv_design(2)`  
`compile(2)`  
`insert_mv_cells(2)`  
`set_opcond_inference(2)`

---

## **mv\_upf\_enable\_forward\_bias\_check**

Controls whether or not implementation of designs using well bias will allow forward well bias

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

mv

---

### **DESCRIPTION**

When the variable is set to true the tool will test for voltage differences between power/ground supplies and its related well bias supply to detect forward well bias occurrences. In addition, the tool will try to avoid such occurrences by making use of well bias insulated cells during cell insertion and mapping.

---

### **SEE ALSO**

`check_mv_design(2)`  
`mv_upf_enable_forward_reverse_bias_check(3)`  
`mv_upf_enable_reverse_bias_check(3)`

---

## **mv\_upf\_enable\_forward\_reverse\_bias\_check**

Controls whether or not implementation of designs using well bias will allow forward and reverse well bias

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

mv

---

### **DESCRIPTION**

When this variable is set to true the tool will test for voltage differences between power/ground supplies and its related well bias supply to detect forward or reverse well bias occurrences. In addition, the tool will try to avoid such occurrences by making use of well bias insulated cells during cell insertion and mapping.

---

### **SEE ALSO**

[check\\_mv\\_design\(2\)](#)  
[mv\\_upf\\_enable\\_forward\\_bias\\_check\(3\)](#)  
[mv\\_upf\\_enable\\_reverse\\_bias\\_check\(3\)](#)

---

## **mv\_upf\_enable\_reverse\_bias\_check**

Controls whether or not implementation of designs using well bias will allow reverse well bias

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

mv

---

### **DESCRIPTION**

When the variable is set to true the tool will test for voltage differences between power/ground supplies and its related well bias supply to detect reverse well bias occurrences. In addition, the tool will try to avoid such occurrences by making use of well bias insulated cells during cell insertion and mapping.

---

### **SEE ALSO**

`check_mv_design(2)`  
`mv_upf_enable_forward_reverse_bias_check(3)`  
`mv_upf_enable_forward_bias_check(3)`

---

## mv\_upf\_tracking

Controls whether the UPF tracking feature is enabled in the current session.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable controls whether the UPF tracking feature is enabled in the current session. The default value of this variable is **true**.

When this variable is set to **true** (the default), the user-specified UPF commands are tracked to ensure that their original order is preserved. Also, the UPF' file written by the tool contains two sections. The first section contains the user-specified commands and the second section contains the tool-generated commands. The beginning of the tool-generated section is marked by the following variable setting:

```
set derived_upf true
```

Similarly the end of the tool-generated section is marked by the following variable setting:

```
set derived_upf false
```

To ensure that user-specified UPF content is preserved, this variable has the following usage restrictions:

1. Changing the value of this variable from **true** to **false** is allowed. However, when the variable is changed from **true** to **false**, the variable is marked read-only. This is to ensure that the variable cannot be changed to **true** again.
2. Changing the value of this variable from **false** to **true** is not allowed when the design has UPF constraints.

---

## **mv\_use\_std\_cell\_for\_isolation**

Allows the tool to insert standard cells as UPF isolation cells.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

true in DC Explorer

---

### **GROUP**

mv

---

### **DESCRIPTION**

This variable determines whether standard cells can be used as isolation cells. When the variable is set to **false** (the default), standard cells are not used as isolation cells.

When the variable is set to **true**, a latch or a two-input NAND, AND, OR, or NOR gate can be used as an isolation cell if the **ok\_for\_isolation lib\_cell** attribute is set to **true** for the cell, and the **isolation\_cell\_enable\_pin lib\_pin** attribute is set to **true** on the enable pin. Based on the isolation sense and clamp value of the isolation strategy, the tool selects an appropriate standard cell for use as an isolation cell and connects it to the isolation supply.

---

### **SEE ALSO**

`set_isolation(2)`  
`set_isolation_control(2)`

---

## **mw\_cell\_name**

Contains the Milkyway design cell name.

---

### **TYPE**

string

---

### **DEFAULT**

""

---

### **DESCRIPTION**

This variable contains the Milkyway design cell name. By default, the string is empty. If given, **read\_mdb** reads in the cell specified by this variable, or **read\_mdb** modifies this variable to indicate the cell, view, and version of the MDB cell read in. The **write\_mdb** command searches for this variable when writing data to an MDB cell. If this variable is set, it writes to the cell specified by this variable, or it writes to a cell using the current design name.

---

### **SEE ALSO**

---

## **mw\_design\_library**

Contains the Milkyway design library.

---

### **TYPE**

string

---

### **DEFAULT**

""

---

### **DESCRIPTION**

This variable contains the Milkyway design libraries. The default is the empty string. When this variable is set, the Milkyway design is stored in the directory specified by the variable. If this variable is set, it will be used by the **read\_milkyway**, **write\_milkyway** and **create\_mw\_design** commands.

This variable needs to be set for a smooth data transfer to Milkyway.

---

### **SEE ALSO**

[write\\_milkyway\(2\)](#)

---

## **mw\_disable\_escape\_char**

Disables the escape characters for hierarchy delimiters.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true

---

### **DESCRIPTION**

This variable controls the behavior of escape characters for hierarchies. This variable is used only by the **read\_mdb** and **write\_mdb** commands.

By default, the tool always escapes the hierarchy delimiters if they are part of names.

When set to **false**, it enables escape characters for hierarchies, similar to setting "No Backslash Insertion to avoid Hier Name Collisions" in Astro.

Make sure that the design does not have name collisions.

---

### **SEE ALSO**

---

## **mw\_hdl\_bus\_dir\_for\_undef\_cell**

Specifies how to determine the bus direction for an undefined cell.

---

### **TYPE**

integer

---

### **DEFAULT**

0

---

### **DESCRIPTION**

If any port of any undefined cell is a bus, verilog2cel Verilog reader creates a bus port for the undefined cell and instantiates the cell. This variable specifies the direction of the bus.

For example, assume an undefined cell is instantiated similar to the following:

```
sub si (.port(net[x:y]),...);
```

The number of bus bits =  $r = |x-y|+1$  defines the bus origin according to the value given:

0 (From Connection)  
x > y type [r:0] port  
x < y type [0:r] port

1 (Descending)

type [r:0] port

2 (Ascending) type [0:r] port

To determine the current value of this variable, use the **printvar variable\_name\_filler** command. For a list of all HDL variables and their current values, use **print\_variable\_group hdl**.

---

### **SEE ALSO**

[enable\\_cell\\_based\\_verilog\\_reader\(3\)](#)

---

## **mw\_hdl\_expand\_cell\_with\_no\_instance**

Determines whether or not to expand netlist cells without instances.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

This variable determines whether or not the verilog2cel Verilog reader expands netlist cells that do not contain physical descriptions. By default, no expansion occurs when you have netlist instances with no physical description. Set this variable to **true** if you have netlist instances containing only nets.

To determine the current value of this variable, use the **printvar mw\_hdl\_expand\_cell\_with\_no\_instance** command. For a list of all HDL variables and their current values, use **print\_variable\_group hdl**.

---

### **SEE ALSO**

[enable\\_cell\\_based\\_verilog\\_reader\(3\)](#)

---

## **mw\_reference\_library**

Contains the Milkyway reference libraries.

---

### **TYPE**

list

---

### **DEFAULT**

""

---

### **DESCRIPTION**

This variable contains the Milkyway reference libraries. The default is the empty string. By setting this variable, the search\_path and the physical\_library will be enhanced to use the Milkyway libraries.

---

### **SEE ALSO**

[create\\_mw\\_lib\(2\)](#)  
[open\\_mw\\_lib\(2\)](#)

---

## **mw\_site\_name\_mapping**

Specifies pairs of site names that synchronize a floorplan's site name with a physical library's site name.

---

### **TYPE**

string

---

### **DEFAULT**

""

---

### **GROUP**

physopt

---

### **DESCRIPTION**

This variable specifies pairs of site names that synchronize a floorplan's site name with a physical library's site name. When you use this variable, the floorplan site name is mapped to the physical library site name during library loading. You must set the variable before library loading.

The syntax for the variable is as follows:

```
set mw_site_name_mapping
{ {floorplan_site_name1 mw_reference_lib_site_name}
  {floorplan_site_name2 mw_reference_lib_site_name} }
```

You must use curly braces in the syntax in IC Compiler; therefore, you should also use curly braces in Design Compiler for compatibility between the tools.

To determine the current value of this variable, use the **printvar mw\_site\_name\_mapping** command.

---

### **EXAMPLE**

The following example shows three site names in the floorplan file remapped to unit in the Milkyway reference library. You must specify the exact names in the correct case.

```
prompt> set mw_site_mapping { {CORE unit} {core unit} {core2 unit} }
```

---

## SEE ALSO

---

## ndm\_load\_mol\_routing\_layers

Enables loading the geometries for metal0 and via0 layers

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

When variable **ndm\_load\_mol\_routing\_layers** is set to **true** before loading physical libraries, the tool loads the pin and obstruction geometries for metal0 and via0 layers.

This feature is supported in Design Compiler NXT topographical NDM mode.

---

### EXAMPLES

The following example shows how to enable and disable loading of geometries at metal0/via0 layers:

```
prompt> set ndm_load_mol_routing_layers true
prompt> set ndm_load_mol_routing_layers false
```

---

### SEE ALSO

[shell\\_is\\_in\\_ndm\\_mode\(2\)](#)

---

## net\_attributes

Contains attributes that can be placed on a net.

---

## DESCRIPTION

Contains attributes that can be placed on a net.

To set an attribute, use the command identified in the individual description of that attribute. If an attribute is "read-only," the user cannot set it.

To determine the value of an attribute, use the **get\_attribute** command. To remove attributes, use the **remove\_attribute** command.

For a more detailed explanation of an attribute, refer to the manual pages of the appropriate **set** command. For information on all attributes, refer to the **attributes** manual page.

### Net Attributes

**ba\_net\_resistance**

A floating point number that specifies the back-annotated net resistance on a net. Set with **set\_resistance**.

**bus\_name**

If the net is bussed, returns the full hierarchical name of the net bus. This attribute is **read only** and cannot be set by the user.

**dont\_touch**

Identifies nets to be excluded from optimization. Values are *true* (the default) or *false*. Nets with the **dont\_touch** attribute set to *true* are not modified or replaced during **compile**. Set with **set\_dont\_touch**.

**groute\_length**

Get the global routing length of the net if global route is done for the net.

**is\_bussed**

Returns true if the net is part of a bussed net. This attribute is **read only** and cannot be set by the user.

**is\_test\_circuitry**

Set by **insert\_dft** on the scan cells and nets added to a design during the addition of test circuitry. This attribute is read-only and cannot be set by the user.

**load \***

A floating point number that specifies the wire load value on a net. The total load on a net is the sum of all the loads on pins, ports, and wires associated with that net. This attribute represents only the wire load; pin and port loads are not included in the attribute value unless the attribute **subtract\_pin\_load** is set to **true** for the same net. Set with **set\_load**.

**route\_mode**

The rerouting mode of a net. The attribute could be **normal**, **minorchange**, or **freeze**. The attribute could be set by **set\_net\_routing\_rule** command with **-reroute** option.

**static\_probability**

A floating point number that specifies the percentage of time that the signal is in the logic 1 state; this information is used by **report\_power**. If this attribute is not set, **report\_power** will use the default value of 0.5, indicating that the signal is in the logic 1 state half the time. Set with **set\_switching\_activity**.

#### subtract\_pin\_load

Causes **compile** to reduce the wire load value of a net by an amount equal to its pin load. Specifies that the **load** attribute includes the capacitances of all pins on the net. If the resulting wire load is negative, it is set to zero. Set with **set\_load -subtract\_pin\_load**.

#### route\_guide\_group\_id

Specifies the route guide group id for a flat net. The data type of **route\_guide\_group\_id** is int. The valid value range of **route\_guide\_group\_id** is 1~8. This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

#### switching\_activity

A positive floating point number that specifies the switching activity; that is, the number of zero-to-one and one-to-zero transitions within a library time unit period. This information is used by **report\_power**; if this attribute is not set, **report\_power** will use the default value of  $2 * (\text{static\_probability})(1 - \text{static\_probability})$ . The default will be scaled by any associated clock signal (if one is available). Set with **set\_switching\_activity**.

#### wired\_and

One of a set of two wired logic attributes that includes **wired\_or**. When present and set to *true*, **wired\_and** determines that the associated net has more than one driver and implements a wired AND function. Wired logic attributes cannot be manually set by the user. To cause wired logic attributes to be added to a netlist design that contains multiply-driven nets, you have two alternatives: 1. execute **compile** or **translate** on the design; or 2. specify the wired logic types using a resolution function in the HDL file.

#### wired\_or

One of a set of two wired logic attributes that includes **wired\_and**. When present and set to *true*, **wired\_or** determines that the associated net has more than one driver and implements a wired OR function. Wired logic attributes cannot be manually set by the user. To cause wired logic attributes to be added to a netlist design that contains multiply-driven nets, you have two alternatives: 1. execute **compile** or **translate** on the design; or 2. specify the wired logic types using a resolution function in the HDL file.

---

## SEE ALSO

`get_attribute(2)`  
`remove_attribute(2)`  
`attributes(3)`

---

## **net\_auto\_layer\_promotion\_max\_utilization**

Defines the maximum utilization of top metal layers that automatic layer promotions is allowed to use.

---

### **TYPE**

float

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

1 in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

This variable controls the maximum utilization that the automatic layer promotion optimization is allowed to use for the top metal layers. Setting this variable to a lower value is likely to result in less nets that are promoted to top metal layers.

The value of the variable is within range (0.0, 1.0], and the default is 1.0, which corresponds to allowing 100% utilization of available resources for layer promotions.

To determine the current value of this variable, use the following command:

```
prompt> printvar net_auto_layer_promotion_max_utilization
```

---

### **SEE ALSO**

`set_congestion_options(2)`

---

## optimize\_area\_ignore\_path\_group\_weights

Ignores the weights on path groups during area optimization in **optimize\_netlist -area**.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When **optimize\_area\_ignore\_path\_group\_weights** variable is **true**, the **optimize\_netlist -area** command ignores the weights set on the path groups. The weights of all path groups are set as 1 during area optimization. After area optimization is done, the weight on each path group is restored to the original value.

---

### EXAMPLES

The following examples show how to enable and disable ignoring the weights on the path groups during area optimization for a design:

```
prompt> set optimize_area_ignore_path_group_weights true  
prompt> set optimize_area_ignore_path_group_weights false
```

---

### SEE ALSO

[optimize\\_netlist\(2\)](#)  
[group\\_path\(2\)](#)

---

## optimize\_ndr\_critical\_range

Sets the critical range value for choosing nets for nondefault routing rules during optimization.

---

### TYPE

Float

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
0.008 in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### GROUP

syn-qor

---

### DESCRIPTION

Sets the critical range value for nondefault routing rules during optimization. The nets that fall within the following range are considered for nondefault routing rules:

[WNS, WNS\*(1-optimize\_ndr\_critical\_range)]

By default, the variable is set to 0.008. Therefore, if the worst negative slack is -1000, the range is [-1000, -992] where  $-992 = -1000 * (1 - 0.008)$ . If the delay value falls into this range, it is considered critical.

If you specify both the **optimize\_ndr\_critical\_range** and **optimize\_ndr\_max\_nets** variables, the tool uses the tighter constraints.

---

### SEE ALSO

[compile\\_ultra\(2\)](#)

---

## optimize\_ndr\_max\_nets

Restricts the maximum number of nets to be assigned nondefault routing rules during optimization.

---

### TYPE

Integer

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
2000 in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### GROUP

syn-qor

---

### DESCRIPTION

Sets a limit on the maximum number of nets to be assigned nondefault routing rules during optimization in the Design Compiler Graphical tool. Use the variable before running the **compile\_ultra -spg** command.

---

### SEE ALSO

[compile\\_ultra\(2\)](#)

---

## optimize\_ndr\_user\_rule\_names

Enables the automatic timing-focused promotion of nets with nondefault routing rules in the Design Compiler Graphical tool.

---

### TYPE

String

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

"" in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Set the **optimize\_ndr\_user\_rule\_names** variable to a prioritized list of nondefault routing rules that you want to use for automatic net promotion.

To define the nondefault routing rules use the **define\_routing\_rule command**. When you run the **compile\_ultra** command, the tool automatically promotes nets based on the nondefault routing rules that you specified.

The default value for this variable is empty.

Use the following command to determine the current value of the variable:

```
prompt> printvar optimize_ndr_user_rule_names
```

---

### SEE ALSO

`define_routing_rule(2)`  
`compile_ultra(2)`

---

## **optimize\_netlist\_enable\_state\_reachability**

Additional state-reachability to remove constant registers for the **optimize\_netlist** command.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

When **optimize\_netlist\_enable\_state\_reachability** is **true**, the **optimize\_netlist** command would do additional state-reachability to remove constant registers. The variable is useful if the constant propagates to the register only at the end of the flow.

---

### **SEE ALSO**

[optimize\\_netlist\(2\)](#)

---

## optimize\_reg\_add\_path\_groups

Instructs the **compile\_ultra** command to create a group of paths on nets connected to retimed subdesigns.

---

### TYPE

string

---

### DEFAULT

false

---

### DESCRIPTION

This variable automatically creates path groups for nets inside of or connected to subdesigns that are retimed. Use this variable to create path groups for designs that are retimed using the **set\_optimize\_registers** command. This variable does not affect designs retimed using the **compile\_ultra -retime** command.

When this variable is set to **inputs**, the **compile\_ultra** command creates path groups for nets connected to input pins of the subdesign that is being retimed. A separate path group for each subdesign is created. Path groups are created at the beginning of compile and removed just before the retiming engine is called in the optimization flow.

When this variable is set to **outputs**, the **compile\_ultra** command creates path groups for nets connected to output pins of the subdesign that is being retimed. A separate path group for each subdesign is created. Path groups are created at the beginning of compile and removed just before the retiming engine is called in the optimization flow.

When this variable is set to **registers**, the **compile\_ultra** command creates path groups for nets connected to data pins and next state pins of registers in the subdesign that is being retimed. A separate path group for each subdesign is created. Path groups are created at the beginning of compile and removed just before the retiming engine is called in the optimization flow. Use this setting to group paths that connect registers inside subdesigns being retimed.

By default, paths are not grouped. Set this variable to **false** to reset the variable to the default setting.

Be aware that paths grouped this way can result in longer runtime in Design Compiler.

To determine the current value of this variable, use the **printvar optimize\_reg\_add\_path\_groups** command. For a list of compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

**compile\_ultra(2)**  
**set\_optimize\_registers(2)**  
**group\_path(2)**



---

## optimize\_via\_ladder\_critical\_range

Sets the critical range value for choosing driver pins for via ladder insertion during optimization.

---

### TYPE

Float

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
0.5 in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### GROUP

syn-qor

---

### DESCRIPTION

Allows you to choose via ladders on driver pins in a timing path within a specific slack range during optimization. The variable sets the critical range value for via ladder insertion. The driver pins with nets falling within the following range are considered for via ladder insertion during optimization:

[WNS, WNS\*(1-optimize\_via\_ladder\_critical\_range)]

By default, the variable is set to 0.5. Therefore, if the worst negative slack is -1000, the range is [-1000, -500] where  $-500 = -1000*(1-0.5)$ . If the delay value falls into this range, it is considered critical.

---

### SEE ALSO

compile\_ultra(2)

---

## **optimize\_via\_ladder\_net\_length\_threshold**

Sets threshold on the length of nets connected to pins for via ladder assignment during optimization.

---

### **TYPE**

integer

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

100 in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **GROUP**

syn-qor

---

### **DESCRIPTION**

Sets a minimum length threshold on the nets considered for via ladder assignment during optimization in the Design Compiler Graphical tool. The value you specify is multiplied by the minimum height of the unit tile.

For example, if you specify a threshold value of 100, the minimum length threshold for nets considered for via ladder assignment is 100 times the minimum height of the unit tile.

---

### **SEE ALSO**

[compile\\_ultra\(2\)](#)

---

## pdefout\_diff\_original

Writes cells not in the original PDEF file when used in conjunction with the `-new_cells_only` option of the **write\_clusters** command.

---

### TYPE

Boolean

---

### DEFAULT

true in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

When this variable is set to **true**, the **write\_clusters -new\_cells\_only** command writes the new cells that are not in the original PDEF file. It determines the new cells by comparing the cell names.

When this variable is set to **false**, the **write\_clusters -new\_cells\_only** command writes the cells that were added during the last run of the **reoptimize\_design** command.

---

### SEE ALSO

---

# physical\_bus\_attributes

Contains attributes related to physical buses.

---

## DESCRIPTION

Contains attributes related to physical buses.

You can use the **get\_attribute** command to determine the value of an attribute and use the **report\_attribute** command to get a report of all attributes on a specified physical bus. To list the definitions of the attributes, use the **list\_attribute -class physical\_bus -application** command.

### Physical Bus Attributes

cell\_id

Specifies the Milkyway design ID in which a physical bus object is located.

This attribute is read-only.

name

Specifies the name of a physical bus object.

This attribute is read-only.

num\_nets

Specifies the number of nets in a physical bus object.

You can get the nets associated with a physical bus object by using the **get\_nets -of\_object <physical\_bus\_object>** command.

This attribute is read-only.

object\_class

Specifies the object class name of a physical bus object, which is **physical\_bus**.

This attribute is read-only.

object\_id

Specifies the object ID in the Milkyway design file.

This attribute is read-only.

---

## SEE ALSO

[get\\_attribute\(2\)](#)  
[list\\_attributes\(2\)](#)  
[report\\_attribute\(2\)](#)

---

# physical\_lib\_pin\_attributes

Describes the attributes related to physical library pins.

---

## DESCRIPTION

This man page describes the attributes related to physical library pins.

You can use the **get\_attribute** command to determine value of an attribute, and use the **report\_attribute** command to get a report of all attributes on a specified object. To see the attributes defined for physical library pins, use the **list\_attribute -class physical\_lib\_pin -application** command.

All of these attributes are read-only.

### Physical Library Pin Attributes

**cell\_id**

Specifies Milkyway design ID in which a physical\_lib\_pin object is located.

The data type of the **cell\_id** attribute is integer.

**cell\_name**

Specifies name of the Milkyway design in which a physical\_lib\_pin object is located.

The data type of the **cell\_name** attribute is string.

**direction**

Specifies the direction of a physical\_lib\_pin object.

The data type of the **direction** attribute is string.

**full\_name**

Specifies the full name of a physical\_lib\_pin object. The full name of a physical\_lib\_pin object is composed of the library name (**lib\_name** attribute), the cell name (**cell\_name** attribute), and the pin name (**name** attribute).

The data type of the **full\_name** attribute is string.

**is\_diode**

Indicates whether the specified object is a diode.

The data type of the **is\_diode** attribute is Boolean.

**lib\_name**

Specifies the library name of a physical\_lib\_pin object.

The data type of the **lib\_name** attribute is string.

**lib\_path**

Specifies the UNIX path name of the library that contains the physical\_lib\_pin object.

The data type of the **lib\_path** attribute is string.

**name**

Specifies the name of a physical\_lib\_pin object.

The data type of the **name** attribute is string.

**object\_class**

Specifies the object class name of a physical\_lib\_pin, which is **physical\_lib\_pin**.

The data type of the **object\_class** attribute is string.

**object\_id**

Specifies the ID of the physical\_lib\_pin object in the Milkyway design database.

The data type of the **object\_id** attribute is integer.

**pin\_type**

Specifies the pin type of a physical\_lib\_pin object.

The data type of the **pin\_type** attribute is string.

**pg\_pin\_weight**

A float attribute representing the PG pin weight. It should be between 0.1 and 25.0. And the fraction precision is 0.1, e.g. 0.11 will be cut off as 0.1.

---

## SEE ALSO

`get_attribute(2)`  
`list_attribute(2`  
`report_attribute(2)`

---

## physopt\_area\_critical\_range

Specifies a margin of slack for cells during area optimization. If a cell has a slack less than the area critical range, area optimization is not done for the cell.

---

### TYPE

float

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXTnon-topographical mode

-1.04858e+06 in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

The **physopt\_area\_critical\_range** variable specifies a margin of slack for cells during area optimization. If a cell has a slack less than the area critical range, area optimization is not done for the cell. The default value is minus infinity; that is, all cells are optimized for area during area recovery.

To determine the current value of this variable, use the **printvar physopt\_area\_critical\_range** command.

---

## **physoft\_create\_missing\_physical\_libcells**

Directs the tool to create dummy physical descriptions of missing physical library cells.

---

### **TYPE**

Boolean

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXTnon-topographical mode

false in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### **GROUP**

physoft

---

### **DESCRIPTION**

This variable enables the tool to create a dummy physical cell if a cell is missing from the user-supplied physical libraries.

The tool uses a simple physical description for these dummy physical cells. This is mainly required in the exploration flow so that the tool does not stop when you do not have the final physical libraries. This is not intended as a replacement for specifying the correct physical libraries. For a final and accurate solution, you must specify the correct physical libraries.

The dummy physical cells created by the tool are not persistent. They exist only in the current session and are not stored in the database. These cells are recreated in a new session, if they are still required.

To determine the current value of this variable, use the **printvar physoft\_create\_missing\_physical\_libcells** command.

---

## **physoft\_enable\_root\_via\_res\_support**

Enable via resistance support in the command **compile\_ultra -spg**.

---

### **TYPE**

Boolean

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **GROUP**

syn-qor

---

### **DESCRIPTION**

Controls the support of via resistance.

The default value for this variable is false.

---

### **SEE ALSO**

[compile\\_ultra\(2\)](#)

---

## physopt\_enable\_via\_res\_support

Enables and disables the support of via resistance for RC estimation.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
true in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Controls the support of via resistance for RC estimation. To disable via resistance for RC estimation, set this variable to **false**.  
To see the current value of this variable, use the **printvar physopt\_enable\_via\_res\_support** command.

---

## **physopt\_hard\_keepout\_distance**

Specifies the keepout distance used during virtual layout generation in the **compile\_ultra** flow.

---

### **TYPE**

float

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXTnon-topographical mode

0 in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

You can use this feature in Design Compiler topographical mode. This variable specifies the keepout distance used during virtual layout generation in the **compile\_ultra** flow. Specify the distance in micron units.

To prevent congestion, it is useful to mark an area in the design that surrounds a fixed macro as a hard keepout area. If you specify an area as a hard keepout area, the tool does not place any cells in that area. Define the area to be marked by setting a value for this variable, which the tool then uses to inflate the fixed cell's rectangle the same distance in all four directions.

To determine the current value of this variable, use the **printvar physopt\_hard\_keepout\_distance** command.

---

### **SEE ALSO**

[compile\\_ultra\(2\)](#)

---

## physoft\_ignore\_lpin\_fanout

Ignores max fanout constraints that are specified in the library.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### GROUP

physoft

---

### DESCRIPTION

This variable instructs tools to ignore max\_fanout violations from the constraints in the library. Only optimization ignores those constraints and the **report\_constraint** command still reports the violation.

---

### SEE ALSO

[report\\_constraint\(2\)](#)

---

## physopt\_power\_critical\_range

Specifies a margin of slack for cells during leakage power optimization. If a cell has a slack less than the power critical range, power optimization will not be done for the cell.

---

### TYPE

float

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXTnon-topographical mode

-1.04858e+06 in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### GROUP

physopt

---

### DESCRIPTION

This variable specifies a power critical range, which is a margin of slack for cells during leakage power optimization. If a cell has a slack less than the power critical range, leakage power optimization is not performed for the cell.

By default, the value of minus infinity indicates that all cells are optimized for leakage power during the leakage power optimization phase of the **physopt** command.

---

### SEE ALSO

---

## pin\_attributes

Contains attributes placed on pins.

---

## DESCRIPTION

Contains attributes that can be placed on a pin.

There are a number of commands used to set attributes; however, most attributes can be set with the **set\_attribute** command. If the attribute definition specifies a **set** command, use it to set the attribute. Otherwise, use the **set\_attribute** command. If an attribute is **read only**, it cannot be set by the user.

To determine the value of an attribute, use the **get\_attribute** command. To remove attributes, use the **remove\_attribute** command.

For a detailed information of an attribute, see the man pages of the appropriate **set** command. For information on all attributes, see the **attributes** man page.

### Pin Attributes

**bus\_name**

If the pin is bussed, returns the full hierarchical name of the pin bus. This attribute is **read only** and cannot be set by the user.

**clock**

The clock attribute indicates whether an input pin is a clock pin.

**clock : true | false**

The *true* value specifies the pin as a clock pin. The *false* value specifies the pin as not a clock pin, even though it might have the clock characteristics.

The following example defines pin CLK2 as a clock pin.

```
pin(CLK2) {  
    direction : input ;  
    capacitance : 1.0 ;  
    clock : true ;  
}
```

**disable\_timing**

Disables timing arcs. This has the same affect on timing as not having the arc in the library. Set with the **set\_disable\_timing** command.

**is\_bussed**

Returns true if the pin is part of a bussed pin. This attribute is **read only** and cannot be set by the user.

**is\_diode**

Tells if the pin is a diode pin.

**max\_fall\_delay**

A floating point value that specifies the maximum falling delay on ports, clocks, pins, cells, or on paths between such objects. Set with the **set\_max\_delay** command.

**max\_rise\_delay**

A floating point value that specifies the maximum rising delay on ports, clocks, pins, cells, or on paths between such objects. Set with the **set\_max\_delay** command.

**min\_fall\_delay**

A floating point value that specifies the minimum falling delay on ports, clocks, pins, cells, or on paths between such objects. Set with the **set\_min\_delay** command.

**min\_rise\_delay**

A floating point value that specifies the minimum rising delay on ports, clocks, pins, cells, or on paths between such objects. Set with the **set\_min\_delay** command.

**observe\_pin**

Specifies the (internal) observe pin name of an LSI Logic scan macro cell (LSI CTV only). This attribute is used by the **write\_test** command. Set with the **set\_attribute** command.

**pin\_direction**

Returns the direction of a pin. The value can be **in**, **out**, **inout**, or **unknown**. This attribute cannot be set by the user. You can also use the **direction** attribute to get the direction of the pin.

**pin\_properties**

Lists valid EDIF property values to be attached to different versions of the output pin. The EDIF property values correspond to different output emitter-follower resistance values on the output pin. For information about how to use attribute, see the *Library Compiler Reference Manual*. Set with the **set\_attribute** command.

**set\_pin**

Specifies the (internal) set pin name of an LSI Logic scan macro cell (LSI CTV only). This attribute is used by the **write\_test** command. Set with the **set\_attribute** command.

**signal\_type**

Used to indicate that a pin or port is of a special type, such as a **clocked\_on\_also** port in a master/slave clocking scheme, or a **test\_scan\_in** pin for scan-test circuitry. Set with the **set\_signal\_type** command.

**static\_probability**

A floating point number that specifies the percentage of time that the signal is in the logic 1 state; this information is used by the **report\_power** command. If this attribute is not set, the **report\_power** command uses 0.5 (the default) as the value, indicating that the signal is in the logic 1 state half the time. Set with the **set\_switching\_activity** command.

**test\_assume**

A string that represents a constant logic value to be assumed for specified pins throughout test design rule checking, test pattern generation, and fault simulation by the **check\_test**, **create\_test\_patterns**, and **fault\_simulate** commands. "1", "one", or "ONE" specifies a constant value of logic 1; "0", "zero", or "ZERO" specifies a constant value of logic 0. Use the **report\_test -assertions** command for a report on objects that have the **test\_assume** attribute set. Set with the **set\_test\_assume** command.

**test\_dont\_fault**

Specifies pins not faulted during test pattern generation. If no command options are specified, this attribute is set for both stuck-at-0 and stuck-at-1 faults. Set with the **set\_test\_dont\_fault** command.

**test\_initial**

A string that represents an initial logic value to be assumed for specified pins at the start of test design rule checking and fault simulation by the **check\_test** and **fault\_simulate** commands. "1", "one", or "ONE" specifies an initial value of logic 1; "0", "zero", or "ZERO" specifies an initial value of logic 0. Use the **report\_test -assertions** command for a report on objects that have the **test\_initial** attribute set. Set with the **set\_test\_initial** command.

**test\_isolate**

Indicates that the specified sequential cells, pins, or ports are to be logically isolated and considered untestable during test design rule checking by the **check\_test** command. When this attribute is set on a cell, it is also placed on all pins of that cell. Do not set this attribute on a hierarchical cell. Use the **report\_test -assertions** command for a report on isolated objects. Set with the **set\_test\_isolate** command.

**Note:** Setting this attribute suppresses the warning messages associated with the isolated objects.

#### test\_require

Specifies a constant, fixed logic value that a pin is required to have during scan test vector generation. The pin maintains the same value for each test vector generated. Use the **report\_test -assertions** for a report on objects that have the **test\_require** attribute set. Set with the **set\_test\_require** command.

#### test\_routing\_position

Specifies the preferred routing order of the scan-test signals of the identified cells. Set with the **set\_test\_routing\_order** command.

#### switching\_activity

A positive floating point number that specifies the switching activity, that is, the number of zero-to-one and one-to-zero transitions within a library time unit period. This information is used by the **report\_power** command. If this attribute is not set, the **report\_power** command uses the default value of  $2 * (\text{static\_probability})(1 - \text{static\_probability})$ . The default value is scaled by any associated clock signal (if one is available). Set with the **set\_switching\_activity** command.

#### true\_delay\_case\_analysis

Specifies a value to set all or part of an input vector for the **report\_timing -true** and **report\_timing -justify** commands. Allowed values are 0, 1, r (rise, X to 1), and f (fall, X to 0). Set with the **set\_true\_delay\_case\_analysis** command.

#### hold\_uncertainty

Specifies a negative uncertainty from the edges of the ideal clock waveform. Affects all sequential cells in the transitive fanout of this pin. Set with the **set\_clock\_uncertainty -hold** command.

#### setup\_uncertainty

Specifies a positive uncertainty from the edges of the ideal clock waveform. Affects all sequential cells in the transitive fanout of this pin. Set with the **set\_clock\_uncertainty -setup** command.

#### pg\_pin\_weight

A float attribute representing the PG pin weight. The PG pin weight should be between 0.1 and 25.0, and the fraction precision is 0.1. For example, 0.11 will be cut off as 0.1.

---

## SEE ALSO

`get_attribute(2)`  
`remove_attribute(2)`  
`set_attribute(2)`  
`attributes(3)`

---

## placement\_blockage\_attributes

Contains attributes related to placement blockage.

---

### DESCRIPTION

Contains attributes related to placement blockage.

You can use **get\_attribute** to determine value of an attribute, and use **report\_attribute** to get a report of all attributes on specified object. Specified with **list\_attribute -class placement\_blockage -application**, the definition of attributes can be listed.

#### Placement Blockage Attributes

affects

Specifies the affects of a placement blockage, which is placement.

The data type of **affects** is string.

This attribute is read-only.

area

Specifies area of a placement blockage.

The data type of **area** is float.

This attribute is read-only.

bbox

Specifies the bounding-box of a placement blockage. The **bbox** is represented by a **rectangle**.

The format of a *rectangle* specification is {{llx lly} {urx ury}}, which specifies the lower-left and upper-right corners of the rectangle.

The data type of **bbox** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

blocked\_percentage

Specifies the percentage blockage for a partial blockage.

The data type of **blocked\_percentage** is integer.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

cell\_id

Specifies Milkyway design ID in which a placement blockage object is located.

The data type of **cell\_id** is integer.

This attribute is read-only.

layer

Specifies layer name of a placement blockage.

The data type of **layer** is string.

Its valid values are:

- **PlaceBlockage**
- **SoftPlaceBlk**
- **pinBlockage**
- **MacroBlockage**
- **PartialPlaceBlk**

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**name**

Specifies name of a placement blockage object.

The data type of **name** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**object\_class**

Specifies object class name of a placement blockage, which is **placement\_blockage**.

The data type of **object\_class** is string.

This attribute is read-only.

**object\_id**

Specifies object ID in Milkyway design file.

The data type of **object\_id** is integer.

This attribute is read-only.

**pin\_blockage\_layers**

Specifies the layers for which routing to pins are blocked. This attribute only applies on pin blockage type.

The data type of **pin\_blockage\_layers** is string.

This attribute is read-only.

**type**

Specifies type of a placement blockage.

The data type of **type** is string.

Its valid values are:

- **hard**
- **soft**
- **pin**
- **hard\_macro**
- **partial**

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### is\_reserved\_placement\_area

The attribute is true if the placement blockage has the property "is\_reserved\_placement\_area".

The attribute is read-only.

**no\_register** is a writable boolean attribute. If true, it specifies that register cells are prohibited within the blockage. All other cells are allowed.

**buffer\_only** is a writable boolean attribute. If true, it specifies that non-buffer cells are prohibited within the blockage. Buffers and inverters are allowed.

**no\_rp\_group** is a writable boolean attribute. If true, it specifies that rp groups are prohibited within the blockage. All other cells are allowed.

**category\_name** is a writable string attribute. If set, it specifies the name of a boolean user-defined attribute. Use this attribute to specify which cells or references are prohibited within the blockage. See **create\_placement\_blockage** for details.

**no\_register**, **buffer\_only**, **no\_rp\_group** and **category\_name** are mutually exclusive, i.e. they may not be used together on the same placement blockage. They may only be used on partial type blockages. See **create\_placement\_blockage** for more information.

**buffer\_only** and **category\_name** require the **redefined blockage behavior** feature, enabled as follows:

```
set placer_enable_redefined_blockage_behavior true
```

---

## SEE ALSO

```
create_placement_blockage(2)
get_attribute(2)
list_attributes(2)
report_attribute(2)
set_attribute(2)
placer_enable_redefined_blockage_behavior(3)
```

---

## placer\_auto\_timing\_control

Enables automatic timing control for direct timing-driven placement when you use the **compile\_ultra -spg** and **compile\_ultra -incremental -spg** commands.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXT non-topographical mode

false in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

When you set this variable to **true**, the direct timing-driven placement tries to focus the timing optimization on the most critical timing paths to find a balance between reducing the worst negative slack (WNS) and reducing the total negative slack (TNS).

This also enables Zroute-based congestion-driven placement instead of congestion estimation based on virtual routing, which estimates congestion based on wire-routing predictions.

You can use this feature in Design Compiler NXT topographical mode.

To use the automatic timing control feature, you must use the **set\_icc2\_options** command as follows:

```
prompt> set_app_var placer_auto_timing_control true  
prompt> set_icc2_options -ref_lib "lib1.ndm lib2.ndm" -technology tech.tf
```

---

### SEE ALSO

[set\\_icc2\\_options\(2\)](#)

---

## placer\_buffering\_aware

Enables buffering-aware timing-driven placement when you use the **compile\_ultra -spg** command.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXT non-topographical mode

false in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

When you set this variable to **true**, the tool enables buffering-aware timing-driven placement by using an approximate timing model that estimates the effects of buffering long nets and high-fanout nets later in the flow. The netlist is not changed.

This feature is used during the initial placement to get a better starting point for later timing optimizations.

You can use this feature in Design Compiler NXT topographical mode.

To use the buffering-aware placement feature, you must use the **set\_icc2\_options** command as follows:

```
prompt> set_app_var placer_buffering_aware true  
prompt> set_icc2_options -ref_lib "lib1.ndm lib2.ndm" -technology tech.tf
```

---

### SEE ALSO

[set\\_icc2\\_options\(2\)](#)

---

## placer\_channel\_detect\_mode

Controls the treatment of channel areas during coarse placement.

---

### TYPE

string

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

This variable controls the treatment of channel areas during coarse placement.

Valid values are **auto**, **true**, or **false**.

By default (**false**), the tool does not treat channel areas differently.

When you set this variable to **true**, the tool analyzes the area available for placement and classifies narrow parts as channels. The tool reduces the maximum cell density allowed in channel areas during coarse placement to help reduce congestion.

When you set this variable to **auto**, the tool considers the amount of channel area in the design. If the tool determines that the design has little or no channel area, it does not treat channel areas differently. If the tool determines that the design has a substantial amount of channel area, it reduces the maximum cell density allowed in channel areas during coarse placement to help reduce congestion.

Some increase in runtime and memory usage is expected when this feature is active. Setting this variable to **auto** only incurs the runtime and memory penalties when the design has a substantial amount of channel area.

---

### SEE ALSO

---

## placerCongRestruct

Enables congestion-driven restructuring when you use the **compile\_ultra -spg** command

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXT non-topographical mode

false in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

When you set this variable to **true**, the tool enables congestion-driven restructuring when you use the **compile\_ultra -spg** command. The tool performs restructuring of the net during the initial placement inside the wire-length-driven placement.

You can use this feature in Design Compiler NXT topographical mode.

To use the congestion-driven restructuring feature, you must use the **set\_icc2\_options** command as follows:

```
prompt> set_app_var placerCongRestruct true  
prompt> set_icc2_options -ref_lib "lib1.ndm lib2.ndm" -technology tech.tf
```

---

### SEE ALSO

[set\\_icc2\\_options\(2\)](#)

---

## placer\_congestion\_effort

Controls which congestion estimator to use during congestion-driven placement in the **place\_opt-congestion** or **compile\_ultra-spg** flow.

---

### TYPE

string

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
auto in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

The **placer\_congestion\_effort** variable controls which congestion estimator to use during congestion-driven placement in the **place\_opt-congestion** or **compile\_ultra-spg** flow.

Valid values are **auto** or **medium**. For the **placer\_congestion\_effort** variable settings to take effect in the Design Compiler Graphical tool, you must first set the **placer\_enable\_enhanced\_router** variable to **true**.

By default (**auto**), the tool first runs a fast internal estimator to determine how much congestion is there in the placement. If the tool determines that there is not much congestion, it uses the map with fast estimator to drive congestion-driven placement. If the tool determines that there is too much congestion, uses Zroute global router to do a more accurate congestion estimation and uses that map to drive congestion-driven placement.

When you set the variable to **medium**, the tool always uses the Zroute global router for congestion-driven placement.

To improve congestion correlation with the IC Compiler II tool, you should not use **auto** for 7 nm and lower-process nodes. With 7 nm and lower-process nodes designs, you should launch the IC Compiler II tool from the Design Compiler NXT tool using the **set\_icc2\_options-congestion\_use\_global\_route** command for congestion estimation during placement.

---

### SEE ALSO

[compile\\_ultra\(2\)](#)  
[placer\\_enable\\_enhanced\\_router\(3\)](#)

---

## placer\_disable\_auto\_bound\_for\_gated\_clock

Determines whether automatic group bounding is disabled for gated clocks created by Power Compiler.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

true in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

The gated-clock method reduces a design's power consumption by controlling the switching activity from the clock signal to flip-flop registers. The automatic bound function that this variable enables (when set to *false*, the default is *true*) works only for the gated-clock elements Power Compiler creates. The **placer\_disable\_auto\_bound\_for\_gated\_clock** variable does not affect your design unless you use the clock-gating functionality of Power Compiler.

To reduce clock skew, place the clock-gating element and the flip-flops it controls close together in your design. The tool automatically creates a group bound for each clock-gating element and the flip-flops the element drives. This group bound helps place the flip-flops closer to the clock-gating element.

If this variable remains true, the tool does not create a group bound for the clock-gating elements created with Power Compiler.

---

### SEE ALSO

[remove\\_bounds\(2\)](#)  
[report\\_bounds\(2\)](#)  
[create\\_bounds\(2\)](#)

---

## placer\_disable\_macro\_placement\_timeout

Prevents the coarse placer from timing out during macro placement.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXT non-topographical mode

false in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

Use this variable to prevent the coarse placer from timing out during macro placement when running **create\_placement** with floating macros.

By default, macro placement exits early if runtime is too long when compared to the rest of coarse placement. This is to prevent excessively long runtimes that can occur when there are too many floating macros, too many constraints on macros, or bad constraints. The result is that some macros may be placed illegally.

When this variable is set to true, the placer will let macro placement run to completion regardless of runtime.

The default value of this variable is false.

---

### SEE ALSO

---

## **placer\_dont\_error\_out\_on\_conflicting\_bounds**

Prevents the coarse placer from exiting with an error when it detects conflicting bounds.

---

### **TYPE**

Boolean

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXTnon-topographical mode

true in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

Use this variable to prevent the tool from exiting with an error when it detects conflicting bounds when running **place\_opt** or **create\_placement**.

By default, the placer will automatically adjust the conflicting groupbounds and continue instead of exiting with an error.

When this variable is set to false, the placer checks for conflicting movebounds and groupbounds and errors out if a conflict is detected. These bounds can be user-specified bounds or bounds generated by the tool.

The default value of this variable is true.

---

### **SEE ALSO**

[create\\_bounds\(2\)](#)

---

## placer\_enable\_enhanced\_router

Enables Zroute-based congestion-driven placement to perform more accurate, congestion-aware placement.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

When the **placer\_enable\_enhanced\_router** variable is set to **true**, the tool uses Zroute-based congestion-driven placement instead of congestion estimation based on virtual routing, which estimates congestion based on wire-routing predictions. Zroute-based congestion estimation is enabled only on designs that meet the internal congestion threshold. Any designs that are not congested enough to meet the threshold are estimated by virtual routing (the default).

Design Compiler Graphical and IC Compiler use the same internal congestion thresholds. As a result, Zroute-based congestion-driven placement provides better optimization and congestion correlation between Design Compiler Graphical and IC Compiler than virtual routing.

However, using Zroute congestion-driven placement might increase runtime and impact area and timing. Therefore, use it only on highly congested designs.

Note that the **set\_congestion\_options -layer** command is not supported when **placer\_enable\_enhanced\_router** is enabled.

Use the following command to determine the current value of the variable:

```
prompt> printvar placer_enable_enhanced_router
```

---

### SEE ALSO

[set\\_congestion\\_options\(2\)](#)

---

## placer\_enable\_enhanced\_soft\_blockages

Prevents cells already placed on soft blockages, at the beginning of placement, from being moved out of the soft blockages.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

true in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

This variable affects only incremental coarse placement. It has no effect on synthesis or legalization.

Soft blockages prevent the coarse placer from placing cells on the blockage. They do not prevent synthesis or legalization placing cells. After an initial placement, synthesis may add cells on top of a soft blockage. If incremental coarse placement is later done on the design, it will move those new cells off the soft blockages. This may be undesirable.

Set this variable to true to prevent incremental coarse placement from moving cells out of soft blockages.

If this variable is set to true, cells already on soft blockages at the beginning of incremental coarse placement will be allowed, but not constrained, to stay there.

Cells not on soft blockages at the beginning of incremental coarse placement will always be prevented from moving onto the soft blockages during placement, irrespective of the value of this variable.

---

### SEE ALSO

[create\\_placement\\_blockage\(2\)](#)

---

## placer\_enable\_redefined\_blockage\_behavior

Enables new behavior and features related to placement blockages.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

true in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

This variable affects coarse placement when your design contains enhanced soft blockages, no-register blockages, buffer-only blockages, no-relative-placement blockages, and category blockages.

Set this variable to **true**, when:

- Your design contains any of the types of blockages previously listed, to prevent clumping of cells in the region outside the blockages.
  - Your design contains more than one of the types of blockages previously listed, to ensure the correct interaction between the different types of blockages.
  - You create buffer-only blockages using the **create\_placement\_blockage -buffer\_only** command.
  - You create category blockages using the **create\_placement\_blockage -category** command.
- 

### SEE ALSO

[create\\_placement\\_blockage\(2\)](#)

---

## placer\_enhanced\_low\_power\_effort

Controls Link Placer ELPP Effort Level.

This variable is supported only in Design Compiler NXT shell and in topographical mode.

---

### TYPE

string

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, DC Explorer, and Design Compiler NXT non-topographical mode

default in Design Compiler NXT topographical mode

---

### DESCRIPTION

This variable controls the effort level of the "link placer enhanced low power placement" feature. This feature is only available when Total power optimization in DC-NXT is enabled and link placer is employed.

Allowed values are **none**, **low**, **medium**, and **high**.

When set to **none**, enhanced low power placement optimization is skipped for the link placer.

When set to **low**, ELPP effort for low power placement is low.

When set to **medium**, ELPP effort for low power placement is medium.

When set to **high**, ELPP effort for low power placement is high.

By default, low effort is used and medium/high efforts can be used to get more total power improvement.

To determine the current value of this variable, use the **printvar placer\_enhanced\_low\_power\_effort** command. For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

`compile(2)`  
`compile_enable_total_power_optimization(3)`

---

## placer\_gated\_register\_area\_multiplier

Specifies the value of the multiplier used to generate automatic group bounds for gated clocks.

---

### TYPE

float

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXT non-topographical mode

20 in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

The gated-clock method reduces a design's power consumption by controlling the switching activity from the clock signal to flip-flop registers. The automatic bound function works only for the gated-clock elements created by Power Compiler. The **placer\_gated\_register\_area\_multiplier** variable does not affect your design unless you use the clock-gating functionality of Power Compiler.

To reduce clock skew, place the clock-gating element and the flip-flops it controls close together in your design. The tool automatically creates a floating group bound for each clock-gating element and the flip-flops the element drives. This group bound helps place the flip-flops closer to the clock-gating element.

The size of the group bound is equal to the square root of the product of the total area of flip-flop elements the gate controls within the group bound and the value of the **placer\_gated\_register\_area\_multiplier** variable.

For example, if a clock-gating element drives five flip-flops and the total area of these six cells is 45, the size of the group bound is  $\sqrt{20 \times 45} = 30$ .

---

### SEE ALSO

---

## placer\_max\_allowed\_timing\_depth

Specifies the maximum timing graph depth allowed by the placer.

---

### TYPE

integer

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
20000 in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

The placer cannot process extremely deep timing paths, and will check for the presence of such paths. This variable controls the depth limit for the checking.

When running the placer, no path may be deeper than this limit. This applies even if the path is unconstrained.

If this variable is set above 32767, however, two things will happen:

- 1) Depth checking will be disabled.
- 2) Multicore operation will be disabled.

Be aware that increasing this limit may cause the process to abort due to insufficient stack space. Always set the process stack size to a high value in your system command shell when using this option.

An alternative to changing this limit is to use set\_disable\_timing to break very long paths into multiple segments. The paths must be broken up so that no segment (even if unconstrained) is longer than the limit.

---

### SEE ALSO

---

## placer\_max\_cell\_density\_threshold

Enables a mode of coarse placement in which cells can clump together.

---

### TYPE

float

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

-1 in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

This variable enables a mode of coarse placement in which cells are not distributed evenly across the surface of the chip and are allowed to clump together.

The value you specify sets the threshold for how tightly the cells are allowed to clump. A value of 1.0 does not allow gaps between cells.

A reasonable value is one that is above the background utilization of your design but below 1.0. For example, if your background utilization is 40%, or 0.4, a reasonable value for this variable is a value between 0.4 and 1.0. The higher the value, the more tightly the cells clump together.

You can use this feature in Design Compiler topographical mode. It affects the virtual layout in the **compile\_ultra** flow.

For example, to set the threshold to 0.7, enter

```
prompt> set placer_max_cell_density_threshold 0.7
```

---

### SEE ALSO

[compile\\_ultra\(2\)](#)

---

## placer\_max\_parallel\_computations

Overrides the value set by the **set\_host\_options -max\_cores** command for running the placement engine in multicore mode.

---

### TYPE

integer

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
0 in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### GROUP

placer variables

---

### DESCRIPTION

This variable can reduce the number of cores used for running the placement engine when you have previously enabled multicore processing by running the **set\_host\_options -max\_cores** command.

If the variable is set to 0 (the default value), the maximum number of cores used by the placement engine is specified by the **set\_host\_options -max\_cores** command.

If the variable is set to 1, the placement engine runs in single-core mode, regardless of the number of cores specified by the **set\_host\_options -max\_cores** command.

If the variable is set to a value greater than 1 and smaller than the value specified by the **set\_host\_options -max\_cores** command, the placement engine ignores the value set by the **set\_host\_options** command and runs in multicore mode with the number of cores specified by the variable.

If the variable is set to a value greater than the value specified by the **set\_host\_options -max\_cores** command, this variable is ignored.

This variable should not be used for normal operation and is primarily intended for diagnostic purposes.

---

### EXAMPLES

The following example enables multicore processing with a maximum of four cores for all multicore functions.

```
prompt> set_host_options -max_cores 4
```

The following example enables multicore processing with a maximum of two cores for the placement engine and a maximum of four cores for all other multicore functions.

```
set_host_options -max_cores 4  
set placer_max_parallel_computations 2
```

The following example enables singles-core processing for the placement engine and a maximum of four cores for all other multicore functions.

```
set_host_options -max_cores 4  
set placer_max_parallel_computations 1
```

The following example enables multicore processing with a maximum of two cores for all multicore functions. The **placer\_max\_parallel\_computations** variable is ignored because its value is greater than the value set by the **set\_host\_options** command.

```
set_host_options -max_cores 2  
set placer_max_parallel_computations 4
```

---

## SEE ALSO

[set\\_host\\_options\(2\)](#)

---

## placer\_reduce\_high\_density\_regions

Enables high-effort high-density-spot reduction during coarse placement.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

This variable enables high-effort high-density-spot reduction during coarse placement when set to **true**.

Use this variable on designs that exhibit high-density areas around macros or blockages when the default coarse placement effort is insufficient to remove all these high-density areas. You might see longer runtimes as a side effect (coarse placement runtime is expected to double). This feature is not yet wire-length or timing aware, so wire-length and timing might degrade as a result of using it.

To enable this feature, enter

```
prompt> set placer_reduce_high_density_regions true
```

---

### SEE ALSO

---

## placer\_show\_zrouteigr\_output

Reports Zroute global routing information during congestion-driven placement.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXT non-topographical mode

false in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

This variable controls whether global routing information is reported during congestion-driven placement when the Zroute global router is used.

By default (**false**), the global routing information is not reported.

When you set this variable to **true**, the global routing information is reported when you use Zroute global routing for congestion-driven placement.

---

### SEE ALSO

---

## placer\_tns\_driven

Directs the timing-driven placer to optimize the total negative slack in the design instead of the worst negative slack during the initial compile.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXTnon-topographical mode

false in Design Compiler topographical mode

true in Design Compiler NXT topographical mode

---

### DESCRIPTION

When you set the `placer_tns_driven` variable to **true** before running the `compile_ultra` command, the placer tries to reduce the total negative slack of the design instead of optimizing the worst negative slack.

This variable is only supported in Design Compiler and Design Compiler NXT topographical modes. It is not supported in Design Compiler and Design Compiler NXT non-topographical modes or DC Explorer.

In Design Compiler NXT topographical mode, the variable is on by default (**true**) and timing-driven placement enhanced to focus timing optimization on the most critical timing paths to find a good balance between reducing the worst slack and reducing the total negative slack.

Use the following command to determine the current value of the variable:

```
prompt>printvar placer_tns_driven
```

---

### SEE ALSO

`placer_tns_driven_in_incremental_compile(3)`

---

## placer\_tns\_driven\_in\_incremental\_compile

Controls how the tool optimizes the total negative slack in the design during incremental compile.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXT non-topographical mode

auto in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

By default, the placer tries to reduce the total negative slack in the design only when the total negative slack exceeds a certain threshold.

To optimize the total negative slack in the design even if the total negative slack number is low, set the **placer\_tns\_driven\_in\_incremental\_compile** variable to **true** before running the **compile\_ultra -incremental** command.

To optimize the worst negative slack instead of the total negative slack, set the **placer\_tns\_driven\_in\_incremental\_compile** variable to **false** before running the **compile\_ultra -incremental** command.

This variable is only supported in Design Compiler topographical mode. It is not supported in Design Compiler non-topographical mode or DC Explorer.

Use the following command to determine the current value of the variable:

```
prompt>printvar placer_tns_driven_in_incremental_compile
```

---

### SEE ALSO

[placer\\_tns\\_driven\(3\)](#)

---

## **placer\_wide\_cell\_pg\_strap\_distance**

Sets the power and ground (PG) pitch for the design to distribute wide cells evenly during coarse placement.

---

### **TYPE**

float

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXTnon-topographical mode

0 in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

This variable specifies the pitch of the PG straps in the design. You must use this variable along with the **placer\_wide\_cell\_use\_model** variable. These variables together enable a mode of coarse placement to distribute wide cells evenly across the surface of the chip to minimize displacement of cells during legalization and reduce congestion. Cells with a width greater than half the specified pitch are considered as wide cells.

You can use this feature in Design Compiler topographical mode.

For example, to specify the pitch of the PG straps,

```
prompt> set_app_var placer_wide_cell_use_model true
prompt> set_app_var placer_wide_cell_pg_strap_distance 0.3
```

---

### **SEE ALSO**

[compile\\_ultra\(2\)](#)

---

## placer\_wide\_cell\_use\_model

Enables wide cell support in the coarse placer.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXT non-topographical mode

false in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

This variable enables a mode of coarse placement to distribute wide cells evenly across the surface of the chip to minimize displacement of cells during legalization and reduce congestion. Cells with a width (of M1 PG pitch) greater than half the distance between adjacent M1 power and ground (PG) straps are considered as wide cells. You must use this variable along with the **placer\_wide\_cell\_pg\_strap\_distance** variable.

You can use this feature in Design Compiler topographical mode.

For example, to improve the placement of wide cells in a region,

```
prompt> set_app_var placer_wide_cell_use_model true
```

---

### SEE ALSO

compile\_ultra(2)

---

## plan\_group\_attributes

Contains attributes related to plan group.

---

## DESCRIPTION

Contains attributes related to plan group.

You can use **get\_attribute** to determine value of an attribute, and use **report\_attribute** to get a report of all attributes on specified object. Specified with **list\_attribute -class plan\_group -application**, the definition of attributes can be listed.

### Plan Group Attributes

#### aspect\_ratio

Specifies the **height:width** ratio of a plan group.

The data type of **aspect\_ratio** is double.

This attribute is read-only.

#### bbox

Specifies the bounding-box of a plan group. The **bbox** is represented by a **rectangle**.

The format of a *rectangle* specification is {{llx lly} {urx ury}}, which specifies the lower-left and upper-right corners of the rectangle.

The data type of **bbox** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### bbox\_ll

Specifies the lower-left corner of the bounding-box of a plan group.

The **bbox\_ll** is represented by a **point**. The format of a *point* specification is {x y}.

You can get the **bbox\_ll** of a plan group, by accessing the first element of its**bbox**.

The data type of **bbox\_ll** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### bbox\_llx

Specifies x coordinate of the lower-left corner of the bounding-box of a plan group.

The data type of **bbox\_llx** is double.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### bbox\_lly

Specifies y coordinate of the lower-left corner of the bounding-box of a plan group.

The data type of **bbox\_lly** is double.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**bbox\_ur**

Specifies the upper-right corner of the bounding-box of a plan group.

The **bbox\_ur** is represented by a **point**. The format of a *point* specification is {x y}.

You can get the **bbox\_ur** of a plan group, by accessing the second element of its **bbox**.

The data type of **bbox\_ur** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**bbox\_urx**

Specifies x coordinate of the upper-right corner of the bounding-box of a plan group.

The data type of **bbox\_urx** is double.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**bbox\_ury**

Specifies y coordinate of the upper-right corner of the bounding-box of a plan group.

The data type of **bbox\_ury** is double.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**bottom\_padding**

Specifies bottom-side width of interior paddings.

The data type of **bottom\_padding** is double.

This attribute is read-only. You can use **create\_fp\_plan\_group\_padding** to set its value.

**bottom\_padding\_external**

Specifies bottom-side width of exterior paddings.

The data type of **bottom\_padding\_external** is double.

This attribute is read-only. You can use **create\_fp\_plan\_group\_padding** to set its value.

**bottom\_shielding**

Specifies bottom-side widths of signal shielding inside a plan group.

The data type of **bottom\_shielding** is string.

This attribute is read-only. You can use **create\_fp\_block\_shielding** to set its value.

**bottom\_shielding\_external**

Specifies bottom-side widths of signal shielding outside a plan group.

The data type of **bottom\_shielding\_external** is string.

This attribute is read-only. You can use **create\_fp\_block\_shielding** to set its value.

**color**

Specifies color to draw a plan group and its associated instances.

The data type of **color** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**is\_fixed**

Specifies that a plan group is in a fixed location, and the shaping will ignore it.

The data type of **is\_fixed** is boolean.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### is\_on\_demand\_netlist

Specifies that a plan group contains only the interface netlist.

The data type of **is\_on\_demand\_netlist** is boolean.

This attribute is read-only.

#### left\_padding

Specifies left-side width of interior paddings.

The data type of **left\_padding** is double.

This attribute is read-only. You can use **create\_fp\_plan\_group\_padding** to set its value.

#### left\_padding\_external

Specifies left-side width of exterior paddings.

The data type of **left\_padding\_external** is double.

This attribute is read-only. You can use **create\_fp\_plan\_group\_padding** to set its value.

#### left\_shielding

Specifies left-side widths of signal shielding inside a plan group.

The data type of **left\_shielding** is string.

This attribute is read-only. You can use **create\_fp\_block\_shielding** to set its value.

#### left\_shielding\_external

Specifies left-side widths of signal shielding outside a plan group.

The data type of **left\_shielding\_external** is string.

This attribute is read-only. You can use **create\_fp\_block\_shielding** to set its value.

#### logic\_cell

Specifies name of the hierarchical cell associated with a plan group.

The data type of **logic\_cell** is string.

This attribute is read-only.

#### name

Specifies name of a plan group object.

The data type of **name** is string.

This attribute is read-only.

#### number\_of\_hard\_macro

Specifies number of hard macro cells inside a plan group.

The data type of **number\_of\_hard\_macro** is integer.

This attribute is read-only.

**number\_of\_pin**

Specifies number of pins on the hierarchical cell associated with a plan group.

The data type of **number\_of\_pin** is integer.

This attribute is read-only.

**number\_of\_standard\_cell**

Specifies number of standard cells inside a plan group.

The data type of **number\_of\_standard\_cell** is integer.

This attribute is read-only.

**number\_of\_odl\_standard\_cell**

Specifies number of standard cells inside an ODL plan group.

The data type of **number\_of\_odl\_standard\_cell** is integer.

This attribute is read-only.

**object\_class**

Specifies object class name of a plan group, which is **plan\_group**.

The data type of **object\_class** is string.

This attribute is read-only.

**points**

Specifies point list of a plan group's boundary.

The data type of **points** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**right\_padding**

Specifies right-side width of interior paddings.

The data type of **right\_padding** is double.

This attribute is read-only. You can use **create\_fp\_plan\_group\_padding** to set its value.

**right\_padding\_external**

Specifies right-side width of exterior paddings.

The data type of **right\_padding\_external** is double.

This attribute is read-only. You can use **create\_fp\_plan\_group\_padding** to set its value.

**right\_shielding**

Specifies right-side widths of signal shielding inside a plan group.

The data type of **right\_shielding** is string.

This attribute is read-only. You can use **create\_fp\_block\_shielding** to set its value.

**right\_shielding\_external**

Specifies right-side widths of signal shielding outside a plan group.

The data type of **right\_shielding\_external** is string.

This attribute is read-only. You can use **create\_fp\_block\_shielding** to set its value.

#### target\_utilization

Specified target utilization set on a plan group.

The data type of **target\_utilization** is double.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### top\_padding

Specifies top-side width of interior paddings.

The data type of **top\_padding** is double.

This attribute is read-only. You can use **create\_fp\_plan\_group\_padding** to set its value.

#### top\_padding\_external

Specifies top-side width of exterior paddings.

The data type of **top\_padding\_external** is double.

This attribute is read-only. You can use **create\_fp\_plan\_group\_padding** to set its value.

#### top\_shielding

Specifies top-side widths of signal shielding inside a plan group.

The data type of **top\_shielding** is string.

This attribute is read-only. You can use **create\_fp\_block\_shielding** to set its value.

#### top\_shielding\_external

Specifies top-side widths of signal shielding outside a plan group.

The data type of **top\_shielding\_external** is string.

This attribute is read-only. You can use **create\_fp\_block\_shielding** to set its value.

#### utilization

Specifies the ratio of total area size of associated instances to the area of a plan group.

The data type of **utilization** is double.

This attribute is read-only.

#### odl\_utilization

Specifies the ratio of total area size of associated instances to the area of an ODL plan group.

The data type of **odl\_utilization** is float.

This attribute is read-only.

#### is\_mim

Specifies that a plan group is multiply instantiated module (MIM).

The data type of **is\_mim** is Boolean.

This attribute is read-only.

#### is\_mim\_master\_instance

Specifies that a plan group is a master instance among a set of multiply instantiated modules (MIMs).

The data type of **is\_mim\_master\_instance** is Boolean.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### mim\_master\_name

Specifies the name of the master for a multiply instantiated module (MIM) plan group.

The data type of **mim\_master\_name** is string.

This attribute is read-only.

#### mim\_orientation

Specifies the orientation of a MIM plan group.

The allowable orientations are N, S, FN, FS.

The data type of **mim\_orientation** is string.

This attribute is read-only.

---

## SEE ALSO

[create\\_fp\\_block\\_shielding\(2\)](#)  
[create\\_fp\\_plan\\_group\\_padding\(2\)](#)  
[get\\_attribute\(2\)](#)  
[list\\_attributes\(2\)](#)  
[report\\_attribute\(2\)](#)  
[set\\_attribute\(2\)](#)

## port\_attributes

Contains attributes that can be placed on a port.

## DESCRIPTION

Contains attributes that can be placed on a port.

There are a number of commands used to set attributes. Most attributes, however, can be set with the **set\_attribute** command. If the attribute definition specifies a **set** command, use it to set the attribute. Otherwise, use **set\_attribute**. If an attribute is "read-only," the user cannot set it.

To determine the value of an attribute, use the **get\_attribute** command. To remove attributes, use the **remove\_attribute** command.

For a more detailed explanation of an attribute, refer to the manual pages of the appropriate **set** command. For information on all attributes, refer to the **attributes** manual page.

### Port Attributes

#### bus\_name

If the port is bussed, returns the full hierarchical name of the port bus. This attribute is **read only** and cannot be set by the user.

#### connection\_class

A string that specifies the connection class label to be attached to a port or to a list of ports. **compile**, **insert\_pads**, and **insert\_dft** will connect only those loads and drivers that have the same connection class label. The labels must match those in the library of components for the design, and must be separated by a space. The labels *universal* and *default* are reserved. *universal* indicates that the port can connect with any other load or driver. *default* is assigned to any ports that do not have a connection class already assigned. Set with **set\_connection\_class**.

#### dont\_touch\_network

When a design is optimized, **compile** assigns **dont\_touch** attributes to all cells and nets in the transitive fanout of **dont\_touch\_network** clock objects. The **dont\_touch** assignment stops at the boundary of storage elements. An element is recognized as storage only if it has setup or hold constraints. Set with **set\_dont\_touch\_network**.

#### driven\_by\_logic\_one

Specifies that input ports are driven by logic one. **compile** uses this information to create smaller designs. After optimization, a port connected to logic one usually does not drive anything inside the optimized design. Set with **set\_logic\_one**.

#### driven\_by\_logic\_zero

Specifies that input ports are driven by logic zero. **compile** uses this information to create smaller designs. After optimization, a port connected to logic zero usually does not drive anything inside the optimized design. Set with **set\_logic\_zero**.

#### driving\_cell\_dont\_scale

When *true*, the transition time on the port using the driving cell is not scaled. Otherwise the transition time will be scaled by operating condition factors. Set with **set\_driving\_cell**.

#### driving\_cell\_fall

A string that names a library cell from which to copy fall drive capability to be used in fall transition calculation for the port. Set with **set\_driving\_cell**.

**driving\_cell\_from\_pin\_fall**

A string that names the driving\_cell\_fall input pin to be used to find timing arc fall drive capability. Set with **set\_driving\_cell**.

**driving\_cell\_from\_pin\_rise**

A string that names the driving\_cell\_rise input pin to be used to find timing arc rise drive capability. Set with **set\_driving\_cell**.

**driving\_cell\_library\_fall**

A string that names the library in which to find the **driving\_cell\_fall**. Set with **set\_driving\_cell**.

**driving\_cell\_library\_rise**

A string that names the library in which to find the **driving\_cell\_rise**. Set with **set\_driving\_cell**.

**driving\_cell\_multiply\_by**

A floating point value by which to multiply the transition time of the port marked with this attribute. Set with **set\_driving\_cell**.

**driving\_cell\_pin\_fall**

A string that names the driving\_cell\_fall output pin to be used to find timing arc fall drive capability. Set with **set\_driving\_cell**.

**driving\_cell\_pin\_rise**

A string that names the driving\_cell\_rise output pin to be used to find timing arc rise drive capability. Set with **set\_driving\_cell**.

**driving\_cell\_rise**

A string that names a library cell from which to copy rise drive capability to be used in rise transition calculation for the port. Set with **set\_driving\_cell**.

**fall\_drive**

Specifies the drive value of high to low transition on input or inout ports. Set with **set\_drive**.

**fanout\_load**

Specifies the fanout load on output ports. Set with **set\_fanout\_load**.

**is\_bussed**

Returns true if the port is part of a bussed port. This attribute is **read only** and cannot be set by the user.

**load**

Specifies the load value on ports. The total load on a net is the sum of all the loads on pins, ports, and wires associated with that net. Set with **set\_load**.

**max\_capacitance**

A floating point number that sets the maximum capacitance value for input, output, or bidirectional ports; or for designs. The units must be consistent with those of the technology library used during optimization. Set with **set\_max\_capacitance**.

**max\_fall\_delay**

A floating point value that specifies the maximum falling delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_max\_delay**.

**max\_fanout**

Specifies the maximum fanout load for the net connected to this port. **compile** ensures that the fanout load on this net is less than the specified value. Set with **set\_max\_fanout**.

**max\_rise\_delay**

A floating point value that specifies the maximum rising delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_max\_delay**.

**max\_time\_borrow**

A floating point number that establishes an upper limit for time borrowing; that is, it prevents the use of the entire pulse width for level-sensitive latches. Units are those used in the technology library. Set with **set\_max\_time\_borrow**.

**max\_transition**

Specifies the maximum transition time for the net connected to this port. **compile** ensures that the transition time on this net is less than the specified value. Set with **set\_max\_transition**.

**min\_capacitance**

A floating point number that sets the minimum capacitance value for input or bidirectional ports. The units must be consistent with those of the technology library used during optimization. Set with **set\_min\_capacitance**.

**min\_fall\_delay**

A floating point value that specifies the minimum falling delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_min\_delay**.

**min\_rise\_delay**

A floating point value that specifies the minimum rising delay on ports, clocks, pins, cells, or on paths between such objects. Set with **set\_min\_delay**.

**model\_drive**

A non-negative floating point number that specifies the estimated drive value on ports in terms of standard drives of the current technology library. Set with **set\_model\_drive**.

**model\_load**

A non-negative floating point number that specifies the estimated load value on ports in terms of standard loads of the current technology library. Set with **set\_model\_load**.

**op\_used\_in\_normal\_op**

Specifies that a scan-out port is also used in normal operation (system mode). This attribute is used by the **insert\_dft** command.

**output\_not\_used**

Determines that an output port is unconnected. Used by **compile** to create smaller designs because the logic that drives an unconnected output port might not need to be maintained. After a design with an unconnected output port is compiled, the port is usually not driven by anything inside the design. Set with **set\_unconnected**.

**pad\_location**

A string value that specifies the Xilinx pad location (pin number) to be assigned to a port. Setting a **pad\_location** attribute on a port causes the Synopsys XNF writer to indicate in the XNF netlist that this port has the pad location given by the value of the **pad\_location** attribute. No checks are performed to verify that the specified location is valid; for valid pad locations, refer to the Xilinx *XC4000 Databook*. Set with **set\_attribute**.

**port\_direction**

Returns the direction of a port. The value can be **in**, **out**, **inout**, or **unknown**. This attribute cannot be set by the user. You can also use the **direction** attribute to get the direction of the port.

**rise\_drive**

Specifies the drive value of low to high transition on input or inout ports. Set with **set\_drive**.

**signal\_index**

Used to enumerate different ports with the same signal type (for example, scan-in ports for a design with multiple scan chains). Set with **set\_signal\_type**.

**signal\_type**

Used to indicate that a port is of a "special" type, such as a "clocked\_on\_also" port in a master/slave clocking scheme, or a "test\_scan\_in" pin for scan-test circuitry. Set with **set\_signal\_type**.

#### static\_probability

A floating point number that specifies the percentage of time that the signal is in the logic 1 state. This information is used by **report\_power**. If this attribute is not set, **report\_power** will use the default value of 0.5, indicating that the signal is in the logic 1 state half the time. Set with **set\_switching\_activity**.

#### test\_dont\_fault

If set, ports are not faulted during test pattern generation. If no command options are specified, this attribute is set for both "stuck-at-0" and "stuck-at-1" faults. Set with **set\_test\_dont\_fault**.

#### test\_hold

Specifies a fixed, constant logic value at a port during test generation. Set with **set\_test\_hold**.

#### test\_isolate

Indicates that the specified sequential cells, pins, or ports are to be logically isolated and considered untestable during test design rule checking by **check\_test**. When this attribute is set on a cell, it is also placed on all pins of that cell. Do not set this attribute on a hierarchical cell. Use **report\_test -assertions** for a report on isolated objects. Set with **set\_test\_isolate**.

**Note:** Setting this attribute suppresses the warning messages associated with the isolated objects.

#### toggle\_rate

A positive floating point number that specifies the toggle rate; that is, the number of zero-to-one and one-to-zero transitions within a library time unit period. This information is used by **report\_power**. If this attribute is not set, **report\_power** will use the default value of  $2 * (\text{static\_probability}) (1 - \text{static\_probability})$ . The default will be scaled by any associated clock signal (if one is available). Set with **set\_switching\_activity**.

#### true\_delay\_case\_analysis

Specifies a value to set all or part of an input vector for **report\_timing -true** and **report\_timing -justify**. Allowed values are 0, 1, r (rise, X to 1), and f(fall, X to 0). Set with **set\_true\_delay\_case\_analysis**.

#### is\_diode

Tells if the port is a diode port.

#### is\_bus

Tells if the port is a bus port.

This attribute is read-only and cannot be modified.

#### hold\_uncertainty

Specifies a negative uncertainty from the edges of the ideal clock waveform. Affects all sequential cells in the transitive fanout of this port. Set with **set\_clock\_uncertainty -hold**.

#### setup\_uncertainty

Specifies a positive uncertainty from the edges of the ideal clock waveform. Affects all sequential cells in the transitive fanout of this port. Set with **set\_clock\_uncertainty -setup**.

#### pg\_pin\_weight

A float attribute representing the PG pin weight. It should be between 0.1 and 25.0. And the fraction precision is 0.1, e.g. 0.11 will be cut off as 0.1.

---

## SEE ALSO

`get_attribute(2)`  
`remove_attribute(2)`  
`set_attribute(2)`  
`attributes(3)`

---

## port\_complement\_naming\_style

Defines the convention the **compile** command uses to rename ports complemented as a result of using the **set\_boundary\_optimization** command.

---

### TYPE

string

---

### DEFAULT

%s\_BAR

---

### DESCRIPTION

This variable defines the convention the **compile** command uses to rename ports complemented as a result of using the **set\_boundary\_optimization** command.

The variable string must contain one occurrence of %s (percent s). When **compile** generates a new port name, %s is replaced with the original name of the port. If this does not create a unique port name within the cell, the smallest possible integer that makes the name unique is appended to the end of the name (for example, X\_BAR\_0, X\_BAR\_1, and so on).

To determine the current value of this variable, use the **printvar port\_complement\_naming\_style** command. For a list of all compile variables and their current values, use **print\_variable\_group compile**.

---

### SEE ALSO

`compile(2)`  
`set_boundary_optimization(2)`  
`compile_disable_hierarchical_inverter_opt(3)`

# power\_attributes

Lists the predefined Power Compiler attributes.

## DESCRIPTION

Attributes are properties assigned to objects such as nets, cells, pins and designs, and describe design features to be considered during optimization. A subset of attributes are specific to Power Compiler; they are only available when a Power Compiler license exists.

The Power Compiler attributes are "read-only": they cannot be set by the user. To determine the value of an attribute, use the **get\_attribute** command. For information on all attributes, refer to the **attributes** manual page.

The Power Compiler attributes are grouped into the following categories:

- cell
- pin
- design

Definitions for these attributes are provided in the subsections that follow.

### Cell Attributes

#### is\_clock\_gate

*true* if the cell is a clock gate. If the clock gating logic is encapsulated in a hierarchical clock gate wrapper, this attribute will only return *true* when applied to the hierarchical instance.

#### is\_icg

*true* if the cell is an integrated clock gate (ICG). This attribute can only return *true* when applied to leaf cells. If the ICG cell is encapsulated in a hierarchical clock gate wrapper, this attribute will return *false* when applied to the hierarchical instance.

#### is\_gicg

*true* if the cell is a generic integrated clock gate (GICG). Since GICGs cannot be encapsulated in a hierarchical clock gate wrapper, this attribute can only return *true* when applied to leaf cells.

#### is\_latch\_based\_clock\_gate

*true* if the cell is a latch-based clock gate.

#### is\_latch\_free\_clock\_gate

*true* if the cell is a latch-free clock gate.

#### is\_positive\_edge\_clock\_gate

*true* if the cell is a positive edge clock gate.

#### is\_negative\_edge\_clock\_gate

*true* if the cell is a negative edge clock gate.

#### clock\_gate\_has\_precontrol

*true* if the cell is a clock gate with (pre-latch) control point.

**clock\_gate\_has\_postcontrol**

*true* if the cell is a clock gate with (post-latch) control point.

**clock\_gate\_has\_observation**

*true* if the cell is a clock gate with observation point.

**is\_clock\_gated**

*true* if the cell is a clock gated register or clock gate.

**clock\_gating\_depth**

The number of clock gates on the clock path to this cell; -1 if the cell is not a clock gate or register.

**clock\_gate\_level**

The number of clock gates on the longest clock branch in the fanout of this cell; -1 if not a clock gate.

**clock\_gate\_fanout**

The number of registers and clock gates in the direct fanout of the clock gate; -1 if not a clock gate.

**clock\_gate\_register\_fanout**

The number of registers in the direct fanout of the clock gate; -1 if not a clock gate.

**clock\_gate\_multi\_stage\_fanout**

The number of clock gates in the direct fanout of the clock gate; -1 if not a clock gate.

**clock\_gate\_transitive\_register\_fanout**

The number of register in the transitive fanout of the clock gate; -1 if not a clock gate.

**clock\_gate\_module\_fanout**

The number of modules in the local fanout of the clock gate; -1 if not a clock gate.

**is\_operand\_isolator**

*true* if the cell is an operand isolation cell.

**is\_isolated\_operator**

*true* if the cell is an operator that was isolated with operand isolation.

**operand\_isolation\_style**

Stores the operand isolation style of the isolation cell or isolated operator.

**Pin Attributes****is\_clock\_gate\_enable\_pin**

*true* if the pin is a clock gate enable input.

**is\_clock\_gate\_clock\_pin**

*true* if the pin is a clock gate clock input.

**is\_clock\_gate\_output\_pin**

*true* if the pin is a gated-clock output of a clock gate.

**is\_clock\_gate\_test\_pin**

*true* if the pin is a clock gate scan-enable or test-mode input.

`is_clock_gate_observation_pin`

*true* if the pin is a clock gate observation point.

`is_operand_isolation_control_pin`

*true* if the pin is the control pin of an operand isolation cell.

`is_operand_isolation_data_pin`

*true* if the pin is the data input of an operand isolation cell.

`is_operand_isolation_output_pin`

*true* if the pin is the data output of an operand isolation cell.

## "Design Attributes

`is_clock_gating_design`

*true* if the design is a clock gating design.

`is_clock_gating_observability_design`

*true* if the design is a clock gating observability design.

---

## SEE ALSO

`get_attribute(2)`  
`attributes(3)`

---

## power\_cg\_all\_registers

Specifies to the **insert\_clock\_gating** command whether to clock gate all registers, including those that do not meet the necessary requirements.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable specifies whether to clock gate all registers, including those that do not meet the necessary requirements. If this variable is set to **false** (the default value), registers that do not meet the setup, width, or enable condition are not considered for clock gating unless they are explicitly included with the **set\_clock\_gating\_registers** command. When set to **true**, a redundant clock gate is inserted for these registers. This can be useful for clock tree balancing. If necessary, the redundant clock gates are duplicated to meet the **max\_fanout** constraint. Note that the **minimum\_bitwidth** constraint is not honored for the redundant clock gated registers.

To determine the current value of this variable, use the **printvar power\_cg\_all\_registers** command. For a list of power variables and their current values, use **print\_variable\_group power**.

---

### SEE ALSO

[elaborate\(2\)](#)  
[insert\\_clock\\_gating\(2\)](#)

---

## power\_cg\_auto\_identify

Identifies clock-gating circuitry inserted by Power Compiler from a structural netlist.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When this variable is set to **true**, clock gates inserted by Power Compiler are automatically identified. Identification refers to the process of detecting clock gates and the corresponding gated element association, and setting different attributes on these objects. These attributes enable the subsequent steps in the tool to work efficiently. Set this variable with the **read\_verilog** command before reading the input RTL file.

Clock gate identification is required when a netlist is passed in ASCII format. This is not required if a binary database (such as in .ddc format or MilkyWay) is used to transfer design data between tool invocations.

By using the automatic identification method, each time a command that works on clock-gating circuitry is called, identification is performed. This ensures that the command makes use of the current clock-gating configuration of the design.

In order to be identified, the gate clock must meet the following conditions:

- Be connected to a clock net through its clock pin
- All its gated registers are gated through the clock pin
- All its gated registers are activated by the same edge of the clock

To determine the current value of this variable, use the **printvar power\_cg\_auto\_identify** command.

---

### SEE ALSO

`compile_ultra(2)`  
`identify_clock_gating(2)`  
`insert_clock_gating(2)`

---

## power\_cg\_balance\_stages

Controls whether gate stage balancing is on or off during **compile [-incremental\_mapping] -gate\_clock** or **compile\_ultra [-incremental\_mapping] -gate\_clock**.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable reduces the unevenness in the number of stages of clock gates feeding different register banks. When this variable is set to **true**, the **compile -gate\_clock** or **compile\_ultra -gate\_clock** command reconfigures the different stages of clock gates so that there is exactly the same number of clock gates in each path from the clock root to the clock pin of all gatable register banks. It is necessary to define clocks using the **create\_clock** command for each clock network where clock gates need to be reconfigured.

Only the tool-inserted clock gates and integrated clock gating (ICG) cells are considered during stage balancing.

A clock-gating cell is not modified or removed if it or its parent hierarchical cell is marked as **dont\_touch** with the **set\_dont\_touch** command; it will not be affected by clock gate stage balancing.

To determine the current value of this variable, use the **printvar power\_cg\_balance\_stages** command.

---

### SEE ALSO

[compile\(2\)](#)  
[compile\\_ultra\(2\)](#)  
[report\\_clock\\_gating\(2\)](#)  
[set\\_clock\\_gating\\_style\(2\)](#)  
[power\\_cg\\_reconfig\\_stages\(3\)](#)

---

## power\_cg\_cell\_naming\_style

Specifies the naming style for clock-gating cells created during **insert\_clock\_gating**.

---

### TYPE

string

---

### DEFAULT

""

---

### GROUP

power

---

### DESCRIPTION

This variable determines the way that clock gating cells are named.

This variable must be set before issuing the **insert\_clock\_gating** command.

This variable can contain any string in addition to the tokens listed below. The tokens are replaced by the appropriate value during clock gating and other strings are retained without changes. For example:

```
set power_cg_cell_naming_style \
  "prefix_%c_%e_midfix_%r_%R_%d_suffix"

%c - clock name
%e - immediate enable signal name
%r - first gated register bank name (or module name for module
      clock gates and not applicable for factored clock gates)
%R - all gated register banks sorted alphabetically (not applicable
      for module or factored clock gates)
%d - index for splitting/name clash resolution
```

Only simple (non-hierarchical) names are used for all object names.

If there is no occurrence of "%d" in **power\_cg\_cell\_naming\_style**, the tool assumes a %d at the end. The following are examples of the variable usage:

```
prompt> set power_cg_cell_naming_style "clk_gate_%r_%d
```

```
prompt> set power_cg_cell_naming_style "clock_gate_cell_%c_%r_%d_name"
```

---

## SEE ALSO

[insert\\_clock\\_gating\(2\)](#)  
[power\\_cg\\_gated\\_clock\\_net\\_naming\\_style\(3\)](#)  
[power\\_cg\\_module\\_naming\\_style\(3\)](#)

---

## power\_cg\_derive\_related\_clock

Derives the clock domain relationship between registers from the hierarchical context.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

For latch-free clock gate insertion with the **insert\_clock\_gating** command, the setup condition must be met before a bank can be clock gated. This implies that the enable condition of the bank must be组合ally dependent on nets that are known to be synchronous (such as, belong to the same clock domain) with the registers of the bank that are being clock gated.

The clock domain of nets is determined by the registers within the module (subdesign) that drive the nets and the clock relationship specified for ports with the **set\_input\_delay** command. By default, the clock domain relationship is analyzed within the module. This is to ensure that clock gating on subdesigns is context independent. If a module is instantiated from a design different than the current design, the clock-gating result will still be correct.

If the non-combinational driver (register or top-level port) of an input to a module exists outside of that module, the clock domain of that input is considered unknown and no latch-free clock gating can be performed with enable conditions that depend on that particular input.

The setup condition can be relaxed to perform context specific analysis of the clock domain relationship. This is achieved by setting the **power\_cg\_derive\_related\_clock** variable to **true**. In that case, the clock domain of any net will be derived from the non-combinational drivers in the (hierarchical) fanin of the net.

To determine the current value of this variable, use the **printvar power\_cg\_derive\_related\_clock** command. For a list of power variables and their current values, use **print\_variable\_group power**.

---

### SEE ALSO

**insert\_clock\_gating(2)**  
**set\_clock\_gating\_style(2)**

---

## power\_cg\_enable\_alternative\_algorithm

Specifies to the **insert\_clock\_gating**, **compile-gate\_clock** and **compile\_ultra -gate\_clock** commands whether to use an alternative algorithm to find gateable registers.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

Depending on the design, clock gating can have a long runtime. When set to **true**, **power\_cg\_enable\_alternative\_algorithm** changes the clock gating algorithm. The alternative algorithm that is enabled often reduces the runtime for clock gating, especially for larger designs, but might increase the number of clock gates that are created compared to the default algorithm. The number of gated registers may vary.

To determine the current value of this variable, use the **printvar power\_cg\_enable\_alternative\_algorithm** command.

---

### SEE ALSO

[compile\(2\)](#)  
[compile\\_ultra\(2\)](#)  
[insert\\_clock\\_gating\(2\)](#)

---

## power\_cg\_ext\_feedback\_loop

Controls whether external feedback loops should be used to generate the enable condition for a register with its enable pin tied to logic 1. This variable affects only the **insert\_clock\_gating**, **compile -gate\_clock**, and **compile\_ultra -gate\_clock** commands.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable controls whether external feedback loops should be used to generate the enable condition for a register with its enable pin tied to logic 1.

By default (true), these registers are considered for clock gating by looking for an external feedback loop. If an external feedback loop is found, it is used to generate a valid enable condition for the register.

When this variable is set to false, registers with their enable pin tied to logic 1 are discarded as candidates to be clock gated.

Since this process is done only during the RTL clock gating stage, the effect of this variable is limited to the **insert\_clock\_gating** command or a full run of the **compile -gate\_clock** or **compile\_ultra -gate\_clock** command. Note that this variable has no effect on incremental runs of the **compile** or **compile\_ultra** command.

To determine the current value of this variable, use the **printvar power\_cg\_ext\_feedback\_loop** command.

---

### SEE ALSO

[compile\(2\)](#)  
[compile\\_ultra\(2\)](#)  
[insert\\_clock\\_gating\(2\)](#)

---

## power\_cg\_flatten

Specifies to different **ungroup** commands whether or not to flatten Synopsys clock-gating cells.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable specifies to different **ungroup** commands whether or not to flatten Synopsys clock-gating cells. The list of commands include **ungroup**, **compile -ungroup**, **optimize\_registers -ungroup**, **balance\_registers**, and **ungroup**.

If this variable is set to **false** (the default value), the clock-gating cells are not flattened during any ungroup step. To flatten the clock gating cells, set the value to **true** before using the **ungroup** command or any other ungrouping steps listed above.

In normal usage, ungrouping the clock gates is not recommended. Ungrouping the clock gates before compile could have serious side effects. For example, ungrouped clock gates cannot be mapped to integrated clock-gating cells. Power Compiler commands such as **report\_clock\_gating**, **remove\_clock\_gating**, and **rewire\_clock\_gating** assume that the clock gates have a hierarchy of their own. Also, the tool's placement of clock gates and registers may not be optimal when clock gating cells are flattened. Flattened clock gates are supported when using integrated clock-gating cells, provided the flattening is done only after **compile**.

To determine the current value of this variable, use the **printvar power\_cg\_flatten** command. For a list of power variables and their current values, use **print\_variable\_group power**.

---

### SEE ALSO

**compile(2)**  
**insert\_clock\_gating(2)**  
**set\_clock\_gating\_style(2)**  
**ungroup(2)**

---

## power\_cg\_gated\_clock\_net\_naming\_style

Specifies the naming style for gated clock nets created during **insert\_clock\_gating**.

---

### TYPE

string

---

### DEFAULT

""

---

### GROUP

power

---

### DESCRIPTION

This variable determines the way gated clock nets are named.

This variable must be set before issuing the **insert\_clock\_gating** command.

This variable can contain any string in addition to the different tokens listed below. The tokens are replaced by the appropriate value during clock gating. For example:

```
set power_cg_gated_clock_net_naming_style \
    "prefix_%c_%n_%g_%d_suffix"
```

%c - original clock  
%n - immediate enable signal name  
%g - clock gate (instance) name  
%d - index for splitting/name clash resolution

Only simple (non-hierarchical) names are used for all object names.

If there is no occurrence of "%d" in **power\_cg\_gated\_clock\_net\_naming\_style**, the tool assumes a %d at the end. The following is an example of the variable usage:

```
prompt> set power_cg_gated_clock_net_naming_style "gated_%c_%d"
```

## SEE ALSO

`insert_clock_gating(2)`  
`power_cg_cell_naming_style(3)`  
`power_cg_gated_clock_net_naming_style(3)`  
`power_cg_module_naming_style(3)`

---

## power\_cg\_high\_effort\_enable\_fanin\_analysis

Controls the execution of high effort analysis to rewire the fanin of gated cells during **compile\_ultra [-incremental\_mapping] -gate\_clock**.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable controls the effort level used by **compile\_ultra [-incremental] -gate\_clock** to rewire the fanin of gated cells. The high effort analysis analysis is only performed if the variable **power\_cg\_high\_effort\_enable\_fanin\_analysis** is set to **true**.

This analysis checks if the fanin of the data or enable pin of the gated register, or enable pin of the gated clock-gating cells, can be rewired. Rewiring will change the input logic of a register, or clock-gating cell, given that its gating cell is active. This effects the effort level to avoid having shared logic between the input pins of the registers, or clock-gating cells, and its gating cells. If this rewiring is not possible, then the input logic of the gated cells is not changed. When setting the effort level to high, more runtime is used when performing this analysis.

This analysis, regardless of effort level, will not:

- Cross hierarchical boundaries
- Affect shift registers or multibit registers

Please note that this analysis is only performed upon the gated cells.

To determine the current value of this variable, use the **printvar power\_cg\_high\_effort\_enable\_fanin\_analysis** command.

---

### SEE ALSO

[compile\(2\)](#)  
[compile\\_ultra\(2\)](#)  
[report\\_clock\\_gating\(2\)](#)  
[set\\_clock\\_gating\\_style\(2\)](#)

---

## power\_cg\_ignore\_setup\_condition

Ignores the setup condition for latch-free clock gating.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable ignores the setup condition for latch-free clock gating. For latch-free clock gate insertion with the **insert\_clock\_gating** command, the setup condition must be met before a bank can be clock gated. This implies that the enable condition of the bank must be combinational dependent on nets that are known to be synchronous (belong to the same clock domain) with the registers of the bank that are being clock gated.

The setup condition can be ignored during latch-free clock gating. This is achieved by setting the **power\_cg\_ignore\_setup\_condition** variable to **true**. This is generally not safe, since latch-free clock gating of a bank with an enable that is not synchronous to the registers of that bank can lead to problems on the clock net. In this case it is the responsibility of the designer to ensure that the result after clock gating is functionally correct.

To determine the current value of this variable, use the **printvar power\_cg\_ignore\_setup\_condition** command. For a list of power variables and their current values, use **print\_variable\_group power**.

---

### SEE ALSO

**insert\_clock\_gating(2)**  
**set\_clock\_gating\_style(2)**

---

## power\_cg\_inherit\_timing\_exceptions

Specifies that during **compile -gate\_clock** or **compile\_ultra [-incr] -gate\_clock**, timing exceptions defined on registers must be automatically inferred onto the enable pin of the clock gate that is gating these registers.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

power

---

### DESCRIPTION

If this variable is set before running the **compile -gate\_clock** or **compile\_ultra -gate\_clock**, then clock gate insertion tries to inherit the timing exceptions of the gated registers to the clock gate enable pin. The following conditions apply:

- Only cell level exceptions are inherited. This means that all synchronous pins of a register must have the same set of timing exceptions before this can be inferred onto a clock gate.
- If a set of registers with the same enable conditions has different timing exceptions among them, then this is split into a smaller set of registers with homogeneous exceptions before clock gate insertion. This might create small banks that fall below the minimum bit width specified for clock gating and so they may remain ungated.

---

### SEE ALSO

[compile\(2\)](#)  
[compile\\_ultra\(2\)](#)

---

## power\_cg\_iscgs\_enable

Specifies the use of instance-specific clock-gating style for the **set\_clock\_gating\_style** and **remove\_clock\_gating\_style** commands, and clock gate insertion during compile.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable specifies whether or not to use instance-specific clock-gating style during clock gate insertion, as well as to enable commands or options related to instance-specific clock-gating style. When this variable is set to **true**, instance-specific clock-gating style is enabled.

To determine the current value of this variable, use the **printvar power\_cg\_iscgs\_enable** command.

---

### SEE ALSO

[compile\(2\)](#)  
[compile\\_ultra\(2\)](#)  
[remove\\_clock\\_gating\\_style\(2\)](#)  
[set\\_clock\\_gating\\_style\(2\)](#)

---

## power\_cg\_module\_naming\_style

Specifies the naming style for clock gating modules created during **insert\_clock\_gating**.

---

### TYPE

string

---

### DEFAULT

""

---

### GROUP

power

---

### DESCRIPTION

This variable determines the way clock gate modules (hierarchical designs created for clock gates during **insert\_clock\_gating**) are named.

This variable must be set before issuing the **insert\_clock\_gating** command.

This variable can contain any string in addition to the different tokens listed below. The tokens are replaced by the appropriate value during clock gating, and prefix, midfix, and suffix are examples of any constant strings that can be specified.

```
set power_cg_module_naming_style \
  "prefix_%e_%l_midfix_%p_%t_%d_suffix"

%e - edge type (HIGH/LOW)
%l - library name of ICG cell library (if using ICG cells) or
      concatenated target_library names
%p - immediate parent module name
%t - top module (current design) name
%d - index used to resolve name clash
```

If there is no occurrence of "%d" in **power\_cg\_module\_naming\_style**, the tool assumes a %d at the end. The following are examples of the variable usage:

```
prompt> set power_cg_module_naming_style "SNPS_CLOCK_GATE_%e_%p
prompt> set power_cg_module_naming_style "clock_gate_module_%e_%t_%d
```

---

## SEE ALSO

`insert_clock_gating(2)`  
`power_cg_cell_naming_style(3)`  
`power_cg_gated_clock_net_naming_style(3)`

---

## power\_cg\_permit\_opposite\_edge\_icg

Allows negedge ICGs to gate posedge registers, and posedge ICGs to gate negedge registers during **compile [-incremental\_mapping] -gate\_clock** or **compile\_ultra [-incremental\_mapping] -gate\_clock**.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

Allows negedge ICGs to gate posedge registers, and posedge ICGs to gate negedge registers during **compile\_ultra -gate\_clock** or **compile -gate\_clock**. You can only use this feature if the **power\_cg\_permit\_opposite\_edge\_icg** variable is set to **true** before using the **set\_clock\_gating\_style** command.

This feature is useful when you are restricted from using either posedge or negedge ICGs. Cell selection might be restricted because the appropriate cell is not in your target library or your cells are constrained by a **dont\_use** attribute.

This transformation is ensured by adding an inverter in the fan-in and another one in the fan-out of the ICG.

---

### SEE ALSO

[compile\(2\)](#)  
[compile\\_ultra\(2\)](#)  
[report\\_clock\\_gating\(2\)](#)  
[set\\_clock\\_gating\\_style\(2\)](#)  
[set\\_dont\\_use\(2\)](#)

---

## power\_cg\_physically\_aware\_cg

Enables the restructuring of the integrated clock-gating cell and the registers in the Synopsys physical guidance flow to provide better convergence on clock gating timing paths against postCTS results.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

Set this variable to true to enable the restructuring of the integrated clock-gating cell and the registers in the Synopsys physical guidance flow to provide better convergence on clock gating timing paths against postCTS results. Enabling this setting can degrade power and is hence recommended only if clock gating timing paths are expected to become critical during CTS.

The tool restructures the connection between the integrated clock-gating cell and the registers that it drives so that each clock-gating cell is physically close to the registers gated by the clock-gating cell.

Right before the restructuring process, and independent of the current setting of the variable **power\_cg\_auto\_identify**, clock gating identification is performed.

Clock gates with high fanouts are split according to physical location of their gated registers. This placement is maintained throughout the implementation flow.

During the split operation, the user defined integrated clock-gating cell, specified by the **set\_clock\_gating\_style** command, could be replaced by a better cell based on drive-strength characteristics. To prevent the using specific integrated clock-gating exclude them with the **set\_dont\_use -power** command.

To determine the current value of this variable, use the **printvar power\_cg\_physically\_aware\_cg** command. For a list of power variables and their current values, use the **print\_variable\_group power** command.

When this variable is enabled, the annotation of latency values from the **set\_clock\_gate\_latency** command is disabled and the **apply\_clock\_gate\_latency** command is also disabled.

---

### SEE ALSO

[apply\\_clock\\_gate\\_latency\(2\)](#)  
[compile\\_ultra\(2\)](#)  
[set\\_clock\\_gate\\_latency\(2\)](#)



---

## power\_cg\_print\_enable\_conditions

Reports the enable conditions of registers and clock gates during clock gate insertion.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable prints the enable conditions of clock gates and registers when performing automatic RTL clock gate insertion with the **insert\_clock\_gating** command. The report is useful for debugging purposes and to achieve a better understanding of the design structure and functionality.

The enable condition of a register or clock gate is a combinational function of nets in the design. As such, enable conditions can be represented by Boolean expressions of nets. The enable condition of a register represents the states for which a clock signal must be passed to the register. The enable condition of a clock gate corresponds to the states for which a clock will be passed to the registers in the fanout of the clock gate. The tool utilizes the enable condition of the registers for clock gate insertion.

To enable reporting of the enable conditions during clock gating, set **power\_cg\_print\_enable\_conditions** to **true** before issuing the **insert\_clock\_gating** command.

To determine the current value of this variable, use the **printvar power\_cg\_print\_enable\_conditions** command. For a list of power variables and their current values, use **print\_variable\_group power**.

---

### SEE ALSO

[insert\\_clock\\_gating\(2\)](#)  
[power\\_cg\\_print\\_enable\\_conditions\\_max\\_terms\(3\)](#)

---

## **power\_cg\_print\_enable\_conditions\_max\_terms**

Specifies the maximum number of product terms to be reported in the sum of product expansion of the enable condition.

---

### **TYPE**

integer

---

### **DEFAULT**

10

---

### **DESCRIPTION**

This variable specifies the maximum number of product terms to be reported in the sum of product expansion of the enable condition. For debugging purposes and to achieve a better understanding of the design structure and functionality it can be useful to print the enable conditions of clock gates and registers when performing automatic RTL clock gate insertion with the **insert\_clock\_gating** command.

The enable conditions are reported as a sum of product expression. Since for complex expressions such a representation is known to grow very large, the maximum number of product terms is limited by the **power\_cg\_print\_enable\_conditions\_max\_terms** variable. By default, at most 10 product terms are printed. If the actual number of product terms exceeds this limit, the enable condition is reported as "?? (too many product terms)". If necessary, the number of product terms to be shown can be increased by setting **power\_cg\_print\_enable\_conditions\_max\_terms** to a larger value.

To determine the current value of this variable, use the **printvar power\_cg\_print\_enable\_conditions\_max\_terms** command. For a list of power variables and their current values, use **print\_variable\_group power**.

---

### **SEE ALSO**

[insert\\_clock\\_gating\(2\)](#)  
[power\\_cg\\_print\\_enable\\_conditions\(3\)](#)

---

## power\_cg\_reconfig\_stages

Controls the reconfiguration of multistage clock gates during **compile [-incremental\_mapping] -gate\_clock** or **compile\_ultra [-incremental\_mapping] -gate\_clock**.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable controls whether reconfigurations are performed during **compile\_ultra -gate\_clock** or **compile -gate\_clock**. The reconfigurations are performed only if the **power\_cg\_reconfig\_stages** variable is set to **true**.

Multistage reconfiguration involves the addition or reduction of stages of clock gates. You specify the maximum permissible number of stages of clock gates in the design using the **set\_clock\_gating\_style -num\_stages** command. A clock gate stage is added when a common enable condition can be factored out of many clock gates without violating the maximum stages specified. A clock gate stage is reduced if the design has more stages than what is specified.

Also, it is necessary to define clocks using the **create\_clock** command for each clock network where clock gates need to be reconfigured.

Only the tool-inserted clock gates and integratedclock-gating (ICG) cells can be reconfigured.

A clock-gating cell is not modified or removed if it or its parent hierarchical cell is marked **dont\_touch** with the **set\_dont\_touch** command; it will not be affected by multistage reconfiguration.

To determine the current value of this variable, use the **printvar power\_cg\_reconfig\_stages** command.

---

### SEE ALSO

[compile\(2\)](#)  
[compile\\_ultra\(2\)](#)  
[report\\_clock\\_gating\(2\)](#)  
[set\\_clock\\_gating\\_style\(2\)](#)  
[power\\_cg\\_balance\\_stages\(3\)](#)



---

## **power\_clock\_network\_include\_register\_clock\_pin\_power**

Indicates whether the register clock pin power is included when reporting **clock\_network** power.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

This variable affects the power report for the predefined **clock\_network** and **register** power groups. When set to **true**, the internal power of registers caused by the toggling of register clock pin is included as **clock\_network** power and excluded from **register** power. When set to **false**, the power is included as **register** power and excluded from **clock\_network** power.

---

### **SEE ALSO**

[report\\_power\(2\)](#)

---

## power\_default\_static\_probability

Specifies the default static probability value.

---

### TYPE

float

---

### DEFAULT

0.5

---

### DESCRIPTION

The following variables are used to determine the switching activity of non-user annotated nets that are driven by primary inputs or black box cells:

**power\_default\_static\_probability**  
**power\_default\_toggle\_rate**  
**power\_default\_toggle\_rate\_type**

For other unannotated nets, the tool propagates the switching activities of the driving cell inputs based on the cell functionality to derive the switching activity required for power calculations. This mechanism cannot be used for primary inputs and black box outputs. Instead, the following values are used for these types of nets:

- User annotated values are used, even when the net is partially annotated (for example, the static probability is annotated, but the toggle rate is not).
- In some cases, unannotated switching activity values may still be accurately derived; for example, if the net drives a buffer cell and the output of this cell is user annotated, then the user annotated values are used as the default values. Also, if the input is a clock, then the clock period and waveform are used to derive the switching activity values.
- If the static probability is not annotated, then the value of the **power\_default\_static\_probability** variable is used for the static probability value.
- If the toggle rate is not annotated, then the default toggle rate value is derived from the **power\_default\_toggle\_rate\_type** and **power\_default\_toggle\_rate** values. If the value of the **power\_default\_toggle\_rate\_type** variable is **fastest\_clock** then the toggle rate value is

$dtr * fclk$

where  $fclk$  is the frequency of the related clock if specified by the **set\_switching\_activity** command, or the frequency of the fastest clock in the design. If the design has no clocks, then a value of 1.0 is used for  $fclk$ , and  $dtr$  is the value of the **power\_default\_toggle\_rate** variable.

- If the value of **power\_default\_toggle\_rate\_type** is **absolute**, then the value of the **power\_default\_toggle\_rate** variable is used as the toggle rate.

The value of **power\_default\_static\_probability** must be between 0.0 and 1.0, both inclusive. The value of **power\_default\_toggle\_rate** must be greater or equal to 0.0. Also, if the value of **power\_default\_static\_probability** is 0.0 or 1.0, then the value of **power\_default\_toggle\_rate** must be 0.0. If the value of **power\_default\_toggle\_rate** is 0.0, then the value of **power\_default\_static\_probability** must be either 0.0 or 1.0.

The default value of **power\_default\_toggle\_rate** is 0.1. The default value of **power\_default\_static\_probability** is 0.5. The value of **power\_default\_toggle\_rate\_type** can be either **fastest\_clock** or **absolute**. The default value is **fastest\_clock**.

---

## SEE ALSO

`set_switching_activity(2)`  
`power_default_toggle_rate(3)`  
`power_default_toggle_rate_type(3)`

---

## power\_default\_toggle\_rate

Specifies the default toggle rate value.

---

### TYPE

float

---

### DEFAULT

0.1

---

### DESCRIPTION

The following variables are used to determine the switching activity of non-user annotated nets that are driven by primary inputs or black box cells:

**power\_default\_static\_probability**  
**power\_default\_toggle\_rate**  
**power\_default\_toggle\_rate\_type**

For other unannotated nets, the tool propagates the switching activities of the driving cell inputs based on the cell functionality to derive the switching activity required for power calculations. This mechanism cannot be used for primary inputs and black box outputs. Instead, the following values are used for these types of nets:

- User annotated values are used, even when the net is partially annotated (for example, the static probability is annotated, but the toggle rate is not).
- In some cases, unannotated switching activity values may still be accurately derived; for example, if the net drives a buffer cell and the output of this cell is user annotated, then the user annotated values are used as the default values. Also, if the input is a clock, then the clock period and waveform are used to derive the switching activity values.
- If the static probability is not annotated then the value of the **power\_default\_static\_probability** variable is used for the static probability value.
- If the toggle rate is not annotated, then the default toggle rate value is derived from the **power\_default\_toggle\_rate\_type** and **power\_default\_toggle\_rate** values. If the value of the **power\_default\_toggle\_rate\_type** variable is **fastest\_clock** then the following is used for the toggle rate value:

$dtr * fclk$

where  $fclk$  is the frequency of the related clock if specified by the **set\_switching\_activity** command, or the frequency of the fastest clock in the design. If the design has no clocks, then a value of 1.0 is used for  $fclk$ , and  $dtr$  is the value of the **power\_default\_toggle\_rate** variable.

- If the value of **power\_default\_toggle\_rate\_type** is **absolute**, then the value of the **power\_default\_toggle\_rate** variable is used as the toggle rate.

The value of **power\_default\_static\_probability** must be between 0.0 and 1.0, both inclusive. The value of **power\_default\_toggle\_rate** must be greater or equal to 0.0. Also, if the value of **power\_default\_static\_probability** is 0.0 or 1.0, then the value of **power\_default\_toggle\_rate** must be 0.0. If the value of **power\_default\_toggle\_rate** is 0.0, then the value of **power\_default\_static\_probability** must be either 0.0 or 1.0.

The default value of **power\_default\_toggle\_rate** is 0.1. The default value of **power\_default\_static\_probability** is 0.5. The value of **power\_default\_toggle\_rate\_type** can be either **fastest\_clock** or **absolute**. The default value is **fastest\_clock**.

---

## SEE ALSO

[set\\_switching\\_activity\(2\)](#)  
[power\\_default\\_static\\_probability\(3\)](#)  
[power\\_default\\_toggle\\_rate\\_type\(3\)](#)

---

## power\_default\_toggle\_rate\_type

Specifies the default toggle rate type.

---

### TYPE

string

---

### DEFAULT

fastest\_clock

---

### DESCRIPTION

The following variables are used to determine the switching activity of non-user annotated nets that are driven by primary inputs or black box cells:

power\_default\_static\_probability  
power\_default\_toggle\_rate  
power\_default\_toggle\_rate\_type

For other unannotated nets, the tool propagates the switching activities of the driving cell inputs based on the cell functionality to derive the switching activity required for power calculations. This mechanism cannot be used for primary inputs and black box outputs. Instead, the following values are used for these types of nets:

- User annotated values are used, even when the net is partially annotated (for example, the static probability is annotated, but the toggle rate is not).
- In some cases, unannotated switching activity values may still be accurately derived; for example, if the net drives a buffer cell and the output of this cell is user annotated, then the user annotated values are used as the default values. Also, if the input is a clock, then the clock period and waveform are used to derive the switching activity values.
- If the static probability is not annotated, then the value of the **power\_default\_static\_probability** variable is used for the static probability value.
- If the toggle rate is not annotated, then the default toggle rate value is derived from the **power\_default\_toggle\_rate\_type** and **power\_default\_toggle\_rate** values. If the value of the **power\_default\_toggle\_rate\_type** variable is **fastest\_clock**, then the following is used for the toggle rate value:

dtr \* fclk

where fclk is the frequency of the related clock if specified by the **set\_switching\_activity** command, or the frequency of the fastest clock in the design. If the design has no clocks, then a value of 1.0 is used for fclk, and dtr is the value of the **power\_default\_toggle\_rate** variable.

- If the value of **power\_default\_toggle\_rate\_type** is **absolute**, then the value of the **power\_default\_toggle\_rate** variable is used as the toggle rate.

The value of **power\_default\_static\_probability** must be between 0.0 and 1.0, both inclusive. The value of **power\_default\_toggle\_rate** must be greater or equal to 0.0. Also, if the value of **power\_default\_static\_probability** is 0.0 or 1.0, then the value of **power\_default\_toggle\_rate** must be 0.0. If the value of **power\_default\_toggle\_rate** is 0.0, then the value of **power\_default\_static\_probability** must be either 0.0 or 1.0.

The default value of **power\_default\_toggle\_rate** variable is 0.1. The default value of **power\_default\_static\_probability** variable is 0.5. The value of **power\_default\_toggle\_rate\_type** can be either **fastest\_clock** or **absolute**. The default value is **fastest\_clock**.

---

## SEE ALSO

`set_switching_activity(2)`  
`power_default_static_probability(3)`  
`power_default_toggle_rate(3)`

---

## power\_do\_not\_size\_icg\_cells

Controls whether **compile** does not size the integrated clock-gating cells in a design to correct DRC violations because doing so may result in lower area and power.

---

### TYPE

Boolean

---

### DEFAULT

true in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

When this variable is set to **true**, **compile** does not size the integrated clock-gating cells in the design to correct DRC violations, because doing so may result in lower area and power when the integrated clock-gating cell is the last element in the clock tree and drives all gated registers.

If the clock tree synthesis (CTS) tool inserts buffers after the clock gating, the fanout of the integrated clock-gating cell is limited to the clock-tree buffers. While running **compile** before performing clock tree synthesis, this information is not available in the design. If you set **power\_do\_not\_size\_icg\_cells** to **true**, **compile** ignores DRC violations for the integrated clock-gating cells, because the CTS tool would insert buffers at the output of the cell. Once your design netlist has CTS buffers, you can set this variable to **false** to enable **compile** to fix any DRC violation still existing for the integrated clock-gating cell.

To determine the current value of this variable, use the **printvar power\_do\_not\_size\_icg\_cells** command. For a list of power variables and their current values, use **print\_variable\_group power**.

---

### SEE ALSO

[compile\(2\)](#)  
[elaborate\(2\)](#)  
[set\\_clock\\_gating\\_style\(2\)](#)

---

## power\_domain\_attributes

Describes the attributes related to power domains.

---

### DESCRIPTION

Describes the attributes related to power domains. These attributes are defined only in UPF mode.

You can use the **get\_attribute** command to determine value of an attribute, and use the **report\_attribute** command to get a report of all attributes on a specified power domain. To see all power domain attributes, use the **list\_attribute -class power\_domain -application** command.

#### Power Domain Attributes

cell\_id

Specifies Milkyway design ID in which a power domain object is located.

This attribute is read-only.

name

Specifies name of a power domain object.

This attribute is read-only.

full\_name

Specifies full name of a power domain object.

This attribute is read-only.

object\_class

Specifies object class name of a power domain object, which is **power\_domain**.

This attribute is read-only.

object\_id

Specifies object ID in Milkyway design file.

This attribute is read-only.

within\_block\_abstraction

Specifies whether the power domain is part of the block abstraction.

The data type of **within\_block\_abstraction** is Boolean.

This attribute is read-only and cannot be modified.

within\_ilm

Specifies whether the power domain is part of an ILM.

The data type of **within\_ilm** is Boolean.

This attribute is read-only and cannot be modified.

---

## SEE ALSO

`get_attribute(2)`  
`list_attributes(2)`  
`report_attribute(2)`

---

## power\_enable\_clock\_scaling

Enables or disables clock scaling for power analysis in Design Compiler.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When set to **true**, this variable enables Design Compiler to scale dynamic power number according to clock frequencies specified in the SDC and the **set\_power\_clock\_scaling** command.

For the current value of this variable, type the following command:

```
printvar power_enable_clock_scaling
```

---

### SEE ALSO

**set\_power\_clock\_scaling(2)**  
**printvar(2)**

---

## power\_enable\_datapath\_gating

Enables or disables datapath gating technique for a design.

---

### TYPE

Boolean

---

### DEFAULT

true in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable enables or disables datapath gating, which is a dynamic power optimization technique for a design. By default, this variable is **true** which enables datapath gating. To disable datapath gating, set this variable to **false**.

Datapath gating inserts isolation cells for operators that have Synopsys low-power DesignWare architectures present in the synthetic library files. Datapath gating is also performed on all datapath blocks extracted during the High Level Optimization step. For datapath gating, the tool always uses the adaptive gating style.

This control only takes effect when minpower optimization flow is turned on. See **power\_enable\_minpower** for details.

To determine the current value of this variable, do the following:

```
prompt> printvar power_enable_datapath_gating.
```

For a list of power variables and their current values, type **print\_variable\_group power**.

---

### SEE ALSO

`set_datapath_gating_options(2)`  
`power_enable_minpower(3)`

---

## power\_enable\_minpower

Enable/disable minpower optimization flow.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable can be used to enable or disable minpower optimization flow, which will leverage many power optimization techniques or use power optimized implementations for synthetic parts. By default this variable is **false** which disables minpower flow. To enable minpower flow, set this variable to **true**.

Historically minpower optimization flow is controlled by inserting or removing **dw\_minpower.sldb** to/from **synthetic\_library** and **link\_library**. Since 2019.03 release this control is replaced by **power\_enable\_minpower** variable.

To determine the current value of this variable, use the **printvar power\_enable\_minpower** command.

---

### SEE ALSO

[power\\_enable\\_datapath\\_gating\(3\)](#)

---

## power\_enable\_one\_pass\_power\_gating

Enables the one-pass flow power gating. This variable is for use only in non-UPF mode.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable enables one-pass flow power gating when set to **true**. One-pass flow eliminates the need for an incremental compile, and simplifies the user interface.

The following are examples of the original power-gating flow and the one-pass flow:

- Original power-gating flow:

```
prompt> set_power_gating_style -type CLK_FREE \
           [get_cells lev1b_inst/*reg*]

prompt> set_power_gating_signal -power_pin_index 1 \
           [get_pin lev1b_inst/retain]

prompt> set_power_gating_signal -power_pin_index 2 \
           [get_pin lev1b_inst/shutdown]

prompt> set power_enable_power_gating true

prompt> compile

prompt> hookup_power_gating_ports

prompt> compile -incr

prompt> write -format verilog -hierarchy -output post_compile.v
```

- One-pass power-gating flow:

```
prompt> set_power_gating_style -type CLK_FREE \
```

```
[get_cells lev1b_inst/*reg*]

prompt> set_power_gating_signal -power_pin_index 1 \
[get_pin lev1b_inst/retain]

prompt> set_power_gating_signal -power_pin_index 2 \
[get_pin lev1b_inst/shutdown]

prompt> set power_enable_one_pass_power_gating true

prompt> hookup_power_gating_ports -port_naming_style \
{lev1a_inst/retain lev1a_inst/shutdown} \
-default_port_naming_style power_pin_%d

prompt> compile

prompt> write -format verilog -hierarchy -output post_compile.v
```

---

## SEE ALSO

---

## power\_enable\_power\_gating

Enables the power-gating flow that allows the selected retention registers from the target library to be used to map sequential elements. This variable can be used only in non-UPF mode. In UPF mode, use UPF commands to enable the power-gating flow.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### GROUP

power

---

### DESCRIPTION

The **power\_enable\_power\_gating** variable enables and disables the power gating flow during **compile** and **physopt** command activity.

Retention registers are the registers that can save the values of the registers and restore them later. Retention registers might have different styles. The **power\_gating\_cell** cell-level attributes in target libraries are used to specify the styles.

To allow only the retention registers with certain types used for the specified sequential elements during **compile**, set the **power\_enable\_power\_gating** variable to **true**.

The command requires a Power Compiler license during **compile**, otherwise Design Compiler cannot handle retention registers correctly. If the variable is **true**, it also prevents the **compile** and **physopt** commands from swapping the retention registers back to regular sequential elements.

---

### SEE ALSO

[compile\(2\)](#)



---

## power\_fix\_sdpd\_annotation

Specifies whether user-annotated SDPD switching activity annotation is corrected before it is used.

---

### TYPE

Boolean

---

### DEFAULT

true in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies whether the tool modifies the user-annotated state-dependent and/or path-dependent (SDPD) switching activity to fix any inconsistencies before they are used. The accuracy of switching activity annotation, including the SDPD annotation, affects the accuracy of power calculation, and when this variable is set the tool checks the SDPD annotation for inconsistencies. The SDPD annotation is automatically modified to fix any inconsistencies found.

In most cases, some inconsistencies are created during normal switching activity flows, and the SDPD fixing step modifies the SDPD annotation slightly to improve the power estimation accuracy. For example, during SAIF generation using a simulator, the total of rise and fall toggle on a pin may be different, when perhaps an odd number of toggles are captured. In this case, the SDPD fixing step scales the SDPD toggle rate annotations so that the rise and fall totals are the same.

Setting this variable to **false** disables the SDPD fixing step.

Setting the **power\_fix\_sdpd\_annotation\_verbose** variable to **true** makes the SDPD fixing step issue verbose messages when user annotated switching activity is modified.

The following checks and modifications are performed during the SDPD fixing step:

- False states (states that always evaluate to 0, including the default state on cells whose other states cover all possible states) with non-zero state-dependent (SD) static probabilities have their static probability set to 0.0.
- Unannotated false states on cells with partially annotated SD static probabilities are automatically annotated with 0.0.
- Cells with fully annotated SD static probabilities have their static probabilities scaled so that they add up to 1.0.
- Cells with partially annotated SD static probabilities that add up to more than 1.0 have their static probabilities scaled down so that they add up to 1.0. On such cells, an SD static probability of 0.0 is set on the unannotated states.
- False states and arcs with non-zero state-dependent and/or path-dependent (SDPD) toggle rates have their toggle rate set to 0.0.
- Unannotated false states/arcs on pins with partially annotated SDPD toggle rates are automatically annotated with 0.0.

- Pins with fully annotated SDPD toggle rates have their toggle rates scaled so that they add up to the non-SDPD toggle rate of the pin (that is, the non-SDPD toggle rate on the net connected to the pin).
- Pins with partially annotated SDPD toggle rates that add up to more than the pin toggle rate have their SDPD toggle rates scaled down so that they add up to the non-SDPD toggle rate. On such pins, an SDPD toggle rate of 0.0 is set on the unannotated states and arcs.
- Pins with partially annotated SDPD toggle rates have their toggle rates scaled so that the totals of rise and fall SDPD toggle rates are equal.
- The sum of the SDPD toggle rates on pins with fully annotated SDPD toggle rate information is annotated as the non-SDPD pin toggle rate (that is, the total toggle rate of the net connected to the pin) if this was not previously annotated.

---

## SEE ALSO

`power_fix_sdpd_annotation_verbose(3)`  
`power_sdpd_message_tolerance(3)`

---

## power\_fix\_sdpd\_annotation\_verbose

Specifies whether verbose messages are reported during the fixing of user-annotated SDPD switching activity.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

When this variable is set to **true**, an information or warning message is reported for every modification (exceeding a tolerance criteria) to the user-annotated SDPD switching activity performed by the SDPD fixing step. The SDPD fixing step is enabled by the **power\_fix\_sdpd\_annotation** variable. See the man page for **power\_fix\_sdpd\_annotation** for more information on this step.

By default, the **power\_fix\_sdpd\_annotation\_verbose** verbose messages are not reported and a single message indicating that SDPD annotation is being modified is reported instead. Whether this variable is set to **true** or not, SDPD fixing messages are only reported if they exceed the tolerance criteria specified by the **power\_sdpd\_message\_tolerance** variable.

---

### SEE ALSO

[power\\_fix\\_sdpd\\_annotation\(3\)](#)  
[power\\_sdpd\\_message\\_tolerance\(3\)](#)

---

## power\_hdlc\_do\_not\_split\_cg\_cells

Specifies that the **insert\_clock\_gating** command will not split clock-gating cells to limit their fanout.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable, when set to **true** specifies that the **insert\_clock\_gating** command will not split clock-gating cells to limit their fanout. By default, **insert\_clock\_gating** splits clock-gating cells to limit their fanout. This activity is based on the value specified by the **set\_clock\_gating\_style -max\_fanout** command, whose default is unlimited. When **true**, **insert\_clock\_gating** does not split clock-gating cells, resulting in a netlist where all registers are gated by a single clock-gating cell if they share the same enable signal. Also, **insert\_clock\_gating** does not honor the value specified by **set\_clock\_gating\_style -max\_fanout**.

Set the variable to **true** if your clock-tree synthesis (CTS) tool inserts buffers after the clock-gating cell. In this case, the fanout of the clock-gating cell is limited to the buffers inserted by the CTS tool. This information is not available in the design while the **insert\_clock\_gating** command is performing RTL clock gating. When you set this variable to **true**, **insert\_clock\_gating** does not split the load of the clock-gating cells (by duplicating the cells) to save area and power.

To determine the current value of this variable, use the **printvar power\_hdlc\_do\_not\_split\_cg\_cells** command. For a list of power variables and their current values, use **print\_variable\_group power**.

---

### SEE ALSO

**compile(2)**  
**insert\_clock\_gating(2)**  
**set\_clock\_gating\_style(2)**

---

## power\_keep\_license\_after\_power\_commands

Affects the amount of time a Power Compiler license is checked out during a shell session.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable affects the amount of time a Power Compiler license is checked out during a shell session.

When set to **true**, a Power Compiler license that is checked out remains checked out throughout the shell session. When this variable is set to **false** (the default value), the Power Compiler license remains checked out only as long as a command is using it, and at the completion of the command, the license is released.

To determine the current value of this variable, use the **printvar power\_keep\_license\_after\_power\_commands** command.

---

### SEE ALSO

[report\\_power\(2\)](#)

---

## power\_lib2saif\_rise\_fall\_pd

Specifies whether the **lib2saif** generates forward SAIF files with directives to generate rise and fall dependent path-dependent toggle counts.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

When this variable is set to **true**, the **lib2saif** command generates forward SAIF files with directives to generate separate rise and fall values for non-state-dependent path-dependent toggle counts.

When this variable is set to **false**, directives to generate just the total of the rise and fall values for non-state-dependent path-dependent toggle counts are generated.

For more accurate power calculations, use separate rise and fall toggle counts; however, older simulators and simulation interfaces may not recognize such directives and will fail to read the library forward SAIF file. The Synopsys SAIF generation PLI utility provided with Power Compiler X-2005.09 supports directives for separate rise and fall values for path-dependent toggle rates, but older versions of the utility do not.

Note that this variable affects only directives for path-dependent toggle counts that are not state-dependent. Whether this variable is set to true or false, directives for separate rise and fall values are generated for state-dependent and both state and path-dependent toggle counts.

---

### SEE ALSO

[lib2saif\(2\)](#)

---

## power\_low\_power\_placement

Enables low-power placement during compile, which places cells closer together when they have high switching activity.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable, when set to **true**, enables low-power placement during a compile operation using the **compile\_ultra -spg** command. Low-power placement assigns a higher cost to nets with high switching activity, so that the placer places cells closer together when they are connected by such nets. This tends to reduce the total switching power of the design.

To be effective, you should annotate switching activity information on the netlist using the **read\_saif** command before the compile operation. If the netlist is partially annotated, the tool performs switching activity propagation to estimate switching activity on all nets and pins of the design, before low-power placement.

Low-power placement is a dynamic power reduction technique that uses advanced placement features only available in the **-spg** mode of the **compile\_ultra** command. To enable and use low-power placement:

- Set the **power\_low\_power\_placement** variable to **true**
- Enable dynamic power optimization. In a multicorner-multimode design, use the **set\_scenario\_options -dynamic\_power true** command. In a non-multicorner-multimode design, use **set\_dynamic\_optimization true** command.
- Use physical guidance during optimization, **compile\_ultra -spg**

---

### SEE ALSO

**set\_dynamic\_optimization(2)**  
**set\_scenario\_options(2)**  
**compile\_ultra(2)**

---

## power\_min\_internal\_power\_threshold

Specifies the minimum cell internal power value that can be used in power calculations.

---

### TYPE

string

---

### DEFAULT

"" in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

The value of this variable specifies the minimum threshold used for the cell internal power value. Internal power values are computed using the cell's switching activity and internal power characterization. If this variable has a numeric value and a cell's computed internal power is less than the variable's value, then the variable's value is used instead.

This variable has an effect only if it has a numeric value. The default value of this variable is "", which is non-numeric and so specifies that no minimum threshold is used on the cell internal power.

In general, this variable should not be used, since the internal power characterization specifies the correct internal power values.

---

### SEE ALSO

[report\\_power\(2\)](#)

---

## power\_model\_preference

Specifies the preference between the CCS power and the NLPM models in library cells that have power specified in both models.

---

### TYPE

string

---

### DEFAULT

nlpm in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

A library can contain CCS power, NLPM, or both types of data within a cell definition. This variable specifies the power model preference if the library contains both NLPM and CCS power data.

Allowed values are as follows:

**ccs** instructs Power Compiler to use CCS power data in the library (if present) to calculate both static and dynamic power. If CCS power data is not found, Power Compiler uses NLPM data.

**nlpm** (the default) instructs Power Compiler to use NLPM data. If NLPM data is not found, Power Compiler uses CCS power data.

If neither CCS power nor NLPM data is found for a cell in the library, this cell is not characterized for power analysis.

---

### SEE ALSO

[report\\_power\(2\)](#)

---

## power\_opto\_extra\_high\_dynamic\_power\_effort

This variable is **obsolete**. Previous usage: Instructs the **compile** command to invoke more dynamic power optimization algorithms.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### GROUP

power

---

### DESCRIPTION

This variable is obsolete. For dynamic power optimization, use the **set\_dynamic\_optimization true** in non-MCMM designs or **set\_scenario\_options -dynamic true** in MCMM designs. In both cases, you can also use **set power\_low\_power\_placement true** to enable low power placement.

---

### SEE ALSO

[set\\_dynamic\\_optimization\(2\)](#)  
[set\\_scenario\\_options\(2\)](#)  
[power\\_low\\_power\\_placement\(3\)](#)

---

## power\_rclock\_inputs\_use\_clocks\_fanout

Specifies whether clock network objects in an input port fanout are used to infer the input port's related clock.

---

### TYPE

Boolean

---

### DEFAULT

true in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable is used during related clock inference to decide whether the inferred related clock on a design port is chosen to be the fastest clock whose clock network objects are in the port's transitive fanout. For example, when this variable is set to **true** (the default), if the transitive fanout of an input port contains a number of cells, the fastest clock on these flip-flop cells is chosen as the inferred related clock on the input port. When the variable is set to **false**, the input port will not have an inferred related clock.

For more information on the mechanism used to infer related clock information, see the **propagate\_switching\_activity** command man page.

---

### SEE ALSO

[propagate\\_switching\\_activity\(2\)](#)  
[power\\_rclock\\_unrelated\\_use\\_fastest\(3\)](#)  
[power\\_rclock\\_use\\_asynch\\_inputs\(3\)](#)

---

## power\_rclock\_unrelated\_use\_fastest

Specifies whether the fastest clock is set as the related clock of a design object when a related clock is not inferred by the related clock inference mechanism.

---

### TYPE

Boolean

---

### DEFAULT

true in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable is used during the last stage of related clock inference to decide whether or not the design objects that do not have an inferred related clock will be set as a related clock.

You can use the **set\_switching\_activity** command with the **-clock "\*" argument** to specify that the tool will automatically infer the related clocks for any specified objects. If the related clock inference mechanism did not infer a related clock for a number of such objects, then when the value of the **power\_rclock\_unrelated\_use\_fastest** is **true**, the tool will set the fastest design clock as the objects' related clock. When the variable is set to **false**, such objects will not have a related clock.

For more information on the mechanism used to infer related clock information, see the **propagate\_switching\_activity** command man page.

---

### SEE ALSO

[propagate\\_switching\\_activity\(2\)](#)  
[power\\_rclock\\_inputs\\_use\\_clocks\\_fanout\(3\)](#)  
[power\\_rclock\\_use\\_asynch\\_inputs\(3\)](#)

---

## power\_rclock\_use\_asynch\_inputs

Specifies whether the inferred related clock on an asynchronous pin of a flip-flop is used to determine the inferred related clock on the cell's outputs.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable is used during related clock inference to decide whether the inferred related clock on a flip-flop cell output considers the inferred related clocks on the cell's asynchronous inputs.

When this variable is set to **false**, the inferred related clock on a flip-flop cell output is the inferred related clock on the cell's clock pin. When this variable is set to **true**, the inferred related clock on a flip-flop cell output is the fastest inferred clock on the cell's clock pin and asynchronous input pins.

For more information on the mechanism used to infer related clock information, see the **propagate\_switching\_activity** command man page.

---

### SEE ALSO

[propagate\\_switching\\_activity\(2\)](#)  
[power\\_rclock\\_inputs\\_use\\_clocks\\_fanout\(3\)](#)  
[power\\_rclock\\_use\\_asynch\\_inputs\(3\)](#)

---

## power\_remove\_redundant\_clock\_gates

Specifies to the **compile -incremental** and **physopt -incremental** commands to remove redundant Synopsys clock gating cells.

---

### TYPE

Boolean

---

### DEFAULT

true in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies whether to remove redundant Synopsys clock gating cells during incremental compile. A clock gate is considered redundant when it is always enabled. This is the case when the enable net is tied to logic one. When this variable is set to **true** (the default value), the redundant clock-gating cells are removed during incremental compile. To disable the automatic removal of redundant clock gating cells, set the value to **false** before issuing the **compile** or **physopt** commands.

To determine the current value of this variable, use the **printvar power\_remove\_redundant\_clock\_gates** command. For a list of power variables and their current values, use **print\_variable\_group power**.

---

### SEE ALSO

**compile(2)**

---

## **power\_report\_separate\_switching\_power**

Forces the tool to report wire switching power and pin switching power in two separate columns for the group report from report\_power.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

The **power\_report\_separate\_switching\_power** variable forces the tool to report wire switching power and pin switching power in two separate columns for the group report from report\_power. By default, only one column is shown for switching power, which includes wire switching power and pin switching power.

The **power\_report\_separate\_switching\_power** variable is off (false) by default.

---

### **SEE ALSO**

[report\\_power\(2\)](#)

---

## **power\_same\_switching\_activity\_on\_connected\_objects**

Forces the tool to use the last user-annotated switching activity data on all connected tool objects.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

The **power\_same\_switching\_activity\_on\_connected\_objects** variable forces all switching activity data of all connected tool objects to use the latest user-annotated switching activity data. The user-annotated switching activity information can come from the **read\_saif** command or the **set\_switching\_activity** command. Power reporting commands may produce different power results, since the switching activity data may be changed.

The **power\_same\_switching\_activity\_on\_connected\_objects** variable is off (false) by default.

---

### **SEE ALSO**

[read\\_saif\(2\)](#)  
[set\\_switching\\_activity\(2\)](#)

---

## power\_scale\_internal\_arc

Enables scaling of state probabilities of internal power arcs.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

By default this variable is set to *false*, which disables scaling. If you set the Tcl variable to *true*, then the sum of the probabilities of the internal arc matches with the toggle rate of the pin even if there is no default arc for the pin in the library.

To find the current value of this variable, use the following command:

```
get_app_var power_scale_internal_arc
```

---

## power\_sdpd\_message\_tolerance

Specifies the tolerance value for issuing warning and information messages during fixing of user-annotated SDPD switching activity.

---

### TYPE

float

---

### DEFAULT

1e-05 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies a tolerance value that is used when messages are reported during the SDPD fixing step. The SDPD fixing step is enabled by the **power\_fix\_sdpd\_annotation** variable. See the **power\_fix\_sdpd\_annotation** command man page for more information on this step.

Messages reported by the SDPD fixing step need to specify the tolerance criteria specified by this variable. For example, SDPD fixing scales state-dependent static probabilities so that they add up to 1.0.

A message is reported by the SDPD fixing step if the difference between the sum of the state-dependent static probabilities and 1.0 is not within the tolerance value. A tolerance value of 0.0 makes the SDPD fixing step report a message for every check and modification to the SDPD annotation; however, this will most likely report non-issues due to floating point errors. A high value of the **power\_sdpd\_message\_tolerance** value filters out all but the most significant messages. Note that the verbosity of the SDPD fixing step is determined by the **power\_fix\_sdpd\_annotation\_verbose** variable. When **power\_fix\_sdpd\_annotation\_verbose** is set to **false**, most of the messages reported by the SDPD fixing step are replaced by a single message indicating that user-annotated SDPD switching activity is being corrected.

---

### SEE ALSO

[power\\_fix\\_sdpd\\_annotation\(3\)](#)  
[power\\_fix\\_sdpd\\_annotation\\_verbose\(3\)](#)

---

# power\_switch\_attributes

Describes the attributes related to power switches.

---

## DESCRIPTION

This man page described the attributes related to power switches. These attributes are defined only in UPF mode.

You can use the **get\_attribute** command to determine value of an attribute, and use the **report\_attribute** command to get a report \ of all the attributes on a specified power switch. To see all the power-switch attributes, use the **list\_attribute -class power\_switch -application** command.

### Power Switch Attributes

cell\_id

Specifies Milkyway design ID in which a power switch object is located.

This attribute is read-only.

name

Specifies name of a power switch object.

This attribute is read-only.

full\_name

Specifies full name of a power switch object.

This attribute is read-only.

object\_class

Specifies object class name of a power switch object, which is **power\_switch**.

This attribute is read-only.

object\_id

Specifies object ID in Milkyway design file.

This attribute is read-only.

within\_block\_abstraction

Specifies whether the power switch is part of the block abstraction.

The data type of **within\_block\_abstraction** is boolean.

This attribute is read-only and cannot be modified.

within\_ilm

Specifies whether the power switch is part of an ILM.

The data type of **within\_ilm** is boolean.

This attribute is read-only and cannot be modified.

---

## SEE ALSO

`get_attribute(2)`  
`list_attributes(2)`  
`report_attribute(2)`

---

## preroute\_opt\_verbose

Controls how verbose messages are displayed during DRC fixing, hold fixing, multiple-port-net fixing and tie-off optimization in the preroute stage. The debug can be used for debug purposes.

---

### TYPE

Positive integer

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
0 in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

This variable controls how verbose messages are displayed during DRC fixing, hold fixing, multiple-port-net fixing, tie-off and setup optimization in preroute stage. The messages can be used for debug purposes.

The default is 0.

When the variable is set to bitwise AND 2 (bit 2), which equals 1, the verbose messages are displayed during DRC fixing. For example, **set preroute\_opt\_verbose 2**.

When the variable is set to bitwise AND 4 (bit 3), which equals 1, the verbose messages are displayed during hold fixing. For example, **set preroute\_opt\_verbose 4**.

When the variable is set to bitwise AND 8 (bit 4), which equals 1, the verbose message are displayed during tie-off optimization. For example, **set preroute\_opt\_verbose 8**.

When the variable is set to bitwise AND 16 (bit 5), which equals 1, the verbose message are displayed during multiple-port-net fixing. For example, **set preroute\_opt\_verbose 16**.

When the variable is set to bitwise AND 32 (bit 6), which equals 1, the verbose message are displayed during setup fixing. For example, **set preroute\_opt\_verbose 32**.

When the variable is set to bitwise AND 128 (bit 8), which equals 1, the verbose message will be saved to file propt\_verbose.log. Bit 8 only works with DRC and setup fixing. For example, **set preroute\_opt\_verbose 0xa0** (output setup verbose message to file) **set preroute\_opt\_verbose 0x82** (output DRC verbose message to file)

You can output verbose message to a file. The file name is by default set as propt\_verbose.log and can not be changed.

You can use hexadecimal format as input , for example: **set preroute\_opt\_verbose 0x2** (DRC verbose) **set preroute\_opt\_verbose 0x4** (hold verbose) **set preroute\_opt\_verbose 0x8** (tie-off verbose) **set preroute\_opt\_verbose 0x10** (mpn verbose) **set preroute\_opt\_verbose 0x20** (setup verbose)

A common error from usage is: **set preroute\_opt\_verbose 8002**

Above setting is not valid value infact and the result is unknown.

You can also set the variable to show messages in multiple areas. For example, set `preroute_opt_verbose 24` (both tie-off and mpn verbose)

---

## SEE ALSO

---

## **preserve\_collections\_in\_compile**

Attempt to preserve collections during compile

---

### **TYPE**

Boolean

---

### **DEFAULT**

true in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

false in DC Explorer

---

### **DESCRIPTION**

By default this value is set to true. During **compile** optimizations and changes may invalidate existing collections (due to memory reference changes). If this variable is set to true, all the references will be kept updated as best as possible, though it adds a runtime overhead. Turning this off, reduces this overhead at the cost of existing collections being invalid after **compile**.

Use the following command to determine the current value of the variable:

```
prompt> printvar preserve_collections_in_compile
```

---

### **SEE ALSO**

`compile(2)`

---

## psynopt\_density\_limit

Sets the density limit for local region optimization. This limit prevents preroute optimization being performed on high density regions.

---

### TYPE

float

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

-1 in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### GROUP

psynopt\_variables

---

### DESCRIPTION

This variable sets the density limit for checking a local region during preroute optimization stage.

When the tool tries to optimize a local region, it checks the region's density. If the density is greater or equal to the limit, then the density check fails, and the optimization process is NOT be performed. That means, the optimization tool does NOT perform buffer insertion or cell sizing in this high density region.

The variable affects the following optimization processes: power recovery, DRC fixing, timing fixing, hold fixing, and area recovery.

The variable affects the following optimization commands: psynopt, place\_opt, clock\_opt, preroute\_focal\_opt, place\_opt\_feasibility, and clock\_opt\_feasibility.

The default is -1. You should set the variable to a number less than 1.0. If you set the variable to a number larger than 1.0, the optimization might result in high local density.

---

## psynopt\_tns\_high\_effort

Enables high-effort optimization to improve total negative slack in the design when you run a preroute command, such as **psynopt** or **place\_opt**.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

When you set the **psynopt\_tns\_high\_effort** variable to **true**, preroute commands, such as **place\_opt**, **clock\_opt**, and **psynopt** use high-effort optimization strategies to improve total negative slack (TNS). This variable is not enabled by default because it increases runtime. Set the variable to **true** if further TNS optimization is required.

This variable also improves TNS in the **compile\_ultra** command, but the impact is minimal. To enable high-effort TNS optimization in **compile\_ultra**, use the **compile\_timing\_high\_effort\_tns** variable.

---

### EXAMPLES

The following example enables the **place\_opt** command to use high-effort optimization to improve total negative slack:

```
prompt> set_app_var psynopt_tns_high_effort true
prompt> psynopt
```

---

### SEE ALSO

---

## query\_objects\_format

---

### TYPE

string

---

### DEFAULT

Legacy

---

### DESCRIPTION

This variable sets the format that the **query\_objects** command uses to print its result. There are two supported formats: Legacy and Tcl.

The Legacy format looks like this:

```
{"or1", "or2", "or3"}
```

The Tcl format looks like this:

```
{or1 or2 or3}
```

Please see the man page for **query\_objects** for complete details.

---

### SEE ALSO

[query\\_objects\(2\)](#)

---

## rc\_degrade\_min\_slew\_when\_rd\_less\_than\_rnet

Enables or disables the use of slew degradation in minimum analysis mode during the RCCALC-009 condition.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable enables the use of slew degradation during the RCCALC-009 condition. When set to **false**, (the default), slew degradation through RC networks is not used in minimum analysis mode during the RCCALC-009 condition.

The "RCCALC-009 condition" means a condition in which timing analysis checks the library-derived drive resistance, and if it is less than the dynamic RC network impedance to ground by an amount equal to or greater than the value of a particular drive-strength threshold, timing analysis adjusts the drive resistance using an empirical formula to improve accuracy, and issues the RCCALC-009 message. If this improved accuracy is not sufficient, timing analysis provides extra pessimism by not using slew degradation in minimum analysis mode; however, unnecessary minimum delay violations could occur as a side effect. You can keep slew degradation on in minimum analysis mode after you have qualified the RCCALC-009 methodology for your accuracy requirements, by setting this variable to **true**.

To determine the current value of this variable, use the **printvar rc\_degrade\_min\_slew\_when\_rd\_less\_than\_rnet** or **echo \$rc\_degrade\_min\_slew\_when\_rd\_less\_than\_rnet** command.

---

### SEE ALSO

---

## rc\_driver\_model\_mode

Specifies the driver model type to use for RC delay calculation.

---

### TYPE

string

---

### DEFAULT

advanced

---

### DESCRIPTION

This variable specifies whether the timing engine uses a basic or advanced driver model for RC delay calculation. The **basic** model is derived from a simpler delay and slew library method, whereas the **advanced** model is derived from an advanced driver model that is part of the Synopsys Composite Current Source (CCS) model.

When the variable is set to **basic**, RC delay calculation always uses driver models derived from the conventional delay and slew model present in the design library. When it is set to **advanced** (the default), RC delay calculation uses the advanced driver model, if data for the model is present. In that case, when you use the **report\_delay\_calculation** command to report the cell arc, it displays the message "Advanced driver-modeling used".

You do not need to set the **rc\_driver\_model\_mode** variable to **advanced** to enable the CCS driver model. The CCS model is used automatically if the CCS libraries exist. However, you can set the **rc\_driver\_model\_mode** variable to **basic** to disable the advanced CCS driver model.

When the **rc\_driver\_model\_mode** variable is set to **basic** and the **rc\_receiver\_model\_mode** variable is set to **advanced**, the timing engine uses the advanced voltage-dependent capacitance models to derive an equivalent single capacitance model that depends only on the rise, fall, minimum, or maximum arc condition. These equivalent capacitance values are used in the analysis instead of the pin capacitance values from the library. For details, see the **rc\_receiver\_model\_mode** variable man page.

To determine the current value of this variable, use the **printvar rc\_driver\_model\_mode** command.

---

### SEE ALSO

[report\\_delay\\_calculation\(2\)](#)  
[rc\\_receiver\\_model\\_mode\(3\)](#)

---

## rc\_input\_threshold\_pct\_fall

Specifies the threshold voltage that defines the startpoint of the falling cell or net delay calculation.

---

### TYPE

float

---

### DEFAULT

50 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies the threshold voltage that defines the startpoint of the falling cell or net delay calculation. The value is a percent of the voltage source. Allowed values are 0.0 through 100.0 inclusive.

This variable is one of 8 variables, listed in Table 1, that affect delay and transition time computations for detailed RC networks. These variables interpret the cell delays and transition times from the Synopsys library. The values specified by these variables are overridden by trip-point values specified in the library, so it should not be necessary to set the variables. The values specified are only applied to libraries that do not contain trip-point specifications.

Table 1

| Variable Name                    | Default |
|----------------------------------|---------|
| rc_slew_lower_threshold_pct_rise | 20.0    |
| rc_slew_lower_threshold_pct_fall | 20.0    |
| rc_slew_upper_threshold_pct_rise | 80.0    |
| rc_slew_upper_threshold_pct_fall | 80.0    |
| rc_input_threshold_pct_rise      | 50.0    |
| rc_input_threshold_pct_fall      | 50.0    |
| rc_output_threshold_pct_rise     | 50.0    |
| rc_output_threshold_pct_fall     | 50.0    |

The default values specify that a cell delay is defined from 50 percent of the voltage value for the input transition to 50 percent of the voltage value for the output transition. The default values also specify that a transition time, or slew, is defined from 20 percent to 80 percent of the voltage.

To determine the current value of this variable, use the **printvar rc\_input\_threshold\_pct\_fall** command. For a list of all timing variables and their current values, use **print\_variable\_group timing**.

---

## EXAMPLES

The following example specifies that cell delays from the Synopsys library are computed from 50 percent of the input transition to 55 percent of the output transition. In addition, the example specifies that transition times in the Synopsys library represent the delay from 10 percent to 90 percent of the voltage source.

```
prompt> set rc_slew_lower_threshold_pct_fall 10
prompt> set rc_slew_lower_threshold_pct_rise 10
prompt> set rc_slew_upper_threshold_pct_fall 90
prompt> set rc_slew_upper_threshold_pct_rise 90
prompt> set rc_input_threshold_pct_rise 50
prompt> set rc_input_threshold_pct_fall 50
prompt> set rc_output_threshold_pct_rise 55
prompt> set rc_output_threshold_pct_fall 55
```

---

## SEE ALSO

`rc_input_threshold_pct_fall(3)`  
`rc_input_threshold_pct_rise(3)`  
`rc_output_threshold_pct_fall(3)`  
`rc_output_threshold_pct_rise(3)`  
`rc_slew_lower_threshold_pct_fall(3)`  
`rc_slew_lower_threshold_pct_rise(3)`  
`rc_slew_upper_threshold_pct_fall(3)`  
`rc_slew_upper_threshold_pct_rise(3)`

## **rc\_input\_threshold\_pct\_rise**

Specifies the threshold voltage that defines the startpoint of the rising cell or net delay calculation.

### **TYPE**

float

### **DEFAULT**

50 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

### **DESCRIPTION**

This variable specifies the threshold voltage that defines the startpoint of the rising cell or net delay calculation. The value is a percent of the voltage source. Allowed values are 0.0 through 100.0 inclusive.

This variable is one of 8 variables, listed in Table 1, that affect delay and transition time computations for detailed RC networks. These variables interpret the cell delays and transition times from the Synopsys library. The values specified by these variables are overridden by trip-point values specified in the library, so normally it should not be necessary to set the variables. The values specified are only applied to libraries that do not contain trip-point specifications.

**Table 1**

| Variable Name                    | Default |
|----------------------------------|---------|
| rc_slew_lower_threshold_pct_rise | 20.0    |
| rc_slew_lower_threshold_pct_fall | 20.0    |
| rc_slew_upper_threshold_pct_rise | 80.0    |
| rc_slew_upper_threshold_pct_fall | 80.0    |
| rc_input_threshold_pct_rise      | 50.0    |
| rc_input_threshold_pct_fall      | 50.0    |
| rc_output_threshold_pct_rise     | 50.0    |
| rc_output_threshold_pct_fall     | 50.0    |

The default values specify that a cell delay is defined from 50 percent of the voltage value for the input transition to 50 percent of the voltage value for the output transition. The default values also specify that a transition time, or slew, is defined from 20 percent to 80 percent of the voltage.

To determine the current value of this variable, use the **printvar rc\_input\_threshold\_pct\_rise** command. For a list of all timing variables and their current values, use **print\_variable\_group timing**.

---

## EXAMPLES

The following example specifies that cell delays from the Synopsys library are computed from 50 percent of the input transition to 55 percent of the output transition. In addition, the example specifies that transition times in the Synopsys library represent the delay from 10 percent to 90 percent of the voltage source.

```
prompt> set rc_slew_lower_threshold_pct_fall 10
prompt> set rc_slew_lower_threshold_pct_rise 10
prompt> set rc_slew_upper_threshold_pct_fall 90
prompt> set rc_slew_upper_threshold_pct_rise 90
prompt> set rc_input_threshold_pct_rise 50
prompt> set rc_input_threshold_pct_fall 50
prompt> set rc_output_threshold_pct_rise 55
prompt> set rc_output_threshold_pct_fall 55
```

---

## SEE ALSO

`rc_input_threshold_pct_fall(3)`  
`rc_input_threshold_pct_rise(3)`  
`rc_output_threshold_pct_fall(3)`  
`rc_output_threshold_pct_rise(3)`  
`rc_slew_lower_threshold_pct_fall(3)`  
`rc_slew_lower_threshold_pct_rise(3)`  
`rc_slew_upper_threshold_pct_fall(3)`  
`rc_slew_upper_threshold_pct_rise(3)`

---

## rc\_noise\_model\_mode

Enables the use of CCS noise, if available in the design library, when set to **advanced**.

---

### TYPE

string

---

### DEFAULT

basic in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### GROUP

signal integrity

---

### DESCRIPTION

This variable enables CCS noise in static noise analysis and optimization, when set to **advanced**.

When set to **basic** (the default), CCS noise information is not used even if it exists in the library. However, if the library has NLDM noise information, it is still used.

To determine the current value of this variable, use the **get\_app\_var rc\_noise\_model\_mode** command.

---

### SEE ALSO

[rc\\_driver\\_model\\_mode\(3\)](#)  
[rc\\_receiver\\_model\\_mode\(3\)](#)

---

## rc\_output\_threshold\_pct\_fall

Specifies the threshold voltage that defines the startpoint of the falling cell or net delay calculation.

---

### TYPE

float

---

### DEFAULT

50 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies the threshold voltage that defines the startpoint of the falling cell or net delay calculation. The value is a percent of the voltage source. Allowed values are 0.0 through 100.0 inclusive.

This variable is one of 8 variables, listed in Table 1, that affect delay and transition time computations for detailed RC networks. These variables interpret the cell delays and transition times from the Synopsys library. The values specified by these variables are overridden by trip-point values specified in the library, so it should not be necessary to set the variables. The values specified are only applied to libraries that do not contain trip-point specifications.

**Table 1**

| Variable Name                    | Default |
|----------------------------------|---------|
| rc_slew_lower_threshold_pct_rise | 20.0    |
| rc_slew_lower_threshold_pct_fall | 20.0    |
| rc_slew_upper_threshold_pct_rise | 80.0    |
| rc_slew_upper_threshold_pct_fall | 80.0    |
| rc_input_threshold_pct_rise      | 50.0    |
| rc_input_threshold_pct_fall      | 50.0    |
| rc_output_threshold_pct_rise     | 50.0    |
| rc_output_threshold_pct_fall     | 50.0    |

The default values specify that a cell delay is defined from 50 percent of the voltage value for the input transition to 50 percent of the voltage value for the output transition. The default values also specify that a transition time, or slew, is defined from 20 percent to 80 percent of the voltage.

To determine the current value of this variable, use the **printvar rc\_output\_threshold\_pct\_fall** command.

For a list of all timing variables and their current values, type **print\_variable\_group timing**.

---

## EXAMPLES

The following example specifies that cell delays from the Synopsys library are computed from 50 percent of the input transition to 55 percent of the output transition. In addition, the example specifies that transition times in the Synopsys library represent the delay from 10 percent to 90 percent of the voltage source.

```
prompt> set rc_slew_lower_threshold_pct_fall 10
prompt> set rc_slew_lower_threshold_pct_rise 10
prompt> set rc_slew_upper_threshold_pct_fall 90
prompt> set rc_slew_upper_threshold_pct_rise 90
prompt> set rc_input_threshold_pct_rise 50
prompt> set rc_input_threshold_pct_fall 50
prompt> set rc_output_threshold_pct_rise 55
prompt> set rc_output_threshold_pct_fall 55
```

---

## SEE ALSO

[rc\\_input\\_threshold\\_pct\\_fall\(3\)](#)  
[rc\\_input\\_threshold\\_pct\\_rise\(3\)](#)  
[rc\\_output\\_threshold\\_pct\\_fall\(3\)](#)  
[rc\\_output\\_threshold\\_pct\\_rise\(3\)](#)  
[rc\\_slew\\_lower\\_threshold\\_pct\\_fall\(3\)](#)  
[rc\\_slew\\_lower\\_threshold\\_pct\\_rise\(3\)](#)  
[rc\\_slew\\_upper\\_threshold\\_pct\\_fall\(3\)](#)  
[rc\\_slew\\_upper\\_threshold\\_pct\\_rise\(3\)](#)

---

## rc\_output\_threshold\_pct\_rise

Specifies the threshold voltage that defines the startpoint of the rising cell or net delay calculation.

---

### TYPE

float

---

### DEFAULT

50 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies the threshold voltage that defines the startpoint of the rising cell or net delay calculation. The value is a percent of the voltage source. Allowed values are 0.0 through 100.0 inclusive.

This variable is one of 8 variables, listed in Table 1, that affect delay and transition time computations for detailed RC networks. These variables interpret the cell delays and transition times from the Synopsys library. The values specified by these variables are overridden by trip-point values specified in the library, so it should not be necessary to set the variables. The values specified are only applied to libraries that do not contain trip-point specifications.

**Table 1**

| Variable Name                    | Default |
|----------------------------------|---------|
| rc_slew_lower_threshold_pct_rise | 20.0    |
| rc_slew_lower_threshold_pct_fall | 20.0    |
| rc_slew_upper_threshold_pct_rise | 80.0    |
| rc_slew_upper_threshold_pct_fall | 80.0    |
| rc_input_threshold_pct_rise      | 50.0    |
| rc_input_threshold_pct_fall      | 50.0    |
| rc_output_threshold_pct_rise     | 50.0    |
| rc_output_threshold_pct_fall     | 50.0    |

The default values specify that a cell delay is defined from 50 percent of the voltage value for the input transition to 50 percent of the voltage value for the output transition. The default values also specify that a transition time, or slew, is defined from 20 percent to 80 percent of the voltage.

To determine the current value of this variable, use the **printvar rc\_output\_threshold\_pct\_rise** command.

For a list of all timing variables and their current values, use **print\_variable\_group timing**.

---

## EXAMPLES

The following example specifies that cell delays from the Synopsys library are computed from 50 percent of the input transition to 55 percent of the output transition. In addition, the example specifies that transition times in the Synopsys library represent the delay from 10 percent to 90 percent of the voltage source.

```
prompt> set rc_slew_lower_threshold_pct_fall 10
prompt> set rc_slew_lower_threshold_pct_rise 10
prompt> set rc_slew_upper_threshold_pct_fall 90
prompt> set rc_slew_upper_threshold_pct_rise 90
prompt> set rc_input_threshold_pct_rise 50
prompt> set rc_input_threshold_pct_fall 50
prompt> set rc_output_threshold_pct_rise 55
prompt> set rc_output_threshold_pct_fall 55
```

---

## SEE ALSO

`rc_input_threshold_pct_fall(3)`  
`rc_input_threshold_pct_rise(3)`  
`rc_output_threshold_pct_fall(3)`  
`rc_output_threshold_pct_rise(3)`  
`rc_slew_lower_threshold_pct_fall(3)`  
`rc_slew_lower_threshold_pct_rise(3)`  
`rc_slew_upper_threshold_pct_fall(3)`  
`rc_slew_upper_threshold_pct_rise(3)`

---

## rc\_receiver\_model\_mode

Specifies the receiver model type to use for RC delay calculation.

---

### TYPE

string

---

### DEFAULT

advanced

---

### DESCRIPTION

This variable specifies whether the timing engine uses a basic or advanced receiver model for RC delay calculation. The **basic** model is a single capacitance model that depends only on the rise, fall, minimum, or maximum arc condition. The **advanced** model is a voltage-dependent capacitance model that also depends on input slew and output capacitance.

One advantage of the advanced model is improved accuracy for both delay and slew calculation. Another advantage is that it considers nonlinear effects such as the Miller effect. The advanced receiver model is part of the Synopsys Composite Current Source (CCS) model.

When this variable is set to **advanced** (the default), RC delay calculation uses the advanced receiver model if data for that model is present and if the network driver uses the advanced driver model. In that case, a report generated by the **report\_delay\_calculation** command for a network arc displays the message "Advanced receiver-modeling used".

You do not need to set the **rc\_receiver\_model\_mode** variable to **advanced** to enable the CCS receiver model. The CCS model is used automatically if the CCS libraries exist. However, you can set the **rc\_receiver\_model\_mode** variable to **basic** to disable the advanced CCS receiver model.

When the **rc\_receiver\_model\_mode** variable is set to **advanced**, and the network is not driven by the advanced driver model (such as when the **rc\_driver\_model\_mode** variable is set to basic or a lumped load is used), the timing engine uses the advanced voltage-dependent capacitance models to derive an equivalent single capacitance model that depends only on the rise, fall, minimum, or maximum arc condition. These equivalent capacitance values are used in analysis instead of the pin capacitance values from the library. The **report\_delay\_calculation** command used on a network arc does not show the "Advanced receiver-modeling used" message for these calculations because only an equivalent single capacitance is used.

When the **rc\_receiver\_model\_mode** variable is set to **basic**, RC delay calculation uses the pin capacitance values specified in the design libraries.

To determine the current value of this variable, use the **printvar rc\_receiver\_model\_mode** command.

---

### SEE ALSO

```
report_delay_calculation(2)
rc_driver_model_mode(3)
```

---

## rc\_slew\_derate\_from\_library

Specifies the derating needed for the transition times in the Synopsys library to match the transition times between the characterization trip points.

---

### TYPE

float

---

### DEFAULT

1 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies a floating-point number between 0.0 and 1.0 that indicates the derating needed for the transition times in the Synopsys library to match the transition times between the characterization trip points. The default is 1.0, which means that the transition times in the Synopsys library are used without change.

The value this variable specifies is overridden by any library-specified slew-derating values, so it should not be necessary to set the variable. The value specified applies only to libraries that do not contain slew-derating specifications.

A slew-derating value of 1.0 should be used if the transition times specified in the library represent the exact transition times between the characterization trip points, which is usually the case. Use a slew-derating value of less than 1.0 for libraries where the transition times have been extrapolated to the rail voltages. For example, if the transition times are characterized as between 30 percent and 70 percent and then extrapolated to the rails, the slew-derating value is  $0.4 = (70 - 30) / 100$ .

To determine the current value of this variable, use the **printvar rc\_slew\_derate\_from\_library** command. For a list of all timing variables and their current values, use **print\_variable\_group timing**.

---

### EXAMPLES

The following example specifies that cell delays from the Synopsys library have been computed from 50 percent of the input transition to 50 percent of the output transition. The example also specifies that transition times in the Synopsys library were computed by measuring the delay from 30 percent to 70 percent of the voltage source and then multiplying the measured transition times by  $2.5 = (100-0)/(70-30)$  to extrapolate to 0-100 percent of the rail voltages.

```
prompt> set rc_slew_derate_from_library 0.4
prompt> set rc_slew_lower_threshold_pct_fall 30
prompt> set rc_slew_lower_threshold_pct_rise 30
```

```
prompt> set rc_slew_upper_threshold_pct_fall 70
prompt> set rc_slew_upper_threshold_pct_rise 70
prompt> set rc_input_threshold_pct_rise   50
prompt> set rc_input_threshold_pct_fall   50
prompt> set rc_output_threshold_pct_rise 55
prompt> set rc_output_threshold_pct_fall 55
```

---

## SEE ALSO

`rc_input_threshold_pct_fall(3)`  
`rc_input_threshold_pct_rise(3)`  
`rc_output_threshold_pct_fall(3)`  
`rc_output_threshold_pct_rise(3)`  
`rc_slew_lower_threshold_pct_fall(3)`  
`rc_slew_lower_threshold_pct_rise(3)`  
`rc_slew_upper_threshold_pct_fall(3)`  
`rc_slew_upper_threshold_pct_rise(3)`

---

## rc\_slew\_lower\_threshold\_pct\_fall

Specifies the threshold voltage that defines the endpoint of the falling slew calculation.

---

### TYPE

float

---

### DEFAULT

20 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies the threshold voltage that defines the endpoint of the falling slew calculation. The value is a percent of the voltage source. Allowed values are 0.0 through 100.0 inclusive.

This variable is one of 8 variables, listed in Table 1, that affect delay and transition time computations for detailed RC networks. These variables interpret the cell delays and transition times from the Synopsys library. The values specified by these variables are overridden by trip-point values specified in the library, so it should not be necessary to set the variables. The values specified are only applied to libraries that do not contain trip-point specifications.

Table 1

| Variable Name                    | Default |
|----------------------------------|---------|
| rc_slew_lower_threshold_pct_rise | 20.0    |
| rc_slew_lower_threshold_pct_fall | 20.0    |
| rc_slew_upper_threshold_pct_rise | 80.0    |
| rc_slew_upper_threshold_pct_fall | 80.0    |
| rc_input_threshold_pct_rise      | 50.0    |
| rc_input_threshold_pct_fall      | 50.0    |
| rc_output_threshold_pct_rise     | 50.0    |
| rc_output_threshold_pct_fall     | 50.0    |

The default values specify that a cell delay is defined from 50 percent of the voltage value for the input transition to 50 percent of the voltage value for the output transition. The default values also specify that a transition time, or slew, is defined from 20 percent to 80 percent of the voltage.

To determine the current value of this variable, use the `printvar rc_slew_lower_threshold_pct_fall` command. For a list of all timing variables and their current values, use `print_variable_group timing`.

---

## EXAMPLES

The following example specifies that cell delays from the Synopsys library are computed from 50 percent of the input transition to 55 percent of the output transition. In addition, the example specifies that transition times in the Synopsys library represent the delay from 10 percent to 90 percent of the voltage source.

```
prompt> set rc_slew_lower_threshold_pct_fall 10
prompt> set rc_slew_lower_threshold_pct_rise 10
prompt> set rc_slew_upper_threshold_pct_fall 90
prompt> set rc_slew_upper_threshold_pct_rise 90
prompt> set rc_input_threshold_pct_rise 50
prompt> set rc_input_threshold_pct_fall 50
prompt> set rc_output_threshold_pct_rise 55
prompt> set rc_output_threshold_pct_fall 55
```

---

## SEE ALSO

`rc_input_threshold_pct_fall(3)`  
`rc_input_threshold_pct_rise(3)`  
`rc_output_threshold_pct_fall(3)`  
`rc_output_threshold_pct_rise(3)`  
`rc_slew_lower_threshold_pct_fall(3)`  
`rc_slew_lower_threshold_pct_rise(3)`  
`rc_slew_upper_threshold_pct_fall(3)`  
`rc_slew_upper_threshold_pct_rise(3)`

---

## rc\_slew\_lower\_threshold\_pct\_rise

Specifies the threshold voltage that defines the startpoint of the rising slew calculation.

---

### TYPE

float

---

### DEFAULT

20 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies the threshold voltage that defines the startpoint of the rising slew calculation. The value is a percent of the voltage source. Allowed values are 0.0 through 100.0 inclusive.

This variable is one of 8 variables, listed in Table 1, that affect delay and transition time computations for detailed RC networks. These variables interpret the cell delays and transition times from the Synopsys library. The values specified by these variables are overridden by trip-point values specified in the library, so it should not be necessary to set the variables. The values specified are only applied to libraries that do not contain trip-point specifications.

Table 1

| Variable Name                    | Default |
|----------------------------------|---------|
| rc_slew_lower_threshold_pct_rise | 20.0    |
| rc_slew_lower_threshold_pct_fall | 20.0    |
| rc_slew_upper_threshold_pct_rise | 80.0    |
| rc_slew_upper_threshold_pct_fall | 80.0    |
| rc_input_threshold_pct_rise      | 50.0    |
| rc_input_threshold_pct_fall      | 50.0    |
| rc_output_threshold_pct_rise     | 50.0    |
| rc_output_threshold_pct_fall     | 50.0    |

The default values specify that a cell delay is defined from 50 percent of the voltage value for the input transition to 50 percent of the voltage value for the output transition. The default values also specify that a transition time, or slew, is defined from 20 percent to 80 percent of the voltage.

To determine the current value of this variable, use the **printvar rc\_slew\_lower\_threshold\_pct\_rise** command. For a list of all timing variables and their current values, use **print\_variable\_group timing**.

---

## EXAMPLES

The following example specifies that cell delays from the Synopsys library are computed from 50 percent of the input transition to 55 percent of the output transition. In addition, the example specifies that transition times in the Synopsys library represent the delay from 10 percent to 90 percent of the voltage source.

```
prompt> set rc_slew_lower_threshold_pct_fall 10
prompt> set rc_slew_lower_threshold_pct_rise 10
prompt> set rc_slew_upper_threshold_pct_fall 90
prompt> set rc_slew_upper_threshold_pct_rise 90
prompt> set rc_input_threshold_pct_rise 50
prompt> set rc_input_threshold_pct_fall 50
prompt> set rc_output_threshold_pct_rise 55
prompt> set rc_output_threshold_pct_fall 55
```

---

## SEE ALSO

`rc_input_threshold_pct_fall(3)`  
`rc_input_threshold_pct_rise(3)`  
`rc_output_threshold_pct_fall(3)`  
`rc_output_threshold_pct_rise(3)`  
`rc_slew_lower_threshold_pct_fall(3)`  
`rc_slew_lower_threshold_pct_rise(3)`  
`rc_slew_upper_threshold_pct_fall(3)`  
`rc_slew_upper_threshold_pct_rise(3)`

---

## rc\_slew\_upper\_threshold\_pct\_fall

Specifies the threshold voltage that defines the startpoint of the falling slew calculation.

---

### TYPE

float

---

### DEFAULT

80 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies the threshold voltage that defines the startpoint of the falling slew calculation. The value is a percent of the voltage source. Allowed values are 0.0 through 100.0 inclusive.

This variable is one of 8 variables, listed in Table 1, that affect delay and transition time computations for detailed RC networks. These variables interpret the cell delays and transition times from the Synopsys library. The values specified by these variables are overridden by trip-point values specified in the library, so it should not be necessary to set the variables. The values specified are only applied to libraries that do not contain trip-point specifications.

**Table 1**

| Variable Name                    | Default |
|----------------------------------|---------|
| rc_slew_lower_threshold_pct_rise | 20.0    |
| rc_slew_lower_threshold_pct_fall | 20.0    |
| rc_slew_upper_threshold_pct_rise | 80.0    |
| rc_slew_upper_threshold_pct_fall | 80.0    |
| rc_input_threshold_pct_rise      | 50.0    |
| rc_input_threshold_pct_fall      | 50.0    |
| rc_output_threshold_pct_rise     | 50.0    |
| rc_output_threshold_pct_fall     | 50.0    |

The default values specify that a cell delay is defined from 50 percent of the voltage value for the input transition to 50 percent of the voltage value for the output transition. The default values also specify that a transition time, or slew, is defined from 20 percent to 80 percent of the voltage.

To determine the current value of this variable, use the **printvar rc\_slew\_upper\_threshold\_pct\_fall** command. For a list of all timing variables and their current values, use **print\_variable\_group timing**.

---

## EXAMPLES

The following example specifies that cell delays from the Synopsys library are computed from 50 percent of the input transition to 55 percent of the output transition. In addition, the example specifies that transition times in the Synopsys library represent the delay from 10 percent to 90 percent of the voltage source.

```
prompt> set rc_slew_lower_threshold_pct_fall 10
prompt> set rc_slew_lower_threshold_pct_rise 10
prompt> set rc_slew_upper_threshold_pct_fall 90
prompt> set rc_slew_upper_threshold_pct_rise 90
prompt> set rc_input_threshold_pct_rise 50
prompt> set rc_input_threshold_pct_fall 50
prompt> set rc_output_threshold_pct_rise 55
prompt> set rc_output_threshold_pct_fall 55
```

---

## SEE ALSO

`rc_input_threshold_pct_fall(3)`  
`rc_input_threshold_pct_rise(3)`  
`rc_output_threshold_pct_fall(3)`  
`rc_output_threshold_pct_rise(3)`  
`rc_slew_lower_threshold_pct_fall(3)`  
`rc_slew_lower_threshold_pct_rise(3)`  
`rc_slew_upper_threshold_pct_fall(3)`  
`rc_slew_upper_threshold_pct_rise(3)`

---

## rc\_slew\_upper\_threshold\_pct\_rise

Specifies the threshold voltage that defines the endpoint of the rising slew calculation.

---

### TYPE

float

---

### DEFAULT

80 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies the threshold voltage that defines the endpoint of the rising slew calculation. The value is a percent of the voltage source. Allowed values are 0.0 through 100.0 inclusive.

This variable is one of 8 variables, listed in Table 1, that affect delay and transition time computations for detailed RC networks. These variables interpret the cell delays and transition times from the Synopsys library. The values specified by these variables are overridden by trip-point values specified in the library, so it should not be necessary to set the variables. The values specified are only applied to libraries that do not contain trip-point specifications.

**Table 1**

| Variable Name                    | Default |
|----------------------------------|---------|
| rc_slew_lower_threshold_pct_rise | 20.0    |
| rc_slew_lower_threshold_pct_fall | 20.0    |
| rc_slew_upper_threshold_pct_rise | 80.0    |
| rc_slew_upper_threshold_pct_fall | 80.0    |
| rc_input_threshold_pct_rise      | 50.0    |
| rc_input_threshold_pct_fall      | 50.0    |
| rc_output_threshold_pct_rise     | 50.0    |
| rc_output_threshold_pct_fall     | 50.0    |

The default values specify that a cell delay is defined from 50 percent of the voltage value for the input transition to 50 percent of the voltage value for the output transition. The default values also specify that a transition time, or slew, is defined from 20 percent to 80 percent of the voltage.

To determine the current value of this variable, use the `printvar rc_slew_upper_threshold_pct_rise` command. For a list of all timing variables and their current values, use `print_variable_group timing`.

---

## EXAMPLES

The following example specifies that cell delays from the Synopsys library are computed from 50 percent of the input transition to 55 percent of the output transition. In addition, the example specifies that transition times in the Synopsys library represent the delay from 10 percent to 90 percent of the voltage source.

```
prompt> set rc_slew_lower_threshold_pct_fall 10
prompt> set rc_slew_lower_threshold_pct_rise 10
prompt> set rc_slew_upper_threshold_pct_fall 90
prompt> set rc_slew_upper_threshold_pct_rise 90
prompt> set rc_input_threshold_pct_rise 50
prompt> set rc_input_threshold_pct_fall 50
prompt> set rc_output_threshold_pct_rise 55
prompt> set rc_output_threshold_pct_fall 55
```

---

## SEE ALSO

`rc_input_threshold_pct_fall(3)`  
`rc_input_threshold_pct_rise(3)`  
`rc_output_threshold_pct_fall(3)`  
`rc_output_threshold_pct_rise(3)`  
`rc_slew_lower_threshold_pct_fall(3)`  
`rc_slew_lower_threshold_pct_rise(3)`  
`rc_slew_upper_threshold_pct_fall(3)`  
`rc_slew_upper_threshold_pct_rise(3)`

---

## **read\_db\_lib\_warnings**

Indicates that warnings are to be printed while a technology .db library is being read in with the **read** command. When false (the default), no warnings are given.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

Indicates that warnings are to be printed while a technology .db library is being read in with the **read** command. When false (the default), no warnings are given.

To determine the current value of this variable, type **printvar read\_db\_lib\_warnings**. For a list of all **io** variables and their current values, type **print\_variable\_group io**.

---

### **SEE ALSO**

[read\(2\)](#)

---

## read\_only\_attributes

Contains informational attributes, which the user cannot set.

---

## DESCRIPTION

Contains informational attributes. A "read-only" attribute cannot be set by the user.

To determine the value of an attribute, use the **get\_attribute** command.

For information on all attributes, refer to the **attributes** manual page.

### Read-only Attributes

`design_type`

Indicates the current state of the design and has the value *fsm* (finite state machine), *pla* (programmable logic array), *equation* (Boolean logic), or *netlist* (gates). This attribute cannot be set by the user.

`is_black_box`

*true* if the reference is not yet linked to a design. This attribute cannot be set by the user.

`is_combinational`

*true* if all cells of a design and all designs in its hierarchy are combinational. A cell is combinational if it is non-sequential or non-tristate and all of its outputs compute a combinational logic function. The **report\_lib** command will report such a cell as not a black-box. This attribute cannot be set by the user.

`is_dw_subblock`

*true* if the object (a cell, a reference, or a design) is a DW subblock that was automatically elaborated. This attribute cannot be set by the user.

**Note:** DW subblocks that are manually elaborated will not have this attribute.

`is_hierarchical`

*true* if the design contains leaf cells or other levels of hierarchy. This attribute is read-only and cannot be set by the user.

`is_mapped`

*true* if all the non-hierarchical cells of a design are mapped to cells in a technology library. This attribute cannot be set by the user.

`is_sequential`

*true* if any cells of a design or designs in its hierarchy are sequential. A cell is sequential if it is not combinational. This attribute cannot be set by the user.

`is_test_circuitry`

Set by **insert\_dft** on the scan cells and nets added to a design during the addition of test circuitry. This attribute cannot be set by the user.

`is_synlib_module`

*true* if the object (a cell, a reference, or a design) refers to an unmapped module reference or if the object is (or refers to) a design

that was automatically elaborated from a synlib module or a synlib operator. This attribute cannot be set by the user.

**Note:** synlib modules that are manually elaborated will not have this attribute.

#### is\_synlib\_operator

*true* if the object (a cell or a reference) is a synthetic library operator reference. This attribute cannot be set by the user.

#### is\_unmapped

*true* if any of the cells are not linked to a design or mapped to a technology library. This attribute cannot be set by the user.

#### pin\_direction

Direction of a pin. Value can be *in*, *out*, *inout*, or *unknown*. This attribute cannot be set by the user.

#### port\_direction

Direction of a port. Value can be *in*, *out*, *inout*, or *unknown*. This attribute cannot be set by the user.

#### ref\_name

The reference name of a cell. This attribute cannot be set by the user.

---

## SEE ALSO

[get\\_attribute\(2\)](#)  
[attributes\(3\)](#)

---

## read\_translate\_msff

Automatically translates master-slave flip-flops (specified with the clocked\_on\_also syntax) to master-slave latches.

---

### TYPE

Boolean

---

### DEFAULT

true in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable automatically translates master-slave flip-flops (specified with the clocked\_on\_also syntax) to master-slave latches, when set to **true** (the default). When set to **false**, both master and slave remain flip-flops.

This variable is used when running the **read\_file** command, while a technology .db library is being read in by the shell, and when running the **read\_lib** command while a technology library is being read in by Library Compiler. The technology .db library is affected only if the program reports that the .db library is being updated and asks you to save the results. Library Compiler always follows this variable during processing.

To determine the current value of this variable, use the **printvar read\_translate\_msff** command.

---

### SEE ALSO

[read\\_file\(2\)](#)  
[read\\_lib\(2\)](#)

---

## reference\_attributes

Contains attributes that can be placed on a reference.

---

## DESCRIPTION

Contains attributes that can be placed on a reference.

Several commands exist that can be used to set attributes; however, most attributes can be set by using the **set\_attribute** command. If the attribute definition specifies a **set** command, use it to set the attribute; otherwise, use **set\_attribute**. If an attribute is read-only, you cannot set it.

To determine the value of an attribute, use the **get\_attribute** command. To remove attributes, use the **remove\_attribute** command.

For a more detailed explanation of an attribute, see the manual page of the appropriate **set** command. For information on all attributes, refer to the **attributes** manual page.

### Reference Attributes

#### dont\_touch

Specifies that designs linked to a reference with this attribute are excluded from optimization. Valid values are true (the default) or false. Designs linked to a reference by using the **dont\_touch** attribute set to true are not modified or replaced during compile. Set this by using the **set\_dont\_touch** attribute.

#### is\_black\_box

This is set to true if the reference is not yet linked to a design. This attribute is read-only and you cannot set it.

#### is\_combinational

This is set to true if all the cells of the referenced design are combinational. A cell is combinational if it is nonsequential or non-tristate and all of its outputs compute a combinational logic function. The **report\_lib** command reports such a cell as not a black-box. This attribute is read-only and you cannot set it.

#### is\_dw\_subblock

This is set to true if the object (a cell, a reference, or a design) is a DesignWare subblock that was automatically elaborated. This attribute is read-only and you cannot set it.

**Note:** DesignWare subblocks that are manually elaborated do not have this attribute.

#### is\_hierarchical

This is set to true if the design contains leaf cells or other levels of hierarchy. This attribute is read-only and you cannot set it.

#### is\_mapped

This is set to true if the reference is linked to a design, and all the non-hierarchical cells of the referenced design are mapped to cells in a technology library. This attribute is read-only and you cannot set it.

#### is\_sequential

This is set to true if all the cells of the referenced design are sequential. A cell is sequential if it is not combinational (if any of its outputs depend on previous inputs). This attribute is read-only and you cannot set it.

#### is\_synlib\_module

This is set to true if the object (a cell, a reference, or a design) refers to an unmapped module reference, or the object is (or refers to) a design that was automatically elaborated from a synlib module or a synlib operator. This attribute is read-only and you cannot set it.

**Note:** synlib modules that are manually elaborated do not have this attribute.

#### is\_synlib\_operator

This is set to true if the object (a cell or a reference) is a synthetic library operator reference. This attribute is read-only and you cannot set it.

#### is\_unmapped

This is set to true if any of the non-hierarchical cells of the referenced design are not mapped to cells in a technology library, or the reference is not yet linked to a design. This attribute is read-only and you cannot set it.

#### scan

When *true*, specifies that cells of the referenced design are always replaced by equivalent scan cells during insert\_dft. When false, cells are not replaced. Set by using the **set\_scan\_replacement**.

#### scan\_chain

Includes the specified cells of the referenced design in the scan-chain whose index is the value of this attribute.

#### ungroup

Specifies that all designs linked to a reference with this attribute are ungrouped (levels of hierarchy represented by these design cells are removed) during compile. Set by using the **set\_ungroup** command.

---

## SEE ALSO

[get\\_attribute\(2\)](#)  
[insert\\_dft\(2\)](#)  
[remove\\_attribute\(2\)](#)  
[set\\_attribute\(2\)](#)  
[set\\_scan\\_replacement\(2\)](#)  
[attributes\(3\)](#)

---

## register\_duplicate

Specifies that the **compile** command is to invoke register duplication to reduce the number of fanouts for each register.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

The **register\_duplicate** variable when set to **true**(default is **false**), duplicates the high fanout registers to reduce the number of fanouts for each register. The max fanout that each register should drive is specified by setting **set\_max\_fanout**. The register replication occurs provided that you specified max fanout constraint using **set\_max\_fanout**.

Fanouts for registers that exceed a certain limit can cause an adverse affect on the circuit performance. The fanout is by default controlled only by buffer insertion. Some FPGA architectures lack buffers in the routing architecture that might cause the fixed fanout limit to exceed and cause an error in the back-end tool. To address this problem, the **register\_duplicate** variable provides a method to duplicate registers in an optimized manner.

---

### EXAMPLES

The following is an example of the use of **register\_duplicate**:

```
prompt> set_max_fanout 25 top  
prompt> set_app_var register_duplicate true  
prompt> set_attribute xfpga_virtex2-5 \  
-type float default_fanout_load 100
```

The **compile** command indicates the register duplication status as "-". After the report is generated, the following message appears:

Information: Duplicating register r1\_reg with fanout load of 50.00 (REGDUP-3)

Optimization Complete

## SEE ALSO

`compile(2)`  
`set_max_fanout(2)`

---

## register\_replication\_naming\_style

Specifies the style to use in naming the replicated register with the **set\_register\_replication** command.

---

### TYPE

string

---

### DEFAULT

%s\_rep%d

---

### DESCRIPTION

This variable specifies the naming style of the replicated register created by the **set\_register\_replication** command. It is a string that has exactly one %s and one %d. The %s is replaced by the base name of the register. The %d is the i-th copy of the replicated register.

For example, if the variable is %s\_rep\_%d, then the first copy of the u0\_reg register is u0\_reg\_rep\_1. The fifth copy of the u6 register is u6\_rep\_5.

To determine the current value of this variable, use the **printvar register\_replication\_naming\_style** command.

---

### SEE ALSO

[set\\_register\\_replication\(2\)](#)

---

## **remove\_constant\_register**

is an attribute which specifies whether constant register is set to be optimized or preserved which is set by set\_constant\_register\_removal.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

This attribute being set by set\_constant\_register\_removal command when set to false preserves the constant register, true allows optimization.

---

### **SEE ALSO**

---

## **remove\_unloaded\_register**

is an attribute which specifies whether unloaded register is set to be optimized or preserved which is set by set\_unloaded\_register\_removal.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

This attribute being set by set\_unloaded\_register\_removal command when set to false preserves the unloaded register, true allows optimization.

---

### **SEE ALSO**

---

## report\_capacitance\_use\_ccs\_receiver\_model

Specifies whether the basic or advanced receiver model is used to report receiver pin capacitance.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When set this variable to be true, the advanced CCS receiver model is used to report receiver pin capacitance by the **report\_net**, **report\_constraint**, **report\_delay\_calculation**, and **report\_timing** commands. When it is set to false, the basic library-derived lumped pin capacitance is used. The variable setting only affects pin capacitance reporting, not delay calculation.

---

### SEE ALSO

[report\\_timing\(2\)](#)  
[report\\_net\(2\)](#)  
[report\\_constraint\(2\)](#)  
[report\\_delay\\_calculation\(2\)](#)

---

## report\_default\_significant\_digits

Sets the default number of significant digits for many reports.

---

### TYPE

integer

---

### DEFAULT

-1

---

### DESCRIPTION

The **report\_default\_significant\_digits** variable sets the default number of significant digits for many reports. Allowed values are 0-13; the default is -1. A value of -1 indicates that a command-specific default precision value is used for reporting. Some report commands, such as **report\_timing** and **report\_cell**, have a **-significant\_digits** option, which overrides the value of this variable.

Not all reports respond to this variable. Check the man pages for individual reports to determine whether they support this feature.

To determine the current value of this variable, use the **printvar report\_default\_significant\_digits** command.

Once set, the value of the variable is used by the subsequent reporting commands if a command-specific **-significant\_digits** option is not used. The value of the variable can be reset by setting the value of the variable to -1. This causes the command-specific default to be used as the precision for reporting if the **-significant\_digits** command option is not used.

For example, assume the command-specific default precision of the **report\_cell** command is 6. If the **report\_default\_significant\_digits** variable is set to 5 and the **report\_cell** command is run thereafter, a precision of 5 is used in the **report\_cell** report. If the **report\_cell -significant\_digits 3** command is run after the above variable setting, a precision of 3 is used for the **report\_cell** report. To view the **report\_cell** report with the command default precision of 6, reset the value of the **report\_default\_significant\_digits** variable by setting it to -1.

If an invalid value is set (not in the range 0-13 and not -1), an error is issued and the previous valid value is restored. The following example illustrates the usage of the variable:

```
prompt> printvar report_default_significant_digits
report_default_significant_digits = "-1"

prompt> set_app_var report_default_significant_digits 4
4

prompt> printvar report_default_significant_digits
report_default_significant_digits = "4"

prompt> set_app_var report_default_significant_digits -44
Error: can't set report_default_significant_digits: must be in range 0 to 13
Use error_info for more info. (CMD-013)
```

4

```
prompt> printvar report_default_significant_digits
report_default_significant_digits = "4"
```

---

## SEE ALSO

`report_cell(2)`  
`report_clock_gating_check(2)`  
`report_constraint(2)`  
`report_net(2)`  
`report_path_budget(2)`  
`report_qor(2)`  
`report_timing(2)`  
`write_sdf(2)`

---

## **report\_timing\_use\_accurate\_delay\_symbol**

Specifies whether to use accurate delay symbols in **report\_timing** reports.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true

---

### **DESCRIPTION**

This variable specifies whether to use accurate delay symbols in the "Incr" column of reports generated by **report\_timing**. When the variable is set to true (the default), the following symbols are used:

- &: Delay information is timing-annotated using Elmore delay calculation
- c: Delay information is from Arnoldi calculation with accurate CCS
- @: Delay information is from Arnoldi calculation
- a: Delay information is from postroute AWE calculation
- w: Delay information is from preroute AWE calculation

When the variable is set to false, the "c", "@" and "a" symbols are not used; preroute delay increments are marked with "\*" and postroute delay increments are marked with "&". The asterisk symbol (\*) means back-annotation using preroute Elmore extraction or SDF.

To determine the current value of this variable, use the **printvar report\_timing\_use\_accurate\_delay\_symbol** command.

---

### **SEE ALSO**

[report\\_timing\(2\)](#)

---

## rom\_auto\_inferring

Infers ROM from the RTL description.

---

### TYPE

Boolean

---

### DEFAULT

true in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

When this variable is set to **true**, the tool attempts to infer ROM from the RTL description. When set to **false**, no attempt is made to infer ROM from the RTL description.

---

### SEE ALSO

compile(2)

---

## route\_guide\_attributes

Contains attributes related to route guide.

---

## DESCRIPTION

Contains attributes related to route guide.

You can use **get\_attribute** to determine value of an attribute, and use **report\_attribute** to get a report of all attributes on specified object. Specified with **list\_attribute -class route\_guide -application**, the definition of attributes can be listed.

### Route Guide Attributes

affects

Specifies the affects of a route guide, which is route.

The data type of **affects** is string.

This attribute is read-only.

area

Specifies area of a route guide.

The data type of **area** is float.

This attribute is read-only.

bbox

Specifies the bounding-box of a route guide. The **bbox** is represented by a **rectangle**.

The format of a **rectangle** specification is {{llx lly} {urx ury}}, which specifies the lower-left and upper-right corners of the rectangle.

The data type of **bbox** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

cell\_id

Specifies Milkyway design ID in which a route guide object is located.

The data type of **cell\_id** is integer.

This attribute is read-only.

design\_boundary\_blockage

Specifies the layers on which router will follow design boundary blockage rules.

The data type of **design\_boundary\_blockage** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

double\_pattern\_mask\_constraint

Specifies the coloring information of the route\_guide. This information is needed in the double patterning flow.

The data type of **double\_pattern\_mask\_constraint** is string.

The valid values can be: any\_mask, mask1\_soft, mask1\_hard, mask2\_soft, mask2\_hard and same\_mask.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### horizontal\_track\_utilization

Specifies the horizontal track utilization for the route guide.

The data type of **horizontal\_track\_utilization** is integer.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### layer

Specifies layer name on which a route guide is.

The data type of **layer** is string.

This attribute is read-only.

#### layer\_number

Specifies layer number on which a route guide is.

The data type of **layer\_number** is integer.

This attribute is read-only.

#### multiple\_pattern\_mask\_constraint

Specifies the coloring information of the route\_guide. This information is needed in the multiple patterning flow.

The data type of **multiple\_pattern\_mask\_constraint** is string.

The valid values can be: any\_mask, mask1\_soft, mask1\_hard, mask2\_soft, mask2\_hard, mask3\_soft, mask3\_hard and same\_mask.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### name

Specifies name of a route guide object.

The data type of **name** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### no\_preroute\_layers

Specifies the layers that cannot contain preroutes.

The data type of **no\_preroute\_layers** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### no\_signal\_layers

Specifies the layers that cannot contain signals.

The data type of **no\_signal\_layers** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### object\_class

Specifies object class name of a route guide, which is **route\_guide**.

The data type of **object\_class** is string.

This attribute is read-only.

#### object\_id

Specifies object ID in Milkyway design file.

The data type of **object\_id** is integer.

This attribute is read-only.

#### object\_type

Specifies geometry type of a route guide, which can be RECTANGLE or POLYGON.

The data type of **object\_type** is string.

This attribute is read-only.

#### points

Specifies point list of a route guide's boundary.

The data type of **points** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### preferred\_direction\_only\_layers

Specifies the layers that cannot make nonPreferredDirection wires.

The data type of **preferred\_direction\_only\_layers** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### repair\_as\_single\_sbox

Specifies whether this route guide should be repaired as a single sbox when there is a difficult violation on a prerouted wire or inside a large macro.

The data type of **repair\_as\_single\_sbox** is boolean.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### route\_guide\_group\_id

Route guides with the same route guide group id belong to the same route guide group.

#### switch\_preferred\_direction

Specifies whether to switch the preferred direction for the route guide.

The data type of **switch\_preferred\_direction** is boolean.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### switch\_preferred\_direction\_layers

Specifies the layers on which single layer routing should be encouraged.

The data type of **switch\_preferred\_direction\_layers** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### track\_utilization\_layers

Specifies the layers on which horizontal\_track\_utilization or vertical\_track\_utilization had been set.

The data type of **track\_utilization\_layers** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### type

Specifies the affects of a route guide, which is route.

The data type of **type** is string.

This attribute is read-only.

#### vertical\_track\_utilization

Specifies the vertical track utilization for the route guide.

The data type of **vertical\_track\_utilization** is integer.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### zero\_min\_spacing

Specifies whether zero minimum spacing is allowed for the route guide.

The data type of **zero\_min\_spacing** is boolean.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

---

## SEE ALSO

[get\\_attribute\(2\)](#)  
[list\\_attributes\(2\)](#)  
[report\\_attribute\(2\)](#)  
[set\\_attribute\(2\)](#)

---

## route\_guide\_naming\_style

Specifies the naming convention to be used by the **create\_route\_guide** command.

---

### TYPE

string

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

%s\_%d in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

This variable specifies the naming convention to be used by the **create\_route\_guide** command. The variable string must contain only one %s (percent s) and one %d (percent d) character sequence. To use a percent sign in the route guide name, two are needed in the string (%%).

---

### SEE ALSO

[create\\_route\\_guide\(2\)](#)

---

## routing\_corridor\_attributes

Contains attributes related to routing corridor.

---

### DESCRIPTION

Contains attributes related to routing corridor.

You can use **get\_attribute** to determine the value of an attribute, and use **report\_attribute** to get a report of all attributes on the specified object. Specified with **list\_attribute -class routing\_corridor -application**, the definition of attributes can be listed.

#### Routing Corridor Attributes

**name**

Specifies name of a routing corridor object.

The data type of **name** is string.

This attribute is read-only.

**nets**

Specifies the nets associated with the routing corridor.

The data type of **nets** is collection.

This attribute is read-only.

**object\_class**

Specifies object class name of a routing corridor, which is **routing\_corridor**.

The data type of **object\_class** is string.

This attribute is read-only.

---

### SEE ALSO

[get\\_attribute\(2\)](#)  
[list\\_attributes\(2\)](#)  
[report\\_attribute\(2\)](#)  
[set\\_attribute\(2\)](#)

---

# routing\_corridor\_shape\_attributes

Attributes related to routing corridor shapes.

---

## DESCRIPTION

This man page describes the attributes related to routing corridor shapes.

To list the definitions of the routing corridor shape attributes, use the **list\_attributes -application -class routing\_corridor\_shape** command.

To determine the value of an attribute, use the **get\_attribute** command. To get a report of all attributes on a specified object, use the **report\_attribute** command.

### Routing Corridor Shape Attributes

**bbox**

Specifies the bounding-box of a routing corridor shape, which is represented by a rectangle.

The format of a rectangle specification is {{llx lly} {urx ury}}, which specifies the lower-left and upper-right corners of the rectangle.

The data type of **bbox** is string.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

**max\_layer**

Specifies layer name for the maximum layer constraint for this shape.

The data type of **max\_layer** is string.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

**min\_layer**

Specifies layer name for the minimum layer constraint for this shape.

The data type of **min\_layer** is string.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

**name**

Specifies the name of a routing corridor shape.

The data type of **name** is string.

This attribute is read-only.

**object\_class**

Specifies object class name of a routing corridor shape, which is **routing\_corridor\_shape**.

The data type of **object\_class** is string.

This attribute is read-only.

---

## SEE ALSO

`get_attribute(2)`  
`list_attributes(2)`  
`report_attribute(2)`  
`set_attribute(2)`

---

## rp\_group\_attributes

Contains attributes that can be placed on a relative placement group.

---

## DESCRIPTION

Contains attributes that can be placed on a relative placement group.

To set an attribute, use the command identified in the individual description of that attribute. If an attribute is read-only, you cannot set it.

To determine the value of an attribute, use the **get\_attribute** command. To remove attributes, use the **remove\_attribute** command.

For a more detailed explanation of an attribute, see the man page of the appropriate **set** command. For information about all attributes, see the **attributes** man page.

### RP Group Attributes

#### alignment

Specifies the default alignment method to use when placing leaf cells and relative placement groups in the specified relative placement groups. If you do not specify this option, the tool uses bottom-left alignment.

You can set this attribute by using the **set\_rp\_group\_options** command.

#### allow\_non\_rp\_cells

Specifies that the hard keepout in the relative placement group should be overlapped with tap cells if needed. By default, the value is **false**.

You can set this attribute by using the **set\_rp\_group\_options** command.

#### anchor\_corner

Specifies the corner for the anchor point that is set by using the **-x\_offset** and **-y\_offset** options.

Valid values are **bottom-left** (the default), **bottom-right**, **top-left**, **top-right**, and **rp-location**.

If you specify **bottom-left**, the anchor point corner is the lower-left corner of the relative placement group.

If you specify **bottom-right**, the anchor point corner is the lower-right corner of the relative placement group.

If you specify **top-left**, the anchor point corner is the upper-left corner of the relative placement group.

If you specify **top-right**, the anchor point corner is the upper-right corner of the relative placement group.

If you specify **rp-location**, the anchor point corner is the starting location of the object at the row and column specified by the **-anchor\_row** and **-anchor\_column** options.

This option applies only to top-level relative placement groups and is ignored for hierarchical relative placement groups. When you specify **-anchor\_corner bottom-right**, the relative placement group is anchored at the bottom-right corner at the specified x- and y-coordinates during legalization. When many blockages are present, a slight deviation from the anchor point might occur.

You can set this attribute by using the **set\_rp\_group\_options** command.

#### cell\_orient\_opt

A Boolean value that specifies if cell orientation optimization is done for the cells of the relative placement group for optimizing wire-length. This is a read-only attribute and cannot be modified by the user.

#### columns

An integer value that specifies the number of columns of the specified relative placement group.

This is a read-only attribute and cannot be modified by the user.

#### compress

A Boolean variable that specifies if compression is set in the horizontal direction to a relative placement group during placement. Setting this option places each row of a relative placement group without any gaps between leaf cells, lower-level hierarchical relative placement groups, or keepouts. Column alignment is not maintained when you use the **-compress** option.

You can set this attribute by using the **set\_rp\_group\_options** command.

#### is\_top

A Boolean value that specifies whether a relative placement group is the top.

This is a read-only attribute and cannot be modified by the user.

#### cts\_option

Specifies how to treat the cells in the relative placement group during clock tree synthesis and clock tree optimization.

Valid values are **fixed\_placement** (the default) and **size\_only**.

If you specify **fixed\_placement**, the cells in the relative placement group are treated as fixed during the **compile\_clock\_tree**, **optimize\_clock\_tree**, and **clock\_opt** commands and cannot be sized or moved.

If you specify **size\_only**, the cells in the relative placement group can only be sized. This option is applicable to the **compile\_clock\_tree**, **optimize\_clock\_tree**, and **clock\_opt** commands.

You can set this attribute by using the **set\_rp\_group\_options** command.

#### group\_orient

A string that specifies the user-specified orientation that is set on the relative placement group.

Valid values are **default**, **N** (north), **S** (south), **FN** (flip-north), and **FS** (flip-south). The default is **N**.

You can set this attribute by using the **set\_rp\_group\_options** command.

#### ignore

A Boolean value that specifies whether a relative placement group is ignored.

You can set this attribute by using the **set\_rp\_group\_options** command.

#### move\_effort

A string that specifies the move effort of relative placement group.

Valid values are **high**, **medium** (the default), and **low**.

You can set this attribute by using the **set\_rp\_group\_options** command.

#### name

A string that specifies the full name of a relative placement group.

This is a read-only attribute and cannot be modified by the user.

#### pin\_align\_name

A string that specifies the name of pin on which the relative placement cells will be aligned.

You can set this attribute by using the **set\_rp\_group\_options** command.

#### placement\_type

A string that specifies the type of placement of a relative placement group.

You can set this attribute by using the **set\_rp\_group\_options** command.

#### psynopt\_option

Specifies the behavior of the relative placement cells of the specified relative placement group during the **psynopt** command.

You can set this attribute by using the **set\_rp\_group\_options** command.

#### route\_opt\_option

Specifies the behavior of the relative placement cells of the specified relative placement group during the **route\_opt** command.

You can set this attribute by using the **set\_rp\_group\_options** command.

#### rows

An integer value that specifies the number of rows of a relative placement group.

This is a read-only attribute and cannot be modified by the user.

#### rp\_height

A string that specifies the height of a relative placement group. It contains an estimated height before placement and the actual height if the relative placement group has gone through any kind of placement.

This is a read-only attribute and cannot be modified by the user.

#### rp\_width

A string that specifies the width of a relative placement group. It contains an estimated width before placement and the actual width if the relative placement group has gone through any kind of placement.

This is a read-only attribute and cannot be modified by the user.

#### placed\_orient

A string that specifies the placed orientation of a relative placement group.

Valid values are **N**, **S**, **FN**, and **FS**. If the relative placement group is not placed, it reports that the relative placement group is not placed.

This is a read-only attribute and cannot be modified by the user.

#### is\_placed

A Boolean value that specifies whether a relative placement group is placed.

If the relative placement group is placed without any critical failures, it is set to **true**; otherwise, it is set to **false**.

This is a read-only attribute and cannot be modified by the user.

#### utilization

A floating point nonzero, positive value that specifies the area utilization of a relative placement group.

The default 1. The maximum value is 1.

You can set this attribute by using the **set\_rp\_group\_options** command.

#### x\_offset

A floating point value that specifies the x-coordinate of a relative placement group's anchor point.

You can set this attribute by using the **set\_rp\_group\_options** command.

#### y\_offset

A floating point value that specifies the y-coordinate of a relative placement group's anchor point.

You can set this attribute by using the **set\_rp\_group\_options** command.

#### anchor\_row

An integer value that specifies the row of the object for which the rp-location anchor corner is specified.

You can set this attribute by using the **set\_rp\_group\_options** command.

#### anchor\_column

An integer value that specifies the column of the object for which the rp-location anchor corner is specified.

You can set this attribute by using the **set\_rp\_group\_options** command.

---

## rtl\_load\_resistance\_factor

Specifies a factor to be used by the **set\_rtl\_load** command to calculate resistance values from capacitance values for RTL loads.

---

### TYPE

float

---

### DEFAULT

0

---

### DESCRIPTION

This variable specifies a factor to be used by the **set\_rtl\_load** command to calculate resistance values from capacitance values for RTL loads.

You do not need to specify resistance values directly to **set\_rtl\_load**. Instead, you can cause the resistance value to be calculated as a constant factor times capacitance by setting the **rtl\_load\_resistance\_factor** variable to the constant factor required. Then, you execute **set\_rtl\_load** with only the **-capacitance** option, and the command calculates the resistance from the specified capacitance using the constant factor.

For example, if you set the **rtl\_load\_resistance** variable to 0.5, specify the rtl-load capacitance of a pin as 4, and do not specify the rtl-load resistance, **set\_rtl\_load** calculates the rtl-load resistance to be 2. The factor is applied to each annotated pin of a net individually, not to the net's capacitance as a whole. Note that the default library units are used throughout.

To determine the current value of this variable, use the **printvar rtl\_load\_resistance\_factor** command.

---

### SEE ALSO

`remove_rtl_load(2)`  
`set_rtl_load(2)`

---

## sdc\_runtime\_analysis\_enable

Issues information messages to identify and fix runtime issues related to SDC constraints. This might impact quality of reports (QoR) as SDC constraints might be relaxed.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable helps you to debug only SDC issues in your design that result in long runtime. If you suspect long runtime is due to SDC constraints, set the **sdc\_runtime\_analysis\_enable** variable to **true** to identify and debug runtime issues related to SDC constraints. The tool

- Identifies and reports SDC issues
- Generates a Tcl file with potential fixes for the identified SDC issues by relaxing a few constraints.

You must review the Tcl file for your design intent and source the Tcl file during the next compile session after setting the **sdc\_runtime\_analysis\_enable** variable to **false** to see improvements in the runtime of the tool.

You can get an estimate of runtime benefit after applying the SDC fixes in the same debug run (instead of sourcing the file during the next compile session). This feature is available in the Design Compiler NXT tool.

The Design Compiler NXT tool automatically applies the potential fixes (provided in the Tcl file) in the same debug run. There might be an impact on QoR when you enable automatic fixing of SDC issues in the Design Compiler NXT tool due to the change in SDC constraints during the same debug run.

**Note:** Do not keep the **sdc\_runtime\_analysis\_enable** variable always set to **true**. Use the variable only to debug runtime issues related to SDC constraints.

To avoid the Design Compiler NXT tool from automatically applying the fixes provided in the Tcl file for SDC issues, set the **sdc\_runtime\_fixing\_enable** variable to **false**. The default is **true**.

```
dc_shell-topo> set_app_var sdc_runtime_analysis_enable true
```

For more details about the different SDC constraints identified and the potential fixes applied by the tool, see the "Reporting Runtime Issues Related to SDC Constraints" section in the Design Compiler User Guide.

The Design Compiler NXT and Design Compiler Graphical tools by default generate a Tcl script (`sdc_runtime_<timestampl>.log.tcl`) with the information message and Tcl commands to disable the identified SDC constraints that cause runtime issues. For example, `sdc_runtime_24_10_2019_02_11_20.log`.

To specify a different log file name or a standard output file, use the **sdc\_runtime\_analysis\_log\_file** variable.

The following variable creates a new log file name to redirect the output to the my\_log\_file.log file and to redirect Tcl file to the my\_log\_file.tcl file:

```
prompt> set_app_var sdc_runtime_analysis_log_file my_log_file.log
```

The following variable redirects log output to sdc\_runtime<timestamp>.log and redirects Tcl file to sdc\_runtime<timestamp>.log.tcl:

```
prompt> set_app_var sdc_runtime_analysis_log_file
```

The following variable redirects log to a standard output console and redirects Tcl file to sdc\_runtime<timestamp>.log.tcl

```
prompt> set_app_var sdc_runtime_analysis_log_file ""
```

---

## SEE ALSO

[sdc\\_runtime\\_analysis\\_log\\_file\(3\)](#)  
[sdc\\_runtime\\_nets\\_missing\\_exceptions\\_fanout\\_threshold\(3\)](#)  
[sdc\\_runtime\\_top\\_fanout\\_nets\\_missing\\_exceptions\(3\)](#)  
[sdc\\_runtime\\_paths\\_missing\\_inter\\_clock\\_constraints\(3\)](#)  
[sdc\\_runtime\\_port\\_clock\\_constraint\\_threshold\(3\)](#)  
[sdc\\_runtime\\_tightly\\_constrained\\_path\\_group\\_slack\\_percentage\(3\)](#)  
[sdc\\_runtime\\_tightly\\_constrained\\_same\\_clock\\_path\\_groups\(3\)](#)  
[sdc\\_runtime\\_hier\\_block\\_pins\\_timing\\_path\\_threshold\(3\)](#)  
[sdc\\_runtime\\_hier\\_block\\_pins\\_top\\_timing\\_paths\(3\)](#)  
[sdc\\_runtime\\_unused\\_clocks\\_threshold\(3\)](#)  
[sdc\\_runtime\\_fixing\\_enable\(3\)](#)

---

## sdc\_runtime\_analysis\_log\_file

Redirects logs to a file.

---

### TYPE

String

---

### DEFAULT

sdc\_runtime.log

---

### DESCRIPTION

This variable is used to redirect logs to a file. Note that you must set the **sdc\_runtime\_analysis\_enable** variable to true to use this variable.

If a file name is not specified, the information messages are stored in the sdc\_runtime.log file. To specify a new log file name, use the variable as follows:

```
set_app_var sdc_runtime_analysis_enable true  
set_app_var sdc_runtime_analysis_log_file my_log_file.log - a new log file name to redirect it to a my_log_file.log  
set_app_var sdc_runtime_analysis_log_file - redirects log to sdc_runtime.log  
set_app_var sdc_runtime_analysis_log_file "" - redirects log to standard output console
```

---

### SEE ALSO

[sdc\\_runtime\\_analysis\\_enable\(3\)](#)

---

## sdc\_runtime\_fixing\_enable

Fixes the runtime issues related to SDC constraints, identified when sdc\_runtime\_analysis\_enable switch is enabled.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable controls the dirty constraints fixes, which helps in improving runtime. You can disable this variable if automatic fixing of dirty constraints is not needed. Enabling SDC fixing can change the QoR trajectory in the compile run. The fixed constraints are written out to a Tcl file to support customization.

You can use the tcl commands in your tcl script to review the fixes. By default, the **sdc\_runtime\_fixing\_enable** variable is set to true. To set the variable to false,

```
dc_shell-t0> set_app_var sdc_runtime_fixing_enable false
```

If a file name is not specified, the tcl commands are stored in the sdc\_runtime\_<timestamp>.log.tcl file. To specify a file name, use the **sdc\_runtime\_analysis\_log\_file** variable. To redirect the messages to a tcl file, use the variable as follows:

```
set_app_var sdc_runtime_analysis_log_file my_log_file.log - a new log file name to redirect it to a my_log_file.log.tcl
```

```
set_app_var sdc_runtime_analysis_log_file - redirects tcl to sdc_runtime<timestamp>.log.tcl
```

```
set_app_var sdc_runtime_analysis_log_file "" - also redirects tcl to sdc_runtime<timestamp>.log.tcl
```

---

### SEE ALSO

[sdc\\_runtime\\_analysis\\_enable\(3\)](#)  
[sdc\\_runtime\\_analysis\\_log\\_file\(3\)](#)  
[sdc\\_runtime\\_nets\\_missing\\_exceptions\\_fanout\\_threshold\(3\)](#)  
[sdc\\_runtime\\_top\\_fanout\\_nets\\_missing\\_exceptions\(3\)](#)  
[sdc\\_runtime\\_paths\\_missing\\_inter\\_clock\\_constraints\(3\)](#)  
[sdc\\_runtime\\_port\\_clock\\_constraint\\_threshold\(3\)](#)  
[sdc\\_runtime\\_tightly\\_constrained\\_path\\_group\\_slack\\_percentage\(3\)](#)  
[sdc\\_runtime\\_tightly\\_constrained\\_same\\_clock\\_path\\_groups\(3\)](#)

---

## **sdc\_runtime\_hier\_block\_pins\_timing\_path\_threshold**

Controls the timing arcs threshold and the number of pins to display when the design has hierachical blocks.

---

### **TYPE**

Integer

---

### **DEFAULT**

500

---

### **DESCRIPTION**

When the tool spends huge time during buffering, this could be due to high number of timing arcs through the hierachical block pins in the design.

The variable controls threshold value of number of timing arcs for displaying the TIM-609 message.

By default, the tool prints this message only when number of timing arcs through hierarchical pin exceeds 500 in a design.

The variable setting is effective only when you set the **sdc\_runtime\_analysis\_enable** variable to true.

---

### **SEE ALSO**

[sdc\\_runtime\\_hier\\_block\\_pins\\_top\\_timing\\_paths\(3\)](#)  
[sdc\\_runtime\\_analysis\\_enable\(3\)](#)

---

## **sdc\_runtime\_hier\_block\_pins\_top\_timing\_paths**

Controls the display of number of pins with high timing arcs when the design has hierarichal blocks.

---

### **TYPE**

Integer

---

### **DEFAULT**

100

---

### **DESCRIPTION**

When the tool spends huge time during buffering, this could be due to high number of timing arcs through the hierarichal block pins in the design.

The variable controls the display of hierarichal pins with high number of timing arcs under TIM-609 message.

By default, the tool prints this message only for the top 100 such pins in a design.

The variable setting is effective only when you set the **sdc\_runtime\_analysis\_enable** variable to true.

---

### **SEE ALSO**

`sdc_runtime_hier_block_pins_timing_path_threshold(3)`  
`sdc_runtime_analysis_enable(3)`

---

## sdc\_runtime\_nets\_missing\_exceptions\_fanout\_threshold

Controls the fanout threshold and the number of nets to display when high-fanout nets are not set with the **set\_ideal\_network** or **set\_dont\_touch** command.

---

### TYPE

Integer

---

### DEFAULT

500

---

### DESCRIPTION

When the tool spends huge time during buffering, this could be due to high-fanout nets in the design. In such cases, the timing complexity could be because of the high-fanout nets that are not set with the **ideal\_network** or **dont\_touch** constraint.

For more information, see the TIM-606 information message. By default, the variable prints this message for only top 100 paths with fanout > 100 that are not set with the **set\_ideal\_network** or **set\_dont\_touch** command.

The variable controls the fanout threshold and the number of nets to display when high-fanout nets are not set with the **ideal\_network** or **dont\_touch** constraints.

The variable setting is effective only when you set the **sdc\_runtime\_analysis\_enable** variable to true.

---

### SEE ALSO

[sdc\\_runtime\\_top\\_fanout\\_nets\\_missing\\_exceptions\(3\)](#)  
[sdc\\_runtime\\_analysis\\_enable\(3\)](#)

---

## **sdc\_runtime\_paths\_missing\_inter\_clock\_constraints**

Controls the number of paths to display when inter-clock constraints are missing for each path group.

---

### **TYPE**

Integer

---

### **DEFAULT**

5

---

### **DESCRIPTION**

If the worst net slack (WNS) printed is high in a design log file, the reason could be missing multicycle or false path constraint. This is because you missed applying multicycle or false path constraints. Optimizing the design in such cases could increase runtime.

For more information, see the TIM-608 information message. By default, the variable prints this message for only 5 paths for each path group with tightly constrained paths that do not have false or multicycle path.

The variable controls the number of paths to display when inter-clock constraints are missing for each path group. The variable setting is effective only when you set the **sdc\_runtime\_analysis\_enable** variable to true.

---

### **SEE ALSO**

[sdc\\_runtime\\_analysis\\_enable\(3\)](#)

---

## **sdc\_runtime\_port\_clock\_constraint\_threshold**

Controls the number of paths to display for each port.

---

### **TYPE**

Integer

---

### **DEFAULT**

20

---

### **DESCRIPTION**

When there are too many clocks associated with input and output pins, it can mean that there are multiple timing paths through a pin. Optimizing the design in such cases could increase runtime. The variable controls the number of paths to display for each port.

For more information, see the TIM-607 information message. By default, the variable prints this message only when the number of paths on a port exceed 20.

The variable setting is effective only when you set the **sdc\_runtime\_analysis\_enable** variable to true.

---

### **SEE ALSO**

[sdc\\_runtime\\_analysis\\_enable\(3\)](#)

---

## **sdc\_runtime\_tightly\_constrained\_path\_group\_slack\_percentage**

Sets the threshold to determine whether a path is tightly constrained.

---

### **TYPE**

Integer

---

### **DEFAULT**

75

---

### **DESCRIPTION**

The variable sets the threshold for determining whether a path is tightly constrained. It considers paths with critical slack more than 75 percent of a clock period.

For more information, see the TIM-602 information message. By default, the variable prints this message only when paths with slack more than 75 percent of a clock period are tightly constrained.

The variable setting is effective only when you set the **sdc\_runtime\_analysis\_enable** variable to true.

---

### **SEE ALSO**

---

## **sdc\_runtime\_tightly\_constrained\_same\_clock\_path\_groups**

Sets the threshold to identify whether too many path groups use the same clock.

---

### **TYPE**

Integer

---

### **DEFAULT**

50

---

### **DESCRIPTION**

This variable is a threshold for identifying whether there are too many path groups using the same clock.

For more information, see the TIM-603 information message. By default, the variable prints this message only when more than 50 path groups are created with a single clock.

The variable setting is effective only when you set the **sdc\_runtime\_analysis\_enable** variable to true.

---

### **SEE ALSO**

[sdc\\_runtime\\_analysis\\_enable\(3\)](#)

---

## sdc\_runtime\_top\_fanout\_nets\_missing\_exceptions

Controls the fanout threshold and the number of nets to display when high-fanout nets are not set with the **set\_ideal\_network** or **set\_dont\_touch** command.

---

### TYPE

Integer

---

### DEFAULT

100

---

### DESCRIPTION

The variable controls the fanout threshold and the number of nets to display when high-fanout nets that are not set with the **ideal\_network** or **dont\_touch** constraints.

For more information, see the TIM-606 information message. By default, the variable prints this message for only top 100 paths with fanout > 100 that are not set with the **set\_ideal\_network** or **set\_dont\_touch** command.

The variable setting is effective only when you set the **sdc\_runtime\_analysis\_enable** variable to true.

---

### SEE ALSO

[sdc\\_runtime\\_analysis\\_enable\(3\)](#)  
[sdc\\_runtime\\_nets\\_missing\\_exceptions\\_fanout\\_threshold\(3\)](#)

---

## **sdc\_runtime\_unused\_clocks\_threshold**

Controls the minimum number of unused clocks required in the design, to enable display of TIM-601 messages

---

### **TYPE**

Integer

---

### **DEFAULT**

5

---

### **DESCRIPTION**

Tool can take extra runtime to work on unused clocks in the design. In such cases, it is better to remove such clocks to save time.

By default, the tool prints the TIM-601 message only when the design has more than 5 unused clocks. Use this variable to control this threshold.

The variable setting is effective only when you set the **sdc\_runtime\_analysis\_enable** variable to true.

---

### **SEE ALSO**

[sdc\\_runtime\\_top\\_fanout\\_nets\\_missing\\_exceptions\(3\)](#)  
[sdc\\_runtime\\_analysis\\_enable\(3\)](#)

---

## sdc\_write\_unambiguous\_names

Ensures that cell, net, pin, lib\_cell, and lib\_pin names that are written to the SDC file are not ambiguous.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable ensures that cell, net, pin, lib\_cell, and lib\_pin names that are written to the SDC file are not ambiguous.

When the hierarchy has been partially flattened, embedded hierarchy separators can make names ambiguous. It is unclear which hierarchy separator characters are part of the name and which are real separators.

Beginning with SDC Version 1.2, hierarchical names can be made unambiguous using the **set\_hierarchy\_separator** SDC command and/or the **-hsc** option for the **get\_cells**, **get\_lib\_cells**, **get\_lib\_pins**, **get\_nets**, and **get\_pins** SDC object access commands. By default, the tools write an SDC file, using these features to create unambiguous names.

It is wise to write SDC files that contain names that are not ambiguous. However, if you are using a third-party application that does not fully support SDC 1.2 or later versions (that is, it does not support the unambiguous hierarchical names features of SDC), you can suppress these features by setting the variable **sdc\_write\_unambiguous\_names** to **false**. The **write\_sdc** command issues a warning if you have set this variable to **false**.

To determine the current value of this variable, use the **printvar sdc\_write\_unambiguous\_names** command.

---

### SEE ALSO

**printvar(2)**  
**write\_sdc(2)**

---

## sdfout\_allow\_non\_positive\_constraints

Writes out PATHCONSTRAINT constructs with nonpositive ( $\leq 0$ ) constraint values. This variable will be obsolete in the next release. Please adjust your scripts accordingly.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Writes out PATHCONSTRAINT constructs with nonpositive ( $\leq 0$ ) constraint values. When *true*, **write\_constraints -format sdf** writes out PATHCONSTRAINT constructs with nonpositive ( $\leq 0$ ) constraint values. When *false* (the default), paths with nonpositive constraints are written with a constraint value of 0.01.

Nonpositive constraints can occur when the arrival time at a path startpoint is larger than the required arrival time at the path endpoint. This typically indicates an error, but is sometimes valid when generating constraints for a subdesign.

To determine the current value of this variable, type **printvar sdfout\_allow\_non\_positive\_constraints**. For a list of all **links\_to\_layout** variables and their current values, type **print\_variable\_group links\_to\_layout**.

---

### SEE ALSO

---

## sdfout\_min\_fall\_cell\_delay

Specifies the minimum non-back-annotated fall cell delay that the **write\_timing** command writes to a timing file in SDF format. This variable will be obsolete in the next release. Please adjust your scripts accordingly.

---

### TYPE

float

---

### DEFAULT

0 in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Specifies the minimum non-back-annotated fall cell delay that the **write\_timing** command writes to a timing file in SDF format. The value of this variable can be *positive*, *negative*, or *zero* (the default); the unit must be the same as the timing unit in the technology library.

By default, if this variable is not set, **write\_timing** writes to the SDF file all fall cell delay values greater than or equal to zero. You can override this default behavior for non-back-annotated delays by setting **sdfout\_min\_fall\_cell\_delay** to a minimum value; **write\_timing** does not write values that are less than this minimum. However, you cannot override the default behavior for back-annotated delays; **write\_timing** always writes values of delays that have been back-annotated, regardless of the value of this variable.

Use this variable to filter non-back-annotated delays so that **write\_timing** writes only values that are significant (greater than the specified minimum value). Also, if you do not want non-annotated fall cell delays to be written to the SDF file, set this variable to a value higher than any of the non-annotated cell delays in the design.

---

### SEE ALSO

[sdfout\\_min\\_rise\\_cell\\_delay\(3\)](#)

---

## sdfout\_min\_fall\_net\_delay

Specifies the minimum non-back-annotated fall net delay that **write\_timing** can write to a timing file in SDF format. This variable will be obsolete in the next release. Please adjust your scripts accordingly.

---

### TYPE

float

---

### DEFAULT

0 in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Specifies the minimum non-back-annotated fall net delay that **write\_timing** can write to a timing file in SDF format. The value of this variable can be *positive*, *negative*, or *zero* (the default); the unit must be the same as the timing unit in the technology library.

By default, if this variable is not set, **write\_timing** writes to the SDF file all fall net delay values greater than or equal to zero. You can override this default behavior for non-back-annotated delays by setting **sdfout\_min\_fall\_net\_delay** to a minimum value; **write\_timing** does not write values that are less than this minimum. However, you cannot override the default behavior for back-annotated delays; **write\_timing** always writes values of delays that have been back-annotated, regardless of the value of this variable.

Use this variable to filter non-back-annotated delays so that **write\_timing** writes only values that are significant (greater than the specified minimum value). Also, if you do not want any non-annotated fall net delays to be written to the SDF file, set this variable to a value higher than any of the non-annotated net delays in the design.

---

### SEE ALSO

[sdfout\\_min\\_rise\\_net\\_delay\(3\)](#)

---

## sdfout\_min\_rise\_cell\_delay

Specifies the minimum non-back-annotated rise cell delay that **write\_timing** can write to a timing file in SDF format. This variable will be obsolete in the next release. Please adjust your scripts accordingly.

---

### TYPE

float

---

### DEFAULT

0 in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Specifies the minimum non-back-annotated rise cell delay that **write\_timing** can write to a timing file in SDF format. The value of this variable can be *positive*, *negative*, or *zero* (the default); the unit must be the same as the timing unit in the technology library.

By default, if this variable is not set, **write\_timing** writes to the SDF file all rise cell delay values greater than or equal to zero. You can override this default behavior for non-back-annotated delays by setting **sdfout\_min\_rise\_cell\_delay** to a minimum value; **write\_timing** will not write values less than this minimum. However, you cannot override the default behavior for back-annotated delays; **write\_timing** always writes values of delays that have been back-annotated, regardless of the value of this variable.

Use this variable to filter non-back-annotated delays so that **write\_timing** writes only values that are significant (greater than the specified minimum value). Also, if you do not want any non-annotated rise cell delays to be written to the SDF file, set this variable to a value higher than any of the non-annotated cell delays in the design.

---

### SEE ALSO

[sdfout\\_min\\_fall\\_cell\\_delay\(3\)](#)

---

## sdfout\_min\_rise\_net\_delay

Specifies the minimum non-back-annotated rise net delay that the **write\_timing** command can write to a timing file in SDF format. This variable will be obsolete in the next release. Please adjust your scripts accordingly.

---

### TYPE

float

---

### DEFAULT

0 in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Specifies the minimum non-back-annotated rise net delay that the **write\_timing** command can write to a timing file in SDF format. The value of this variable can be *positive*, *negative*, or *zero* (the default); the unit must be the same as the timing unit in the technology library.

By default, if this variable is not set, **write\_timing** writes to the SDF file all rise net delay values greater than or equal to zero. You can override this default behavior for non-back-annotated delays by setting **sdfout\_min\_rise\_net\_delay** to a minimum value; **write\_timing** does not write values less than this minimum. However, you cannot override the default behavior for back-annotated delays; **write\_timing** always writes values of delays that have been back-annotated, regardless of the value of this variable.

Use this variable to filter non-back-annotated delays so that **write\_timing** writes only values that are significant (greater than the specified minimum value). Also, if you do not want any non-annotated rise net delays to be written to the SDF file, set this variable to a value higher than any of the non-annotated net delays in the design.

---

### SEE ALSO

[sdfout\\_min\\_fall\\_net\\_delay\(3\)](#)

---

## sdfout\_time\_scale

Specifies the time scale of the delays written to timing files in SDF format. This variable will be obsolete in the next release. Please adjust your scripts accordingly.

---

### TYPE

float

---

### DEFAULT

1 in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Specifies the time scale of the delays written to timing files in SDF format. Delays from Design Compiler are written to timing files with **write\_timing**. The **sdfout\_time\_scale** variable must be set if the library has no time unit specified and if the time unit of the delays in the library is different than 1 nanosecond. By default, the time unit is nanosecond and the time scale is 1. The only valid values for the SDF format are 0.001, 0.01, 0.1, 1, 10 and 100. The time unit is specified in the library with the attributes **time\_scale** and **time\_unit\_name**.

For example, a library with timing values in 10 picoseconds is specified with the attributes:

time\_scale = 10 and time\_unit\_name = ps

When the attribute **time\_scale** is missing in the library, use the **sdfout\_time\_scale** variable to specify the scale of the timing unit. For example, if the library has no time unit specified but is in 10 ns, set **sdfout\_time\_scale** to 10 in order to specify the time unit as 10 ns.

---

### SEE ALSO

---

## sdfout\_top\_instance\_name

Specifies the name prepended to all instance names when writing timing files in SDF format. This variable will be obsolete in the next release. Please adjust your scripts accordingly.

---

### TYPE

string

---

### DEFAULT

"" in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Specifies the name prepended to all instance names when writing timing files in SDF format. Timing files are written with the **write\_timing** command. By default **write\_timing** prepends no name to all cell instance names. Set this variable when you want the cell instance names to contain a prepended name.

For example set **sdfout\_top\_instance\_name = "stim.cell1"** if the timing file should contain:

```
(DESIGN "fifo")
(DIVIDER .)
(CELL
  (CELLTYPE "fifo")
  (INSTANCE stim\cell1)
)
(CELL
  (CELLTYPE "AND2")
  (INSTANCE stim\cell1.U1)
```

With the previous example, if **sdfout\_top\_instance\_name = ""** timing file will contain:

```
(DESIGN "fifo")
(DIVIDER .)
(CELL
  (CELLTYPE "fifo")
  (INSTANCE )
)
(CELL
  (CELLTYPE "AND2")
  (INSTANCE U1))
```

## SEE ALSO

---

## sdfout\_write\_to\_output

Specifies whether the **write\_timing -f sdf** command writes interconnect delays between cells and top-level output ports. This variable will be obsolete in the next release. Please adjust your scripts accordingly.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Specifies whether the **write\_timing -f sdf** command writes interconnect delays between cells and top-level output ports. The **sdfout\_write\_to\_output** variable also determines whether output to output pin IOPATH statements are written for cells that contain output-to-output timing arcs. v1.0 SDF does not support output-to-output timing for either IOPATH or INTERCONNECT statements. However, the Synopsys Simulator does support output-to-output timing for these statements.

Set this variable to *true*, if the targeted SDF reader is the Synopsys Simulator.

Leave this variable set to *false*, the default, to ensure that generated SDF files comply with the v1.0 specification.

Set this variable before using **write\_timing**. To check the value of this variable, use the command **printvar sdfout\_write\_to\_output**.

---

### SEE ALSO

---

## search\_path

Specifies directories that the tool searches for files specified without directory names.

---

### TYPE

list

---

### DEFAULT

{*search\_path* + .}

---

### DESCRIPTION

This variable specifies directories that the tool searches for files specified without directory names. The search includes looking for technology and symbol libraries, design files, and so on. The value of this variable is a list of directory names and is usually set to a central library directory.

To determine the current value of this variable, use the **printvar search\_path** command. For a list of all system variables and their current values, use the **print\_variable\_group system** command.

---

### SEE ALSO

---

## seqmap\_prefer\_registers\_with\_multibit\_equivalent

Controls the **compile\_ultra** command for preferentially mapping sequential cells to single-bit registers with compatible multibit registers.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When this variable is set to **true**, the **compile\_ultra** command tries to map the registers using single-bit registers with equivalent multibit registers. The goal is to improve the multibit register's packing ratio of the design.

To determine the current value of the **seqmap\_prefer\_registers\_with\_multibit\_equivalent** variable, use the **printvar seqmap\_prefer\_registers\_with\_multibit\_equivalent** command.

For a list of all compile variables and their current values, use the **print\_variable\_group compile** command.

---

### SEE ALSO

[hdlin\\_infer\\_multibit\(3\)](#)

---

## sh\_allow\_tcl\_with\_set\_app\_var

Allows the **set\_app\_var** and **get\_app\_var** commands to work with application variables.

---

### TYPE

string

---

### DEFAULT

true

---

### DESCRIPTION

Normally the **get\_app\_var** and **set\_app\_var** commands only work for variables that have been registered as application variables. Setting this variable to **true** allows these commands to set a Tcl global variable instead.

These commands issue a CMD-104 error message for the Tcl global variable, unless the variable name is included in the list specified by the **sh\_allow\_tcl\_with\_set\_app\_var\_no\_message\_list** variable.

---

### SEE ALSO

[get\\_app\\_var\(2\)](#)  
[set\\_app\\_var\(2\)](#)

---

## **sh\_allow\_tcl\_with\_set\_app\_var\_no\_message\_list**

Suppresses CMD-104 messages for variables in this list.

---

### **TYPE**

string

---

### **DEFAULT**

""

---

### **DESCRIPTION**

This variable is consulted before printing the CMD-104 error message, if the **sh\_allow\_tcl\_with\_set\_app\_var** variable is set to **true**. All variables in this Tcl list receive no message.

---

### **SEE ALSO**

[get\\_app\\_var\(2\)](#)  
[set\\_app\\_var\(2\)](#)

---

## sh\_arch

Indicates the system architecture of your machine.

---

### TYPE

string

---

### DEFAULT

linux64

---

### DESCRIPTION

The **sh\_arch** variable is set by the application to indicate the system architecture of your machine. Examples of machines being used are sparcOS5, amd64, and so on. This variable is read-only.

---

## sh\_command\_abbrev\_mode

Sets the command abbreviation mode for interactive convenience.

---

### TYPE

string

---

### DEFAULT

Anywhere

---

### DESCRIPTION

This variable sets the command abbreviation mode as an interactive convenience. Script files should not use any command or option abbreviation, because these files are then susceptible to command changes in subsequent versions of the application.

Although the default value is **Anywhere**, it is recommended that the site startup file for the application set this variable to **Command-Line-Only**. It is also possible to set the value to **None**, which disables abbreviations altogether.

To determine the current value of this variable, use the **get\_app\_var sh\_command\_abbrev\_mode** command.

---

### SEE ALSO

[sh\\_command\\_abbrev\\_options\(3\)](#)  
[get\\_app\\_var\(2\)](#)  
[set\\_app\\_var\(2\)](#)

---

## sh\_command\_abbrev\_options

Turns off abbreviation of command dash option names when false.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When command abbreviation is currently off (see sh\_command\_abbrev\_mode) then setting this variable to false will also not allow abbreviation of command dash options. This variable also impacts abbreviation of the values specified to command options that expect values to be one of an allowed list of values.

This variable exists to be backward compatible with previous tool releases which always allowed abbreviation of command dash options and option values regardless of the command abbreviation mode.

It is recommended to set the value of this variable to false.

To determine the current value of this variable, use the **get\_app\_var sh\_command\_abbrev\_options** command.

---

### SEE ALSO

[sh\\_command\\_abbrev\\_mode\(3\)](#)  
[get\\_app\\_var\(2\)](#)  
[set\\_app\\_var\(2\)](#)

---

## sh\_command\_log\_file

Specifies the name of the file to which is written a log of the initial values of variables and executed commands.

---

### TYPE

string

---

### DEFAULT

command.log

---

### DESCRIPTION

Specifies the name of the file to which is written a log of the initial values of variables and executed commands.

By default, the tool writes the log to a file named command.log. If the value is an empty string, a command log file is not created.

To determine the current value of this variable, use the **printvar sh\_command\_log\_file** command.

---

### SEE ALSO

[printvar\(2\)](#)  
[view\\_command\\_log\\_file\(3\)](#)  
[view\\_log\\_file\(3\)](#)

---

## sh\_continue\_on\_error

Allows processing to continue when errors occur during script execution with the **source** command.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

It is recommended to use the **-continue\_on\_error** option to the **source** command instead of this variable because that option only applies to a single script, and not the entire application session.

When set to **true**, the **sh\_continue\_on\_error** variable allows processing to continue when errors occur. Under normal circumstances, when executing a script with the **source** command, Tcl errors (syntax and semantic) cause the execution of the script to terminate.

When **sh\_continue\_on\_error** is set to **false**, script execution can also terminate due to new error and warning messages based on the value of the **sh\_script\_stop\_severity** variable.

To determine the current value of the **sh\_continue\_on\_error** variable, use the **get\_app\_var sh\_continue\_on\_error** command.

---

### SEE ALSO

[get\\_app\\_var\(2\)](#)  
[set\\_app\\_var\(2\)](#)  
[source\(2\)](#)  
[sh\\_script\\_stop\\_severity\(3\)](#)

---

## sh\_DEPRECATED\_IS\_ERROR

Raise a Tcl error when a deprecated command is executed.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When set this variable causes a Tcl error to be raised when an deprecated command is executed. Normally only a warning message is issued.

---

### SEE ALSO

[get\\_app\\_var\(2\)](#)  
[set\\_app\\_var\(2\)](#)

---

## sh\_dev\_null

Indicates the current null device.

---

### TYPE

string

---

### DEFAULT

/dev/null

---

### DESCRIPTION

This variable is set by the application to indicate the current null device. For example, on UNIX machines, the variable is set to **/dev/null**. This variable is read-only.

---

### SEE ALSO

[get\\_app\\_var\(2\)](#)

---

## sh\_enable\_stdout\_redirect

Allows the redirect command to capture output to the Tcl stdout channel.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When set to **true**, this variable allows the redirect command to capture output sent to the Tcl stdout channel. By default, the Tcl **puts** command sends its output to the stdout channel.

---

### SEE ALSO

[get\\_app\\_var\(2\)](#)  
[set\\_app\\_var\(2\)](#)

---

## sh\_help\_shows\_group\_overview

Changes the behavior of the "help" command.

---

### TYPE

string

---

### DEFAULT

true

---

### DESCRIPTION

This variable changes the behavior of the **help** command when no arguments are specified to help. Normally when no arguments are specified an informational message with a list of available command groups is displayed.

When this variable is set to false the command groups and the commands in each group is printed instead. This variable exists for backward compatibility.

---

### SEE ALSO

[help\(2\)](#)  
[set\\_app\\_var\(2\)](#)

---

## sh\_new\_variable\_message

Controls a debugging feature for tracing the creation of new variables.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

The **sh\_new\_variable\_message** variable controls a debugging feature for tracing the creation of new variables. Its primary debugging purpose is to catch the misspelling of an application-owned global variable. When set to **true**, an informational message (CMD-041) is displayed when a variable is defined for the first time at the command line. When set to **false**, no message is displayed.

Note that this debugging feature is superseded by the new **set\_app\_var** command. This command allows setting only application-owned variables. See the **set\_app\_var** command man page for details.

Other variables, in combination with **sh\_new\_variable\_message**, enable tracing of new variables in scripts and Tcl procedures.

Warning: This feature has a significant negative impact on CPU performance when used with scripts and Tcl procedures. This feature should be used only when developing scripts or in interactive use. When you turn on the feature for scripts or Tcl procedures, the application issues a message (CMD-042) to warn you about the use of this feature.

To determine the current value of this variable, use the **get\_app\_var sh\_new\_variable\_message** command.

---

### SEE ALSO

[get\\_app\\_var\(2\)](#)  
[set\\_app\\_var\(2\)](#)  
[sh\\_new\\_variable\\_message\\_in\\_proc\(3\)](#)  
[sh\\_new\\_variable\\_message\\_in\\_script\(3\)](#)

---

## sh\_new\_variable\_message\_in\_proc

Controls a debugging feature for tracing the creation of new variables in a Tcl procedure.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

The **sh\_new\_variable\_message\_in\_proc** variable controls a debugging feature for tracing the creation of new variables in a Tcl procedure. Its primary debugging purpose is to catch the misspelling of an application-owned global variable.

Note that this debugging feature is superseded by the new **set\_app\_var** command. This command allows setting only application-owned variables. Please see the **set\_app\_var** command man page for details.

Note that the **sh\_new\_variable\_message** variable must be set to **true** for this variable to have any effect. Both variables must be set to **true** for the feature to be enabled. Enabling the feature simply enables the **print\_proc\_new\_vars** command. In order to trace the creation of variables in a procedure, this command must be inserted into the procedure, typically as the last statement. When all of these steps have been taken, an informational message (CMD-041) is generated for new variables defined within the procedure, up to the point that the **print\_proc\_new\_vars** command is executed.

Warning: This feature has a significant negative impact on CPU performance. This should be used only when developing scripts or in interactive use. When you turn on the feature, the application issues a message (CMD-042) to warn you about the use of this feature.

To determine the current value of this variable, use the **get\_app\_var sh\_new\_variable\_message\_in\_proc** command.

---

### SEE ALSO

[get\\_app\\_var\(2\)](#)  
[set\\_app\\_var\(2\)](#)  
[sh\\_new\\_variable\\_message\(3\)](#)  
[sh\\_new\\_variable\\_message\\_in\\_script\(3\)](#)

---

## sh\_new\_variable\_message\_in\_script

Controls a debugging feature for tracing the creation of new variables within a sourced script.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

The **sh\_new\_variable\_message\_in\_script** variable controls a debugging feature for tracing the creation of new variables within a sourced script. Its primary debugging purpose is to catch the misspelling of an application-owned global variable.

Note that this debugging feature is superseded by the new **set\_app\_var** command. This command allows setting only application-owned variables. See the **set\_app\_var** command man page for details.

Note that the **sh\_new\_variable\_message** variable must be set to **true** for this variable to have any effect. Both variables must be set to **true** for the feature to be enabled. In that case, an informational message (CMD-041) is displayed when a variable is defined for the first time. When **sh\_new\_variable\_message\_in\_script** is set to **false** (the default), no message is displayed at the time that the variable is created. When the **source** command completes, however, you see messages for any new variables that were created in the script. This is because the state of the variables is sampled before and after the **source** command. It is not because of inter-command sampling within the script. So, this is actually a more efficient method to see if new variables were created in the script.

For example, given the following script a.tcl:

```
echo "Entering script"
set a 23
echo a = $a
set b 24
echo b = $b
echo "Exiting script"
```

When **sh\_new\_variable\_message\_in\_script** is **false** (the default), you see the following when you source the script:

```
prompt> source a.tcl
Entering script
a = 23
b = 24
Exiting script
Information: Defining new variable 'a'. (CMD-041)
Information: Defining new variable 'b'. (CMD-041)
prompt>
```

Alternatively, when **sh\_new\_variable\_message\_in\_script** is **true**, at much greater cost, you see the following when you source the script:

```
prompt> set sh_new_variable_message_in_script true
Warning: Enabled new variable message tracing -
          Tcl scripting optimization disabled. (CMD-042)
true
prompt> source a.tcl
Entering script
Information: Defining new variable 'a'. (CMD-041)
a = 23
Information: Defining new variable 'b'. (CMD-041)
b = 24
Exiting script
prompt>
```

Warning: This feature has a significant negative impact on CPU performance. This should be used only when developing scripts or in interactive use. When you turn on the feature, the application issues a message (CMD-042) to warn you about the use of this feature.

To determine the current value of this variable, use the **get\_app\_var sh\_new\_variable\_message\_in\_script** command.

---

## SEE ALSO

[get\\_app\\_var\(2\)](#)  
[set\\_app\\_var\(2\)](#)  
[sh\\_new\\_variable\\_message\(3\)](#)  
[sh\\_new\\_variable\\_message\\_in\\_proc\(3\)](#)

---

## **shObsoleteIsError**

Raise a Tcl error when an obsolete command is executed.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

When set this variable causes a Tcl error to be raised when an obsolete command is executed. Normally only a warning message is issued.

Obsolete commands have no effect.

---

### **SEE ALSO**

[get\\_app\\_var\(2\)](#)  
[set\\_app\\_var\(2\)](#)

---

## sh\_output\_log\_file

This variable is used to name the file to record console output. Set the variable to the empty string to disable output capture.

---

### TYPE

*String*

---

### DEFAULT

""

---

### DESCRIPTION

This variable can be used to save almost all console output to a log file. The log file is useful for bug reproduction and reporting.

The first time the variable is set to a valid filename, all previously logged output is written to the specified file, overwriting any previous contents of the file. All subsequent logged output is appended to the file unless the variable is later reset.

If the variable is later changed to an empty string, all logged output is disabled.

If the variable is later set to an non-empty string that is an invalid filename, the new value is ignored and the old value is restored.

If the variable is later set to an non-empty string that is an valid filename, all subsequent logged output is written to this file. Any previous contents of the file are overwritten.

The log file may not capture the banner text from the beginning of the session, and does not capture the stack trace that is printed following a fatal error. You can use the UNIX tee command or redirect the output to capture this information.

This variable is not available in de\_shell mode.

---

### SEE ALSO

[printvar\(2\)](#)

---

## sh\_product\_version

Indicates the version of the application currently running.

---

### TYPE

string

---

### DESCRIPTION

This variable is set to the version of the application currently running. The variable is read only.

To determine the current value of this variable, use the **get\_app\_var sh\_product\_version** command.

---

### SEE ALSO

[get\\_app\\_var\(2\)](#)

---

## sh\_script\_stop\_severity

Indicates the error message severity level that would cause a script to stop running before it completes.

---

### TYPE

string

---

### DEFAULT

None

---

### DESCRIPTION

When a script is run with the **source** command, there are several ways to get it to stop running before it completes. One is to use the **sh\_script\_stop\_severity** variable. This variable can be set to **none**, **W**, or **E**.

- When set to **E**, the generation of one or more error messages by a command causes a script to stop.
- When set to **W**, the generation of one or more warning or error messages causes a script to stop.
- When set to **none**, the generation messages does not cause the script to stop.

Note that **sh\_script\_stop\_severity** is ignored if **sh\_continue\_on\_error** is set to **true**.

To determine the current value of this variable, use the **get\_app\_var sh\_script\_stop\_severity** command.

---

### SEE ALSO

[get\\_app\\_var\(2\)](#)  
[set\\_app\\_var\(2\)](#)  
[source\(2\)](#)  
[sh\\_continue\\_on\\_error\(3\)](#)

---

## sh\_source\_emits\_line\_numbers

Indicates the error message severity level that causes an informational message to be issued, listing the script name and line number where that message occurred.

---

### TYPE

string

---

### DEFAULT

None

---

### DESCRIPTION

When a script is executed with the **source** command, error and warning messages can be emitted from any command within the script. Using the **sh\_source\_emits\_line\_numbers** variable, you can help isolate where errors and warnings are occurring.

This variable can be set to **none**, **W**, or **E**.

- When set to **E**, the generation of one or more error messages by a command causes a CMD-082 informational message to be issued when the command completes, giving the name of the script and the line number of the command.
- When set to **W**, the generation of one or more warning or error messages causes a the CMD-082 message.

The setting of **sh\_script\_stop\_severity** affects the output of the CMD-082 message. If the setting of **sh\_script\_stop\_severity** causes a CMD-081 message, then it takes precedence overCMD-082.

To determine the current value of this variable, use the **get\_app\_var sh\_source\_emits\_line\_numbers** command.

---

### SEE ALSO

[get\\_app\\_var\(2\)](#)  
[set\\_app\\_var\(2\)](#)  
[source\(2\)](#)  
[sh\\_continue\\_on\\_error\(3\)](#)  
[sh\\_script\\_stop\\_severity\(3\)](#)  
[CMD-081\(n\)](#)  
[CMD-082\(n\)](#)

---

## sh\_source\_logging

Indicates if individual commands from a sourced script should be logged to the command log file.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When you source a script, the **source** command is echoed to the command log file. By default, each command in the script is logged to the command log file as a comment. You can disable this logging by setting **sh\_source\_logging** to **false**.

To determine the current value of this variable, use the **get\_app\_var sh\_source\_logging** command.

---

### SEE ALSO

[get\\_app\\_var\(2\)](#)  
[set\\_app\\_var\(2\)](#)  
[source\(2\)](#)

---

## sh\_source\_uses\_search\_path

Causes the **search** command to use the **search\_path** variable to search for files. This variable is for use in **dc\_shell-t** (Tcl mode of dc\_shell) only.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

Causes the **search** command to use the **search\_path** variable to search for files, when **sh\_source\_uses\_search\_path** is *true* (the default). When *false*, the **source** command considers this variable's file argument literally. This variable is for use in **dc\_shell-t** (Tcl mode of dc\_shell) only.

To determine the current value of this variable, use **printvar sh\_source\_uses\_search\_path**.

---

### SEE ALSO

[printvar\(2\)](#)  
[source\(2\)](#)  
[search\\_path\(3\)](#)

---

## sh\_tcllib\_app dirname

Indicates the name of a directory where application-specific Tcl files are found.

---

### TYPE

string

---

### DESCRIPTION

The **sh\_tcllib\_app dirname** variable is set by the application to indicate the directory where application-specific Tcl files and packages are found. This is a read-only variable.

---

### SEE ALSO

[get\\_app\\_var\(2\)](#)

---

## sh\_user\_man\_path

Indicates a directory root where you can store man pages for display with the **man** command.

---

### TYPE

list

---

### DEFAULT

""

---

### DESCRIPTION

The **sh\_user\_man\_path** variable is used to indicate a directory root where you can store man pages for display with the **man** command. The directory structure must start with a directory named *man*. Below *man* are directories named *cat1*, *cat2*, *cat3*, and so on. The **man** command will look in these directories for files named *file.1*, *file.2*, and *file.3*, respectively. These are pre-formatted files. It is up to you to format the files. The **man** command effectively just types the file.

These man pages could be for your Tcl procedures. The combination of defining help for your Tcl procedures with the **define\_proc\_attributes** command, and keeping a manual page for the same procedures allows you to fully document your application extensions.

The **man** command will look in **sh\_user\_man\_path** after first looking in application-defined paths. The user-defined paths are consulted only if no matches are found in the application-defined paths.

To determine the current value of this variable, use the **get\_app\_var sh\_user\_man\_path** command.

---

### SEE ALSO

**define\_proc\_attributes(2)**  
**get\_app\_var(2)**  
**man(2)**  
**set\_app\_var(2)**

---

## shape\_attributes

Attributes related to shapes.

---

### DESCRIPTION

This man page describes attributes related to shapes.

To list the definitions of the shape attributes, use the **list\_attribute -application -class shape** command.

To determine the value of an attribute, use the **get\_attribute** command.

To report all attributes on a specified object, use the **report\_attribute** command.

#### Shape Attributes

**bbox**

Specifies the bounding-box of a shape.

The **bbox** attribute is represented by a rectangle. The format of a rectangle specification is `{llx lly} {urx ury}`, which specifies the lower-left and upper-right corners of the rectangle.

The data type of **bbox** is string.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

**bbox\_ll**

Specifies the lower-left corner of the bounding-box of a shape.

The **bbox\_ll** attribute is represented by a point. The format of a point specification is `{x y}`.

You can get the **bbox\_ll** attribute of a shape by accessing the first element of its **bbox** attribute.

The data type of **bbox\_ll** is string.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

**bbox\_llx**

Specifies the x-coordinate of the lower-left corner of the bounding-box of a shape.

The data type of **bbox\_llx** is integer.

This attribute is read-only.

**bbox\_lly**

Specifies the y-coordinate of the lower-left corner of the bounding-box of a shape.

The data type of **bbox\_lly** is integer.

This attribute is read-only.

**bbox\_ur**

Specifies the upper-right corner of the bounding-box of a shape.

The \fbbox\_ur attribute is represented by a point. The format of a point specification is {x y}.

You can get the **bbox\_ur** attribute of a shape by accessing the second element of its **bbox** attribute.

The data type of **bbox\_ur** is string.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

#### bbox\_urx

Specifies the x-coordinate of the upper-right corner of the bounding-box of a shape.

The data type of **bbox\_urx** is integer.

This attribute is read-only.

#### bbox\_ury

Specifies the y-coordinate of the upper-right corner of the bounding-box of a shape.

The data type of **bbox\_ury** is integer.

This attribute is read-only.

#### cell\_id

Specifies the Milkyway design ID in which a shape object is located.

The data type of **cell\_id** is integer.

This attribute is read-only.

#### datatype\_number

Specifies the GDSII datatype number of a shape object.

The data type of **datatype\_number** is integer.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

#### double\_pattern\_mask\_constraint

Specifies the coloring information for a shape. This information is needed in the double-patterning flow.

The data type of **double\_pattern\_mask\_constraint** is string.

Its valid values are

- **any\_mask**
- **mask1\_soft**
- **mask1\_hard**
- **mask2\_soft**
- **mask2\_hard**
- **same\_mask**

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

#### endcap

Specifies the alignment type for the end of a wire or path shape.

The data type of **endcap** is string.

Its valid values are

- **square\_ends**
- **round\_ends**
- **square\_ends\_by\_half\_width**
- **octagon\_ends\_by\_half\_width**

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

#### is\_via\_ladder

Specifies the via ladder is true or not.

The data type of **is\_via\_ladder** is boolean.

This attribute is writable.

#### layer

Specifies the layer name of a shape.

The data type of **layer** is string.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

#### layer\_name

Specifies the layer name of a shape.

The data type of **layer\_name** is string.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

#### layer\_number

Specifies the layer number of a shape.

The data type of **layer\_number** is integer.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

#### length

Specifies the length of a wire or path shape in user units.

The data type of **length** is float.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

#### multiple\_pattern\_mask\_constraint

Specifies the coloring information for a shape. This information is needed in the multiple-patterning flow.

The data type of **multiple\_pattern\_mask\_constraint** is string.

Its valid values are

- **any\_mask**
- **mask1\_soft**
- **mask1\_hard**
- **mask2\_soft**
- **mask2\_hard**
- **mask3\_soft**

- **mask3\_hard**
- **same\_mask**

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

#### name

Specifies the name of a shape.

The data type of **name** is string.

This attribute is read-only.

#### net\_id

Specifies the object ID of the net associated with a shape.

The data type of **net\_id** is integer.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

#### net\_type

Specifies the type of net associated with a shape.

The data type of **net\_type** is string.

This attribute is read-only.

#### object\_class

Specifies the object class name of a shape, which is **shape**.

The data type of **object\_class** is string.

This attribute is read-only.

#### object\_id

Specifies the object ID in the Milkyway design file.

The data type of **object\_id** is integer.

This attribute is read-only.

#### object\_type

Specifies the object type, which can be **RECTANGLE**, **POLYGON**, **TRAPEZOID**, **PATH**, **HWIRE**, or **VWIRE**.

The data type of **object\_type** is string.

This attribute is read-only.

#### owner

Specifies the Milkyway design file name in which a shape is located.

The data type of **owner** is string.

This attribute is read-only.

#### owner\_net

Specifies the name of the net to which a shape is connected.

The data type of **owner\_net** is string.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

**points**

Specifies the point list of a shape's boundary.

The data type of **points** is string.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

**route\_type**

Specifies the route type of a shape.

The data type of **route\_type** is string.

Its valid values are

- **User Enter** or **user\_enter**
- **Signal Route** or **signal\_route**
- **Signal Route (Global)** or **signal\_route\_global**
- **P/G Ring** or **pg\_ring**
- **Clk Ring** or **clk\_ring**
- **P/G Strap** or **pg\_strap**
- **Clk Strap** or **clk\_strap**
- **P/G Macro/IO Pin Conn** or **pg\_macro\_io\_pin\_conn**
- **P/G Std. Cell Pin Conn** or **pg\_std\_cell\_pin\_conn**
- **Zero-Skew Route** or **clk\_zero\_skew\_route**
- **Bus** or **bus**
- **Shield (fix)** or **shield**
- **Shield (dynamic)** or **shield\_dynamic**
- **Fill Track** or **clk\_fill\_track**
- **Unknown** or **unknown**

The **mw\_attr\_value\_no\_space** variable determines whether the **get\_attribute** or **report\_attribute** command returns the value containing spaces or underscores.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

**width**

Specifies the width of a wire or path shape in user units.

The data type of **width** is float.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

---

## SEE ALSO

[get\\_attribute\(2\)](#)  
[list\\_attributes\(2\)](#)  
[report\\_attribute\(2\)](#)

```
set_attribute(2)
```

---

## si\_ccs\_use\_gate\_level\_simulation

Affects the behavior of timing analysis and postroute optimization when crosstalk effects are enabled.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

si\_variables

---

### DESCRIPTION

This variable affects the behavior of timing analysis and postroute optimization when crosstalk effects are enabled.

When set to **true**, it enables the use of CCS noise engine for delta delay computation. To use this feature, make sure that your library contains proper CCS noise data.

Enabling this feature improves the IC Compiler and PrimeTime SI correlation, but it can lead to runtime increase.

To determine the current value of this variable, use the **get\_app\_var si\_ccs\_use\_gate\_level\_simulation** command.

---

### SEE ALSO

`report_timing(2)`

---

## si\_max\_parallel\_computations

Sets the degree of parallelism used for parallel signal integrity computations.

---

### TYPE

integer

---

### DEFAULT

0

---

### DESCRIPTION

This application variable specifies the degree of parallelism used for parallel signal integrity computations.

When the variable has a value of **1**, parallel signal integrity computation is disabled.

When the variable has a value of **0** (the default), or a value that is larger than **1**, parallel signal integrity computation is enabled.

---

### SEE ALSO

[set\\_host\\_options\(2\)](#)

---

## **si\_xtalk\_composite\_aggr\_noise\_peak\_ratio**

Controls the composite aggressor selection for crosstalk analysis.

---

### **TYPE**

float

---

### **DEFAULT**

0.01

---

### **DESCRIPTION**

Specifies the threshold value in crosstalk bump to VDD ratio, below which aggressors are selected into the composite aggressor group. The default is *0.01*, which means all the aggressor nets with crosstalk bump to VDD ratio less than *0.01* is selected into the composite aggressor group. This variable works together with other filtering threshold variables, **si\_filter\_per\_aggr\_noise\_peak\_ratio** and **si\_filter\_accum\_aggr\_noise\_peak\_ratio**, to determine which aggressors can be selected into the composite aggressor group.

To determine the current value of this variable, use the following command:

```
printvar si_xtalk_composite_aggr_noise_peak_ratio
```

---

### **SEE ALSO**

**si\_filter\_per\_aggr\_noise\_peak\_ratio(3)**  
**si\_filter\_accum\_aggr\_noise\_peak\_ratio(3)**  
**si\_xtalk\_composite\_aggr\_quantile\_high\_pct(3)**

---

## **si\_xtalk\_composite\_aggr\_quantile\_high\_pct**

Controls the composite aggressor creation for statistical analysis.

---

### **TYPE**

float

---

### **DEFAULT**

99.73

---

### **DESCRIPTION**

Sets the desired probability in percentage format that any given real combined bump height is less than or equal to the computed composite aggressor bump height. Given the desired probability, the resulting quantile value for the composite aggressor bump height is calculated.

The default of this variable is 99.73, which corresponds to a 3-sigma probability that the real bump height from any randomly-chosen combination of aggressors is covered by the composite aggressor bump height.

To determine the current value of this variable, use the following command:

```
prompt> printvar si_xtalk_composite_aggr_quantile_high_pct
```

---

### **SEE ALSO**

`si_xtalk_composite_aggr_noise_peak_ratio(3)`

---

## simplified\_verification\_mode

Performs optimization so that formal verification is prioritized over quality of results (QoR).

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

none

---

### DESCRIPTION

Setting this variable to **true** adjusts optimization inside the tool to prioritize formal verification compatibility over QoR. This enables single-pass verification for formal verification to pass with as little effort as possible. The variable is set to **false** by default.

This variable affects the optimization done during the reading and elaboration of RTL files and when the **insert\_clock\_gating** and **compile\_ultra** commands are run.

When you set this variable to **true**, the **compile\_ultra** command runs with the **-no\_autoungroup** option enabled. However, the **-retime** option of the **compile\_ultra** command is ignored, and the **-global** option of the **insert\_clock\_gating** and **replace\_clock\_gates** commands is ignored.

The tool sets the value for the following environment variables when the **simplified\_verification\_mode** variable is set to **true** regardless of the value you specify:

```
compile_ultra_ungroup_dw = false,  
compile_clock_gating_through_hierarchy = false  
hdlin_verification_priority = true
```

The value for these variables is restored to the user-specified value when you set the **simplified\_verification\_mode** variable to **false**. If you do not specify the value for these variables, the tool uses the default value.

When you run the **compile\_ultra** command, the **simplified\_verification\_mode** variable adjusts the optimizations on datapath logic. It also identifies CRC logic in the design and isolates it by creating a new hierarchy.

When you set the **simplified\_verification\_mode** variable to **true**, designs with the **optimize\_registers** attribute and DW\_div\_pipe components are not retimed because they can adversely affect verification success. However, optimizing these designs without

retiming them can have a large impact on QoR and runtime. To enable the retiming of these designs, set the **simplified\_verification\_mode\_allow\_retimig** variable to **true** when you enable the **simplified\_verification\_mode** variable.

---

## SEE ALSO

[simplified\\_verification\\_mode\\_allow\\_retimig\(3\)](#)

---

## simplified\_verification\_mode\_allow\_retiming

Controls whether **DW\_div\_pipe** components and designs with the **optimize\_registers** attribute are retimed when the **simplified\_verification\_mode** variable is set to **true**.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

none

---

### DESCRIPTION

When you set the **simplified\_verification\_mode** variable to **true**, designs with the **optimize\_registers** attribute and DW\_div\_pipe components are not retimed because they can adversely affect verification success. However, optimizing these designs without retiming them can have a large impact on QoR and runtime. To enable the retiming of these designs, set the **simplified\_verification\_mode\_allow\_retiming** variable to **true** when you enable the **simplified\_verification\_mode** variable.

---

### SEE ALSO

[simplified\\_verification\\_mode\(3\)](#)

---

## **single\_group\_per\_sheet**

Specifies to the tool to put only 1 logic group on a sheet.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### **DESCRIPTION**

This variable specifies to the tool to put only 1 logic group on a sheet. Using this partitioning option set to **true** eliminates the possibility of more than 1 off-sheet connector with the same name being on a single sheet. The default value is **false**.

---

### **SEE ALSO**

---

## **site\_info\_file**

Contains the path to the site information file for licensing.

---

### **TYPE**

string

---

### **DEFAULT**

""

---

### **DESCRIPTION**

This variable contains the path to the site information file for licensing. The default value is the empty string.

---

## site\_row\_attributes

Contains attributes related to site row.

---

### DESCRIPTION

Contains attributes related to site row.

You can use **get\_attribute** to determine value of an attribute, and use **report\_attribute** to get a report of all attributes on specified site row. Specified with **list\_attribute -class site\_row -application**, the definition of attributes can be listed.

#### Site Row Attributes

cell\_id

Specifies Milkyway design ID in which a site row object is located.

This attribute is read-only.

name

Specifies name of a site row object.

This attribute is read-only.

object\_class

Specifies object class name of a site row object, which is **site\_row**.

This attribute is read-only.

object\_id

Specifies object ID in Milkyway design file.

This attribute is read-only.

bbox

Specifies the bbox of a site row object.

This attribute is read-only.

bbox\_ll

Specifies the lower-left of a site row object.

This attribute is read-only.

bbox\_llx

Specifies x coordinate of the lower\_left of the bbox a site row object.

This attribute is read-only.

bbox\_lly

Specifies y coordinate of the lower\_left of the bbox a site row object.

This attribute is read-only.

#### **bbox\_ur**

Specifies the upper-right of the bbox of a site row object.

This attribute is read-only.

#### **bbox\_urx**

Specifies x coordinate of the upper-right of the bbox a site row object.

This attribute is read-only.

#### **bbox\_ury**

Specifies y coordinate of the upper-right of the bbox a site row object.

This attribute is read-only.

#### **site\_type**

Specifies the type of site being defined.

This attribute is read-only.

#### **orientation**

Specifies the orientation of the sites. The value can be N, W, S, E, FN, FW, FS, FE.

This attribute is read-only.

#### **direction**

Specifies the direction of the row. The value can be v, h, vertical and horizontal.

This attribute is read-only.

#### **site\_count**

Specifies the number of the sites in the row.

This attribute is read-only.

#### **site\_space**

Specifies the space for each site, from the lower left corner of the site to the lower left corner of the next site. The value is specified in microns.

This attribute is read-only.

#### **origin**

Specifies the lower left corner of the row, regardless of orientation.

This attribute is read-only.

#### **allowable\_pattern**

Specifies the restricted orientations of placed cells on a specified row, which are based on what direction of row is, whether row is flipped and what direction of unit tile is.

This attribute is read-only.

#### **row\_type**

It is just a positive integer associated with site rows. Later on set\_cell\_row\_type can be used to associate one particular cell with some particular rows of corresponding row\_type.

This attribute can be read, set and removed.

#### is\_ignored

TRUE: ignore specified site row FALSE: The specified site row is not ignored

The attribute can be read and set.

#### is\_reserved\_placement\_area

The attribute is true if the site row has the property "is\_reserved\_placement\_area".

The attribute is read-only.

---

## SEE ALSO

`get_attribute(2)`  
`list_attributes(2)`  
`report_attribute(2)`

---

## sort\_outputs

Sorts output ports on the schematic by port name.

---

### TYPE

string

---

### DEFAULT

false

---

### DESCRIPTION

This variable sorts output ports on the schematic by port name.

---

## **spg\_auto\_ndr\_net\_length\_threshold**

Restricts the length of the nets assigned nondefault routing rules during optimization.

---

### **TYPE**

Integer

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

100 in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **GROUP**

syn-qor

---

### **DESCRIPTION**

Sets a minimum length threshold on nets that are considered for nondefault routing rules during optimization in the Design Compiler Graphical tool. The value you specify is multiplied by the minimum height of the unit tile.

For example, if you specify a threshold value of 100, the minimum length of the nets considered for nondefault routing rule assignment is 100 times the minimum height of the unit tile.

---

### **SEE ALSO**

`compile_ultra(2)`

---

## **spg\_congestion\_placement\_in\_incremental\_compile**

Enables congestion-driven placement in incremental compile to improve congestion while preserving quality of results.

---

### **TYPE**

Boolean

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXT non-topographical mode

false in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

When you set the **spg\_congestion\_placement\_in\_incremental\_compile** variable to **true** before running **compile\_ultra -incremental**, the tool runs congestion-driven placement during incremental compilation to improve congestion. This variable also improves congestion correlation between post-incremental compile and post **place\_opt** results.

You do not need to enable Zroute to use the variable. If Zroute is enabled, the tool runs congestion-driven placement in incremental compile by default.

---

### **EXAMPLES**

The following example shows how to enable and disable congestion-driven placement in incremental compile for a design:

```
prompt> set_app_var spg_congestion_placement_in_incremental_compile true  
prompt> set_app_var spg_congestion_placement_in_incremental_compile false
```

---

### **SEE ALSO**

[compile\\_ultra\(2\)](#)  
[set\\_attribute\(2\)](#)  
[get\\_attribute\(2\)](#)  
[remove\\_attribute\(2\)](#)

---

## spg\_enable\_multithreaded\_zroute

Enables multicore Zroute during compile passes which optionally use the Zroute global router.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

false in Design Compiler topographical mode and DC Explorer

true in Design Compiler NXT topographical mode

---

### DESCRIPTION

This feature is available only in Design Compiler-NXT.

This variable enables deterministic multicore Zroute during compile passes which use the Zroute global routing. Zroute is called by 'compile\_ultra -spg' under certain higher-effort settings, such as placer\_enable\_enhanced\_router, and set\_ahfs\_options -global\_route. not used under default compile settings.

When set to **true** (the default), if Zroute is run during compile, it uses a deterministic multithreaded mode to improve runtime.

Routing results are repeatable for a given number of cores, so that quality of results will not vary between runs if the same number of cores is specified using the set\_host\_options command. Results will differ between runs which use different numbers of cores (so for example, two identical runs using 4 cores will produce the same result as each other, and two identical runs using 8 cores will match, but the 4 core runs will differ from the 8 core runs.)

When set to **false**, Zroute global routing will use a single core for routing during compile.

This variable does not affect the behavior of global routing performed as part of the report\_congestion command.

---

### SEE ALSO

set\_host\_options(2)  
set\_ahfs\_options(2)  
report\_congestion(2)  
placer\_enable\_enhanced\_router(3)  
placer\_congestion\_effort(3)

---

## **spg\_enable\_via\_ladder\_opto**

Enable via ladder optimization by setting this variable before **compile\_ultra -spg**.

---

### **TYPE**

Boolean

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **GROUP**

syn-qor

---

### **DESCRIPTION**

Controls the support of via ladder optimization at the end of **compile\_ultra -spg**.

The default value for this variable is false.

---

### **SEE ALSO**

[compile\\_ultra\(2\)](#)

---

## **spg\_enable\_zroute\_layer\_promotion**

Enables the promotion of nets to multiple layers using global routing.

---

### **TYPE**

Boolean

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

When enable the variable, Design Compiler Graphical chooses a range of layers for promotion. Candidate nets are chosen based on length, and the tool uses global routing to determine the best set of nets to promote and the exact range of layers for each net. The pattern-based matching can also be used to control the candidate nets.

Setting the variable to **true** uses Zroute for global routing; therefore, it might have a significant impact on runtime.

---

## **spg\_enhanced\_timing\_model**

Enables the use of enhanced timing models for RC estimation when using the default RC extraction.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### **DESCRIPTION**

Controls the support of enhanced timing models for RC estimation when using the default RC extraction. You do not have to use this variable when using the new RC extraction engine that is enabled with the **spg\_icc2\_rc\_correlation** variable. This is because the new RC extraction engine already uses the advanced RC model to improve the RC correlation with the IC Compiler II tool.

To enable the use of enhanced timing models for RC estimation, set the variable to **true**.

To see the current value of this variable, use the **printvar spg\_enhanced\_timing\_model** command.

---

### **SEE ALSO**

`extract_rc(2)`  
`spg_icc2_rc_correlation(3)`

---

## **spg\_high\_effort\_mux\_area\_structuring**

Enables high-effort area structuring optimization.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true

---

### **DESCRIPTION**

This variable enables high-effort dedicated area structuring targeting mux and select tree structures. The optimization allows these structures to share control logic with common controls in order to improve the design area.

---

## spg\_icc2\_rc\_correlation

Performs a new RC extraction to improve the RC correlation with the IC Compiler II tool

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXT non-topographical mode

false in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

When you set this variable to true, the extract\_rc command performs RC extraction by using the advanced RC model to improve the RC correlation with the IC Compiler II tool.

When you use the compile\_ultra, compile\_ultra - incremental, and optimize\_netlist commands and explicitly run the **extract\_rc** command, the tool issues the **RCEX-302** message to indicate that this feature is enabled for optimization and extraction.

This feature is available only in

- The lower technology when metal layer have significant difference in resistance value
- The Design Compiler NXT tool

To determine the current value of this variable, use the spg\_icc2\_rc\_correlation command

---

### SEE ALSO

[extract\\_rc\(2\)](#)

---

## **spg\_place\_enable\_precluster**

Enables a placer mode change to reduces QoR variations for small design changes.

---

### **TYPE**

Boolean

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode, DC Explorer, and Design Compiler NXTnon-topographical mode

true in Design Compiler topographical mode and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

When enabling the variable, Design Compiler Graphical placer to be more aware of logic modules and naturally clumped groups of logic in your netlist. In general, the resulting placement will have improved quality with respect to these structures. The placement of modules and logic clumps will be more predictable from run to run. Small changes in your netlist or your constraints will not perturb where modules are placed. Logic modules are more likely to be properly placed near fixed connections such as ports and macros. Logic modules and logic clumps will generally be more self-cohesive. That is, a module is more likely to be placed in one physical area instead of more than one. Note that some logic modules may be composed of several loosely connected clumps. These loosely connected modules will still be divided if it helps QOR.

---

## ssf\_current\_version

Show the current version supported by SSF reader and writer.

---

### TYPE

string

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer 1.1 in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### DESCRIPTION

This variable denotes the current version of SSF file reader and writer in the tool. It is a read-only variable.

To determine the current version of SSF file, use the printvar command.

---

### SEE ALSO

[ssf\\_supported\\_versions\(3\)](#)  
[save\\_ssf\(2\)](#)  
[printvar\(2\)](#)

---

## **ssf\_supported\_versions**

Show the supported versions by SSF reader and writer.

---

### **TYPE**

string

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer 1.0 1.1 in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

This variable denotes the supported versions of SSF file reader and writer in the tool. It is a read-only variable.

To determine the supported versions of SSF file, use the printvar command.

---

### **SEE ALSO**

[ssf\\_current\\_version\(3\)](#)  
[save\\_ssf\(2\)](#)  
[printvar\(2\)](#)

---

# supply\_net\_attributes

Describes the attributes related to supply nets.

---

## DESCRIPTION

This man page describes the attributes related to supply nets. These attributes are defined only in UPF mode.

You can use the **get\_attribute** command to determine value of an attribute, and use the **report\_attribute** command to get a report of all the attributes on a specified supply net. To see all supply net attributes, use the **list\_attribute -class supply\_net -application** command.

### Supply Net Attributes

cell\_id

Specifies Milkyway design ID in which a supply net object is located.

This attribute is read-only.

internal\_supply\_net

Specifies whether a supply net object is internal.

When the supply net is set to internal, it can be connected with switched macro internal PG pins, derive\_pg\_connection won't try to connect this internal supply net.

This attribute is writable. You can use **set\_attribute** to set its value.

name

Specifies name of a supply net object.

This attribute is read-only.

full\_name

Specifies full name of a supply net object.

This attribute is read-only.

object\_class

Specifies object class name of a supply net object, which is **supply\_net**.

This attribute is read-only.

object\_id

Specifies object ID in Milkyway design file.

This attribute is read-only.

within\_block\_abstraction

Specifies whether the supply net is part of the block abstraction.

The data type of **within\_block\_abstraction** is boolean.

This attribute is read-only and cannot be modified.

#### within\_ilm

Specifies whether the supply net is part of an ILM.

The data type of **within\_ilm** is boolean.

This attribute is read-only and cannot be modified.

---

## SEE ALSO

`get_attribute(2)`  
`list_attributes(2)`  
`report_attribute(2)`

---

# supply\_port\_attributes

Describes the attributes related to supply ports.

---

## DESCRIPTION

This man pages describes the attributes related to supply ports. The attributes are defined only in UPF mode.

You can use the **get\_attribute** command to determine value of an attribute, and use the **report\_attribute** command to get a report of all attributes on a specified supply port. To see all supply port attributes, use the **list\_attribute -class supply\_port -application** command.

### Supply Port Attributes

cell\_id

Specifies Milkyway design ID in which a supply port object is located.

This attribute is read-only.

direction

Specifies the direction of a supply port object. The value can be "in" or "out".

This attribute is read-only.

full\_name

Specifies full name of a supply port object.

This attribute is read-only.

name

Specifies name of a supply port object.

This attribute is read-only.

object\_class

Specifies object class name of a supply port object, which is **supply\_port**.

This attribute is read-only.

object\_id

Specifies object ID in Milkyway design file.

This attribute is read-only.

within\_block\_abstraction

Specifies whether the supply port is part of the block abstraction.

The data type of **within\_block\_abstraction** is Boolean.

This attribute is read-only and cannot be modified.

**within\_ilm**

Specifies whether the supply port is part of an ILM.

The data type of **within\_ilm** is Boolean.

This attribute is read-only and cannot be modified.

---

**SEE ALSO**

[get\\_attribute\(2\)](#)  
[list\\_attributes\(2\)](#)  
[report\\_attribute\(2\)](#)

---

## **suppress\_errors**

Specifies a list of error codes for which messages are to be suppressed during the current shell session.

---

### **TYPE**

list

---

### **DEFAULT**

""

---

### **DESCRIPTION**

This variable specifies a list of error codes for which messages are to be suppressed during the current shell session. The default is set to no error messages being suppressed.

---

### **EXAMPLES**

The following example demonstrates the use of the variable.

```
set suppress_errors [list OPT-1406 OPT-1407 CMD-024 UIO-9 UIO-78]
```

---

## **symbol\_library**

Specifies the symbol libraries to use during schematic generation.

---

### **TYPE**

string

---

### **DEFAULT**

your\_library.sdb in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### **DESCRIPTION**

This variable specifies the symbol libraries to use during schematic generation. This variable is a list of symbol library names.

---

## **synlib\_abort\_wo\_dw\_license**

Stops the **compile** command if the DesignWare license is required to compile the current design, but the DesignWare license is not available.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

This variable ends the **compile** command when DesignWare license is required to compile the current design, but the DesignWare license is not available.

The datapath generator flow requires the DesignWare license. If the DesignWare license is unavailable, the free DesignWare implementation is used in the design. This could result in a suboptimal circuit.

If **synlib\_abort\_wo\_dw\_license** is **true**, the **compile** command quits with an error message. You can also set **synlib\_wait\_for\_design\_license** to wait for the licenses if all of the licenses are checked out.

---

### **SEE ALSO**

[synlib\\_wait\\_for\\_design\\_license\(3\)](#)

---

## **synlib\_dont\_get\_license**

Specifies a list of synthetic library part licenses that the compiler does not automatically check out.

---

### **TYPE**

list

---

### **DEFAULT**

""

---

### **DESCRIPTION**

This variable specifies a list of synthetic library part licenses that the compiler does not automatically check out. By default, the compiler checks out all synthetic library part licenses if there is a possibility that they will be used.

When there is only the possibility of a license being used, add the license to this list so that it will not be automatically checked out.

Exceptions exist in that licenses on this list are checked out, but only when a design is being read that requires these licenses or when you manually request them with the **get\_license** command.

To determine what licenses are required to read a design, use the **report\_design** command.

To determine the legality of the licenses on the list, use the **set\_synlib\_dont\_get\_license** command. This command checks each license on the list and issues a warning message if the license cannot be found in the key file. It then sets the **synlib\_dont\_get\_license** variable.

---

### **SEE ALSO**

**get\_license(2)**  
**report\_design(2)**  
**set\_synlib\_dont\_get\_license(2)**

---

## **synlib\_enable\_analyze\_dw\_power**

Record power info of ungrouped DesignWare design.

---

### **TYPE**

Integer

---

### **DEFAULT**

0

---

### **DESCRIPTION**

This variable enables recording power related info of ungrouped DesignWare design. The recorded info will be used for **analyze\_dw\_power** command.

When set to the default value of 0, no recording will happen. The report does not show the estimated power for ungrouped DesignWare designs. When set to 1, recording will be enabled. the **analyze\_dw\_power** command will show slack and power info for both ungrouped and non-ungrouped DesignWare design.

---

### **SEE ALSO**

[analyze\\_dw\\_power\(2\)](#)

---

## **synlib\_hiis\_force\_on\_cells**

Specifies a list of design cells on which the compiler is to force hierarchical incremental implementation selection.

---

### **TYPE**

list

---

### **DEFAULT**

""

---

### **DESCRIPTION**

This variable specifies a list of design cells on which the compiler is to force hierarchical incremental implementation selection. Even when implementation is set on the subcomponent of a hierarchical synthetic component, the compiler ignores the implementation attribute on the subcomponent and performs hierarchical incremental implementation selection on the synthetic component.

The list defined by this variable contains valid cell names in the current design. A simple wildcard pattern can be supported by using the **get\_cells** command.

Hierarchical cell names are not supported. For example, to force hierarchical incremental implementation selection on cell U0/U1/MULT, do not place U0/U1/MULT in the **synlib\_hiis\_force\_on\_cells** list; put MULT in the list.

The compiler performs forced hierarchical incremental implementation selection only on instantiated DesignWare components that have a single implementation. If you add to the **synlib\_hiis\_force\_on\_cells** list the cell name of an operator cell that is inferred in the design, the compiler does not perform forced hierarchical incremental implementation selection on the inferred cell. If there are multiple implementations available for a hierarchical DesignWare component, the compiler does not perform hierarchical incremental implementation selection on the DesignWare cell. To establish single implementation on such a cell, use the **set\_implementation** command on the cell or use the **set\_dont\_use** command on all but one implementation.

---

### **EXAMPLES**

The following example places all cell names that begin with the letter *a* in the **synlib\_hiis\_force\_on\_cells** list:

```
prompt> set_app_var synlib_hiis_force_on_cells get_cells "a*"
```

The following example places all cell names in the **synlib\_hiis\_force\_on\_cells** list:

```
prompt> set_app_var synlib_hiis_force_on_cells get_cells ""*
```

## SEE ALSO

`get_cells(2)`  
`set_dont_use(2)`  
`set_implementation(2)`

---

## **synlib\_iis\_use\_netlist**

Allows netlists of the DesignWare parts to be used instead of timing models for cost comparison during the incremental implementation selection step.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

This variable allows netlists of the DesignWare parts to be used instead of timing models for cost comparison during the incremental implementation selection step. Timing models are created without considering the design context; netlists are mapped in the context of the design.

When set to **true**, netlists of the DesignWare architectures are used to calculate the timing and area information. When **false**, timing models of the DesignWare architectures are used.

---

### **SEE ALSO**

compile(2)

---

## **synlib\_preferred\_ff\_chains**

Specifies the preferred flip-flop chains for mapping FF chains in DesignWare Library Clock Domain Crossing (CDC) components.

---

### **TYPE**

list

---

### **DEFAULT**

""

---

### **DESCRIPTION**

Specifies a list of metastability-hardened multiple flip-flop cells (chains) that Design Compiler uses when mapping the flip-flop chains in DesignWare Library CDC components, such as DW\_sync.

For Design Compiler to consider the flip-flop chain cells during mapping, the technology library cells should meet the following requirements:

1. The technology library should contain the single-bit version of the flip-flop that is used in the flip-flop chain. A special string flag, "ff\_chains", should exist on the single flip-flop for Design Compiler to find the chained library cells in the technology library.
2. The technology library cells that contain flip-flop chains should contain the same type of flip-flop. That is, all the flip-flops in the flip-flop chain should be the same.
3. The flip-flop chains in the technology library should have special integer flags, "ff\_chain\_stage", to indicate how many flip-flops are contained in the flip-flop chain cell.

The technology library vendor that creates the flip-flop chain library cell can define these required attributes in the library source code as "user\_defined" attributes.

The flip-flop chain library cell can contain any number of single flip-flops. Design Compiler maps the flip-flop chains in DesignWare Library CDC components to the appropriate and preferred flip-flop chain library cells.

For example, if an instance of a DesignWare Library CDC component is configured to use four levels of synchronization and the preferred flip-flop chain library cells have 2, 3, and 4 flip-flops, the priority order is (from high to low):

- One 4-flip-flop chain
- Two 2-flip-flop chains
- Four single flip-flops

Note that there are fewer requirements for single flip-flop metastability-hardened cells to be mapped as specified by the **synlib\_preferred\_ffs** variable.

## SEE ALSO

[synlib\\_preferred\\_ffs\(3\)](#)

---

## **synlib\_preferred\_ffs**

Specifies a list of preferred flip-flop (FF) library cells that DC will map multi-stage synchronizer FFs to within DesignWare Library Clock Domain Crossing (CDC) components.

---

### **TYPE**

list

---

### **DEFAULT**

""

---

### **DESCRIPTION**

Specifies a list of single flip-flop (FF), metastability-hardened library cells that DC will use when technology mapping synchronizer FF chains in DesignWare Library CDC components (for example DW\_sync).

If there are technology FF library cells that are designed specifically for synchronizers (sometimes referred to as "metastability-hardened" cells), you can set them as the preferred synchronizer FF by adding them to the synlib\_preferred\_ffs list. When DC maps the synchronizer FF chains within DesignWare Library CDC components, it tries to map them to the preferred FF(s).

Note: After mapping, DC can still size the FF cell. So it is still possible for the FF synchronizer chain used within DesignWare Library CDC components to be mapped to a non-preferred FF library cell.

---

### **SEE ALSO**

[synlib\\_preferred\\_ff\\_chains\(3\)](#)

---

## **synlib\_wait\_for\_design\_license**

Specifies a list of authorized synthetic library licenses for which the tool is to wait.

---

### **TYPE**

list

---

### **DEFAULT**

""

---

### **DESCRIPTION**

Specifies a list of authorized synthetic library licenses for which the tool is to wait.

By default, the tool checks for all design licenses and checks out one that is available. If none of the licenses are available, the tool terminates the command that requires the license. You can override this default behavior by setting a list of licenses as the value of **synlib\_wait\_for\_design\_license**. Then, if no licenses are available, the tool does not terminate the command that requires the license, but waits for the listed licenses to become available.

---

### **SEE ALSO**

[get\\_license\(2\)](#)

---

## **synopsys\_program\_name**

Indicates the name of the program currently running.

---

### **TYPE**

string

---

### **DESCRIPTION**

This variable is read only, and is set by the application to indicate the name of the program you are running. This is useful when writing scripts that are mostly common between some applications, but contain some differences based on the application.

To determine the current value of this variable, use **get\_app\_var synopsys\_program\_name**.

---

### **SEE ALSO**

[get\\_app\\_var\(2\)](#)

---

## **synopsys\_root**

Indicates the root directory from which the application was run.

---

### **TYPE**

string

---

### **DESCRIPTION**

This variable is read only, and is set by the application to indicate the root directory from which the application was run.

To determine the current value of this variable, use **get\_app\_var synopsys\_root**.

---

### **SEE ALSO**

[get\\_app\\_var\(2\)](#)

---

## **synthetic\_library**

Specifies a list of synthetic libraries to use when compiling.

---

### **TYPE**

list

---

### **DEFAULT**

""

---

### **DESCRIPTION**

This variable specifies a list of synthetic libraries to use when compiling.

The **synthetic\_library** variable works much like the **target\_library** variable does for technology libraries. This variable can be set to be a list of zero or more sldb files that you want to use in the **compile** or **replace\_synthetic** commands. When synthetic operators or modules are processed in compile, the operators, bindings, modules, and implementations of the specified library or libraries are used. Synthetic libraries are processed in order. So, if two modules in different libraries have the same name, the module in the first listed library is used.

As with target technology libraries, it is sometimes necessary to include your synthetic library as part of the link\_library set. This is especially important when you instantiate synthetic modules.

Because HDL files automatically insert synthetic operators in a netlist, it is important to have a synthetic library defined that supports these operators. For this reason, the standard Synopsys library **standard.sldb** is automatically inserted as the first entry in the **synthetic\_library** variable list. Then if a synthetic library is specified to be an empty list, the insertion of **standard.sldb** provides default definitions.

There is no way to disable the standard synthetic library, but you can disable individual modules or implementations by using the **dont\_use** command. To replace a particular implementation, disable it with **dont\_use**, and use a replacement from your own synthetic library.

---

### **SEE ALSO**

**compile(2)**  
**replace\_synthetic(2)**  
**target\_library(3)**

---

## target\_library

Specifies the list of technology libraries of components to be used when compiling a design.

---

### TYPE

list

---

### DEFAULT

your\_library.db

---

### DESCRIPTION

This variable specifies the list of technology libraries containing the components to be used when compiling a design. The default value is *your\_library.db*. Change this value to reflect your library name.

---

### SEE ALSO

compile(2)

---

## template\_naming\_style

Generates automatically a unique name when a module is built.

---

### TYPE

string

---

### DEFAULT

%s\_%p

---

### DESCRIPTION

This variable automatically generates a unique name when a module is built. This variable is one of three string variables that determine the naming conventions for parameterized modules (templates) built into a design through the **elaborate** command or automatically instantiated from an HDL file. The unique name automatically generated uses the module name, parameter names, and parameter values.

The **template\_naming\_style** variable determines what character or characters appear between the design name and the parameter name. The string value must contain %s, which represents the name of the original design, and %p, which represents the name and value of the parameter or parameters. You can optionally include any ASCII character or characters, or none, between %s and %p. For example, for a design named *DesignName* that has a parameter *parm1*, the default %s\_%p causes the name **DesignName\_parm1** to be generated.

Further, %s\$%p, %s\_\*\_%p, and %s%p would generate respectively the names **DesignName\$parm1**, **DesignName\_\*\_parm1**, and **DesignNameparm1**.

If a design has a noninteger parameter (or if **template\_naming\_style = ""**), the following definitions are locked down for these variables:

```
template_naming_style = %s_%p
template_parameter_style = %d
template_separator_style = _
```

---

### SEE ALSO

[elaborate\(2\)](#)  
[template\\_parameter\\_style\(3\)](#)  
[template\\_separator\\_style\(3\)](#)

---

## template\_parameter\_style

Generates automatically a unique name when a module is built.

---

### TYPE

string

---

### DEFAULT

%s%d

---

### DESCRIPTION

This variable automatically generates a unique name when a module is built. This variable is one of three string variables that determine the naming conventions for parameterized modules (templates) built into a design through the **elaborate** command or automatically instantiated from an HDL file. The unique name automatically generated uses the module name, parameter names, and parameter values.

The **template\_parameter\_style** variable determines what character or characters appear between the parameter name and its value.

The string must contain %s, which represents the name of the parameter, and %d, which represents the value of the parameter. You can optionally include any ASCII character or characters, or none, between %s and %d. For example, for a parameter named *parm* that has a value of 1, the default %s%d causes the name **parm1** to be generated.

The following are additional examples:

```
template_naming_style = "%s$%p"
template_parameter_style = %s_%d  results in DesignName$parm_1
```

```
template_naming_style = "%s_%p"
template_parameter_style = %s@%d  results in DesignName_parm@1
```

If a design has a noninteger parameter (or if **template\_naming\_style** = ""), the following definitions are locked down for these variables:

```
template_naming_style = %s_%p
template_parameter_style = %d
template_separator_style = _
```

---

### SEE ALSO

[elaborate\(2\)](#)

template\_naming\_style(3)  
template\_separator\_style(3)

---

## template\_separator\_style

Generates automatically a unique name when a module is built.

---

### TYPE

string

---

### DEFAULT

—

---

### DESCRIPTION

This variable automatically generates a unique name when a module is built. This variable is one of three string variables that determine the naming conventions for parameterized modules (templates) built into a design through the **elaborate** command or automatically instantiated from an HDL file. The unique name automatically generated uses the module name, parameter names, and parameter values.

The **template\_separator\_style** variable determines what character or characters appear between parameter names for templates that have more than one parameter. You can designate any ASCII character or characters, or none. The default value is an underscore (\_).

For example, for a design called *DesignName* that has parameters named *parm1*, *parm2*, and *parm3*, if **template\_naming\_style = "%s\_%p"** (the default value), and **template\_separator\_style = "\_"**, the name **DesignName\_parm1\_parm2\_parm3** is generated.

The following are additional examples:

```
template_naming_style = "%s$%p"
template_separator_style = "_"    results in DesignName$parm1_parm2_parm3
template_naming_style = "%s#%p"
template_separator_style = "/"    results in DesignName#parm1/parm2/parm3
```

If a design has a noninteger parameter (or if **template\_naming\_style = ""**), the following definitions are locked down for these variables:

```
template_naming_style = %s_%p
template_parameter_style = %d
template_separator_style = _
```

---

### SEE ALSO

[elaborate\(2\)](#)  
[template\\_naming\\_style\(3\)](#)

template\_parameter\_style(3)

---

# terminal\_attributes

---

## DESCRIPTION

This man page described the attributes related to terminals (physical pins).

You can use the **get\_attribute** command to determine value of an attribute, and use the **report\_attribute** command to get a report of all the attributes on a specified object. To see all terminal attributes, use the **list\_attribute -class terminal -application** command.

Note that attributes on a diode terminal are read-only.

### Terminal Attributes

access\_direction

Specifies allowable access directions for a terminal object.

The data type of **access\_direction** is string.

Its valid values are:

- **right**
- **left**
- **up**
- **down**
- **unknown**

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

Note that this attribute is undefined on diode terminal. You will get warning message with message ID "ATTR-3" when you try to get its value on diode terminal.

bbox

Specifies the bounding-box of a terminal. The **bbox** is represented by a **rectangle**.

The format of a *rectangle* specification is {{llx lly} {urx ury}}, which specifies the lower-left and upper-right corners of the rectangle.

The data type of **bbox** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

bbox\_ll

Specifies the lower-left corner of the bounding-box of a terminal.

The **bbox\_ll** is represented by a **point**. The format of a *point* specification is {x y}.

You can get the **attr\_name** of a terminal, by accessing the first element of its**bbox**.

The data type of **bbox\_ll** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### bbox\_llx

Specifies x coordinate of the lower-left corner of the bounding-box of a terminal.

The data type of **bbox\_llx** is double.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### bbox\_lly

Specifies y coordinate of the lower-left corner of the bounding-box of a terminal.

The data type of **bbox\_lly** is double.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### bbox\_ur

Specifies the upper-right corner of the bounding-box of a terminal.

The **fbbox\_ur** is represented by a **point**. The format of a *point* specification is {x y}.

You can get the **bbox\_ur** of a terminal, by accessing the second element of its**bbox**.

The data type of **bbox\_ur** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### bbox\_urx

Specifies x coordinate of the upper-right corner of the bounding-box of a terminal.

The data type of **bbox\_urx** is double.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### bbox\_ury

Specifies y coordinate of the upper-right corner of the bounding-box of a terminal.

The data type of **bbox\_ury** is double.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### cell\_id

Specifies Milkyway design ID in which a terminal object is located.

The data type of **cell\_id** is integer.

This attribute is read-only.

#### constrained\_status

Specifies constrained status of a terminal object.

The data type of **constrained\_status** is string.

Its valid values are:

- **manual\_created**
- **side**
- **location**
- **order**
- **unknown**

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

Note that this attribute is undefined on diode terminal. You will get warning message with message ID "ATTR-3" when you try to get its value on diode terminal.

#### direction

Specifies direction of a terminal object.

The data type of **direction** is string.

Its valid values are:

- **in**
- **out**
- **inout**
- **tristate**
- **unknown**
- **input**
- **output**

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

Note that the direction of a diode terminal will be marked as **diode**. You can not change its value by **set\_attribute**.

#### double\_pattern\_mask\_constraint

Specifies the coloring information of the terminal. This information is needed in the double patterning flow.

The data type of **double\_pattern\_mask\_constraint** is string.

Its valid values are:

- **any\_mask**
- **mask1\_soft**
- **mask1\_hard**
- **mask2\_soft**
- **mask2\_hard**
- **same\_mask**

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### eeq\_class

Specifies electrically equivalent class of a terminal object.

The data type of **eeq\_class** is integer.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

Note that this attribute is undefined on diode terminal. You will get warning message with message ID "ATTR-3" when you try to get its value on diode terminal.

**is\_diode**

Indicates whether a terminal object is diode.

The data type of **is\_diode** is boolean.

This attribute is read-only.

**is\_fixed**

Specifies whether a terminal object is marked as fixed.

The data type of **is\_fixed** is boolean.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**layer**

Specifies layer name of a terminal object.

The data type of **layer** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**must\_join\_class**

Specifies must-join class of a terminal.

The data type of **must\_join\_class** is integer.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

Note that this attribute is undefined on diode terminal. You will get warning message with message ID "ATTR-3" when you try to get its value on diode terminal.

**multiple\_pattern\_mask\_constraint**

Specifies the coloring information of the terminal. This information is needed in the multiple patterning flow.

The data type of **multiple\_pattern\_mask\_constraint** is string.

Its valid values are:

- **any\_mask**
- **mask1\_soft**
- **mask1\_hard**
- **mask2\_soft**
- **mask2\_hard**
- **mask3\_soft**
- **mask3\_hard**
- **same\_mask**

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**name**

Specifies name of a terminal object.

The data type of **name** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**number\_of\_points**

Specifies the number of points to illustrate the boundary of a terminal object.

The data type of **number\_of\_points** is integer.

You can refer to the attribute **points**. The list length of **points** is the value of **number\_of\_points**.

This attribute is read-only.

**object\_class**

Specifies object class name of a terminal, which is **terminal**.

The data type of **object\_class** is string.

This attribute is read-only.

**object\_id**

Specifies object ID in Milkyway design file.

The data type of **object\_id** is integer.

This attribute is read-only.

**owner**

Specifies Milkyway design file name in which a terminal is located.

The data type of **owner** is string.

This attribute is read-only.

**owner\_port**

Specifies port name which a terminal object is associated with.

The data type of **owner\_port** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**points**

Specifies points of the boundary of a terminal. A terminal can be a rectangle, a rectilinear polygon, or multiple rectangles.

When a terminal is either a rectangle or a rectilinear polygon, its **points** is represented by a list of points. The last element of the list is the same as the first element.

When a terminal consists of multiple rectangles, its **points** is represented by a list of points of rectangles. Every five points represent one rectangle.

The data type of **points** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**side\_status**

Specifies constrained side name.

The data type of **side\_status** is string.

Its valid values are:

- **left**

- **right**
- **bottom**
- **top**
- **unknown**

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

Note that this attribute is undefined on diode terminal. You will get warning message with message ID "ATTR-3" when you try to get its value on diode terminal.

**status**

Specifies the placement status of a terminal object.

The data type of **status** is string. The valid values are:

- **fixed**
- **placed**
- **cover**
- **unplaced**

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

Note that this attribute is undefined on diode terminal. You will get an ATTR-3 warning message when you try to get its value on diode terminal.

---

## SEE ALSO

[get\\_attribute\(2\)](#)  
[list\\_attributes\(2\)](#)  
[report\\_attribute\(2\)](#)  
[set\\_attribute\(2\)](#)

---

## test\_allow\_internal\_pins\_in\_hierarchical\_flow

Allows DFT cores with internal pins to be integrated in a hierarchical DFT flow.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

By default, cores with internal pins cannot be integrated, for the safety reasons described in the TESTXG-68 man page.

If your flow requires such cores to be integrated and you can guarantee proper operation of the cores during hierarchical testing, then you can set this variable to **true** to allow these cores to be integrated.

The variable must be set to **true** as follows:

- During core-level creation, to include additional internal-pins information in the core's CTL model
- During top-level insertion, to disable the TESTXG-68 safety check and allow the cores to be integrated

Cores with internal clock pins (other than OCC **oscillator** pins) are not supported by this variable because they cannot be effectively represented in the CTL model.

---

### SEE ALSO

dft\_drc(2)

---

## test\_ate\_sync\_cycles

Specifies the number of ATE clock synchronization cycles used by a user-defined on-chip clocking (OCC) controller.

---

### TYPE

positive integer

---

### DEFAULT

1

---

### DESCRIPTION

When you are using a user-defined on-chip clocking (OCC) controller, this variable specifies the number of ATE clock synchronization cycles used by the OCC controller when a scan-enable transition initiates a transition between the ATE and OCC clocks.

This variable affects the content of the protocol file written at the end of the **insert\_dft** command.

By default, this variable is set to 1, which models an OCC controller that waits for a single clock cycle after a scan-enable transition. When scan-enable is reasserted after capture, scan data is delayed by one cycle, and the **load\_unload** procedure is created as follows:

```
load_unload {
    V { SE=1; ATE_CLK=P; _si-=X; _so=X}
    Shift { ...}
}
```

You should change the value of this variable if your OCC controller does not need a synchronization cycle or if it requires more than one synchronization cycle after a scan-enable transition.

For more information on the synchronization logic structures and timing relationships, see SolvNet article 035708, "What Does the **test\_ate\_sync\_cycles** Variable Do?".

Normally, this variable only affects the test protocol. If the variable is not set to the proper value, the test protocol can be edited or regenerated. However, in serialized compressed scan flows, it also affects the architecture of the serializer clock controller. In these flows, if the variable is not set to the proper value, the serializer logic must be reinserted with the variable set to the correct value.

---

### SEE ALSO

`set_dft_configuration(2)`  
`set_scan_compression_configuration(2)`  
`set_dft_clock_controller(2)`

---

## **test\_avoid\_control\_register\_of\_icg\_in\_scan\_chain\_head**

Forces all control registers of clock-gating functional enable pins to be at the end of a scan chain.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

By default, the tool has no restrictions on the scan chain location of scan registers that drive the functional enable pins of clock-gating cells. If these control registers are at the head (beginning) of a scan chain, then the design can lose test coverage.

If you set this variable to **true**, the tool places the registers at the ends of scan chains, and it forces the SCANDEF information to have the STOP pin be at the control register to prevent it from moving earlier in the chain.

This variable only affects control registers that are in the same hierarchy as the clock-gating cell.

---

### **SEE ALSO**

[set\\_scan\\_path\(2\)](#)  
[identify\\_clock\\_gating\(2\)](#)

---

## **test\_bsd\_dead\_cycle\_after\_update\_dr**

Adds dead cycles before EXTEST measurement cycle so that slow output pads can be measured.

---

### **TYPE**

integer

---

### **DEFAULT**

0 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### **DESCRIPTION**

For designs with slow I/O pads or fast TCK clock frequencies or both, when the EXTEST instruction is active, the output pads might not settle before the value is measured in the clock cycle after the Update-DR state. In this case, you can add one or more dead cycles after the Update-DR state when the EXTEST instruction is active, which provide additional settling time for slow output pads.

You can use this variable to set the desired number of dead cycles. For example,

```
prompt> set_app_var test_bsd_dead_cycle_after_update_dr cycle_count
```

When the **create\_bsd\_patterns** command is run, it creates patterns with the specified number of dead cycles before output measurement. TCK will not pulse during these dead cycles. The default is zero, which does not insert any dead cycles.

---

### **SEE ALSO**

[create\\_bsd\\_patterns\(2\)](#)

---

## **test\_bsd\_default\_bidir\_delay**

Defines the default switching time of bidirectional ports in a tester cycle for BSD applications.

---

### **TYPE**

positive nonzero integer

---

### **DEFAULT**

0 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### **DESCRIPTION**

This variable defines the default switching time of bidirectional ports in a tester cycle. The value is a positive real number in nanoseconds. This value is used when a test protocol is generated for ATPG.

For ATPG, **test\_bsd\_default\_bidir\_delay** defines the following for the design under test:

- The default time at which values are applied (driven) to the bidirectional ports in input mode during the parallel measure cycle.
- The time at which bidirectional ports are released (undriven) during the capture cycle.
- This variable affects only BSD applications.

The value of **test\_bsd\_default\_bidir\_delay** must be less than the output strobe time and greater than the capture clock active edge value.

The value of this variable affects the outcome of the **check\_bsd** command and the test program produced by the **create\_bsd\_patterns** or **write\_test** commands. The **check\_bsd** command uses the value of this variable to check a design against the design rules of a bsd methodology.

Changing the value of **test\_bsd\_default\_bidir\_delay** modifies the content of the inferred or created test protocol generated by **check\_bsd**. To generate the test program, **create\_bsd\_patterns** or **write\_test** uses the value of **test\_bsd\_default\_bidir\_delay** in the test protocol attached to the vector database (.vdb) file.

---

### **SEE ALSO**

**check\_bsd(2)**  
**write\_test(2)**

```
port_attributes(3)
test_bsd_default_delay(3)
test_bsd_default_strobe(3)
test_bsd_default_strobe_width(3)
```

---

## test\_bsd\_default\_delay

Defines the default time in a tester cycle to apply values to input ports for BSD applications.

---

### TYPE

positive nonzero integer

---

### DEFAULT

0 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable defines the default time in a tester cycle to apply values to input ports. The value is a positive real number in nanoseconds. This variable is used to generate a protocol file for ATPG.

For ATPG, **test\_bsd\_default\_delay** defines for the design under test the default time at which values are applied (driven) to the primary inputs for BSD applications. The value of **test\_bsd\_default\_delay** must be less than the output strobe time, and less than the capture clock edge value.

The value of this variable affects the outcome of the **check\_bsd** command and the test program produced by the **create\_bsd\_patterns** or **write\_test** commands. The **check\_bsd** command uses the value of this variable to check a design against the design rules of a bsd methodology. Changing the value of **test\_bsd\_default\_delay** modifies the content of the inferred or created BSD protocol generated by **check\_bsd**.

To generate the test program, **create\_bsd\_patterns** or **write\_test** uses the value of **test\_bsd\_default\_delay** in the test protocol attached to the vector database (.vdb) file.

---

### SEE ALSO

[check\\_bsd\(2\)](#)  
[write\\_test\(2\)](#)  
[port\\_attributes\(3\)](#)  
[test\\_bsd\\_default\\_bidir\\_delay\(3\)](#)  
[test\\_bsd\\_default\\_strobe\(3\)](#)  
[test\\_bsd\\_default\\_strobe\\_width\(3\)](#)

---

## test\_bsd\_default\_strobe

Defines the default strobe time in a test cycle for output ports and bidirectional ports in output mode for BSD applications.

---

### TYPE

positive nonzero integer

---

### DEFAULT

95 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable defines the default strobe time in a test cycle for output ports and bidirectional ports in output mode for BSD applications. The value is a positive real number in nanoseconds. This value is used when a test protocol is generated for ATPG.

For ATPG, **test\_bsd\_default\_strobe** defines for the design under test the default time at which values are strobed on the primary output ports and bidirectional ports in output mode. The value of this variable must be less than or equal to the clock period value.

The value of this variable affects the outcome of the **check\_bsd** command and the test program produced by the **create\_bsd\_patterns** or **write\_test** command. The **check\_bsd** command uses the value of this variable to check a design against the design rules of a bsd methodology.

Changing the value of **test\_bsd\_default\_strobe** modifies the content of the inferred or created test protocol generated by **check\_bsd**. To generate the test program, **create\_bsd\_patterns** or **write\_test** uses the value of **test\_bsd\_default\_strobe** in the test protocol attached to the vector database (.vdb) file.

---

### SEE ALSO

[check\\_bsd\(2\)](#)  
[write\\_test\(2\)](#)  
[test\\_bsd\\_default\\_bidir\\_delay\(3\)](#)  
[test\\_bsd\\_default\\_delay\(3\)](#)  
[test\\_bsd\\_default\\_strobe\\_width\(3\)](#)

---

## **test\_bsd\_default\_strobe\_width**

Defines the default strobe pulse width, which is the default time that specifies how long after invocation the strobe pulse needs to be held active for BSD applications.

---

### **TYPE**

positive nonzero integer

---

### **DEFAULT**

0 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### **DESCRIPTION**

This variable defines the default strobe pulse width, which is the default time that specifies how long after invocation the strobe pulse needs to be held active for BSD applications.

Changing the value of this variable modifies the content of the inferred or created test protocol generated by the **check\_bsd** command. The **create\_bsd\_patterns** or **write\_test** command uses the value of this variable (as stated in the test protocol attached to the design) to generate the test program for vector formats that support the notion of strobe width. For those formats that do not support it, the strobe width value specified is ignored.

The value of the **test\_bsd\_default\_strobe\_width** variable is a real number value whose units are assumed to be nanoseconds, and the value must be a positive number. The sum of this value and the strobe time value must be less than or equal to the clock period value.

---

### **SEE ALSO**

**check\_bsd(2)**  
**write\_test(2)**  
**test\_bsd\_default\_bidir\_delay(3)**  
**test\_bsd\_default\_delay(3)**  
**test\_bsd\_default\_strobe(3)**

---

## test\_bsd\_input\_ac\_parametrics

Specifies what input port value transitions are tested in DC parametric patterns.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

By default, the DC parametric patterns created by the **create\_test\_patterns -type {dc\_parametric}** command exercise all port values for leakage characterization, but they do not exercise all value transitions for switching characterization.

With the default of **false**, input ports and bidirectional ports in input mode go through the following value sequence:

Input ports:

X -> 0  
0 -> 1

Bidirectional ports as inputs:

Z -> 0  
0 -> 1

By setting this variable to **true**, input ports and bidirectional ports input mode go through the following value sequence:

Input ports:

X -> 0  
0 -> 1  
1 -> 0

Bidirectional ports as inputs:

Z -> 0  
0 -> 1  
1 -> 0

---

### SEE ALSO

[test\\_bsd\\_new\\_output\\_parametrics\(3\)](#)

---

## test\_bsd\_make\_private\_instructions\_public

Specifies whether private instructions should be included in BSDL and pattern files.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable controls whether private instructions are included during BSDL and pattern file generation. Private instructions are created using the **-private** option of the **set\_bsd\_instruction** command.

When this variable is set to **false** (the default), the **write\_bsd** and **create\_bsd\_patterns** commands ignore private instructions and their associated test data registers. This behavior is useful for creating BSDL and pattern files for external customers.

When this variable is set to **true**, the **write\_bsd** and **create\_bsd\_patterns** commands include private instructions. The **write\_bsd** command includes private instructions and any associated test data registers in the REGISTER\_ACCESS section of the BSDL output file, and the **create\_bsd\_patterns** command includes private instructions in test pattern generation. This behavior is useful for creating BSDL and pattern files for internal testing.

To determine the current value of this variable, type **printvar test\_bsd\_make\_private\_instructions\_public**.

To see the current value of this variable, type

```
prompt> printvar test_bsd_make_private_instructions_public
```

---

### EXAMPLES

The following example generates BSDL and pattern files for external use:

```
prompt> set test_bsd_make_private_instructions_public false
prompt> write_bsd -naming_check BSDL -output des.bsd
prompt> create_bsd_patterns -type all -output patterns.spf
```

The following example generates BSDL and pattern files for internal testing:

```
prompt> set test_bsd_make_private_instructions_public true  
prompt> write_bsdl -naming_check BSDL -output des_INTERNAL.bsdl  
prompt> create_bsd_patterns -type all -output patterns_INTERNAL.spf
```

To determine the current value of this variable, type **printvar test\_bsd\_make\_private\_instructions\_public**. For a list of **bsd** variables and their current values, type **print\_variable\_group bsd**.

---

## SEE ALSO

[set\\_bsd\\_instruction\(2\)](#)  
[write\\_bsdl\(2\)](#)  
[create\\_bsd\\_patterns\(2\)](#)

---

## test\_bsd\_manufacturer\_id

Specifies the manufacturer ID to use to create the value captured in the device identification register during execution of the **insert\_dft** command.

---

### TYPE

integer

---

### DEFAULT

72 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies the manufacturer ID to use to create the value captured in the device identification register during execution of the **insert\_dft** command. This unique ID represents the manufacturer ID assigned to the organization.

---

### SEE ALSO

[insert\\_dft\(2\)](#)  
[test\\_bsd\\_part\\_number\(3\)](#)  
[test\\_bsd\\_version\\_number\(3\)](#)

---

## test\_bsd\_new\_output\_parametrics

Specifies what output port value transitions are tested in DC parametric patterns.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

By default, the DC parametric patterns created by the **create\_test\_patterns -type {dc\_parametric}** command exercise all port values for leakage characterization, but they do not exercise all value transitions for switching characterization.

With the default of **false**, two-state output ports, three-state output ports, and bidirectional ports in output mode go through the following value sequence:

Two-state output ports:

X -> 0  
0 -> 1

Three-state output ports, bidirectional ports as outputs:

Z -> 0  
0 -> 1

By setting this variable to **true**, two-state output ports, three-state output ports, and bidirectional ports in output mode go through the following value sequence:

Output ports:

X -> 0  
0 -> 1  
1 -> 0  
X -> 1

Three-state output ports, bidirectional ports as outputs:

Z -> 0  
0 -> 1  
1 -> 0  
Z -> 1

---

**SEE ALSO**

`test_bsd_input_ac_parametrics(3)`

---

## test\_bsd\_optimize\_control\_cell

Allows the **optimize\_bsd** command to optimize allocation of BSR control cells during area-driven optimization.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable allows the **optimize\_bsd** command to optimize allocation of boundary-scan register (BSR) control cells during area-driven optimization.

using the value of the **test\_bsd\_control\_cell\_drive\_limit** variable. If the area constraints are not violated, this optimization is not performed. To specify area constraints for the current design, use the **set\_max\_area** command.

When set to **false** (the default), no optimization of BSR control cells takes place during area-driven optimization.

When set to **true**, optimization is performed if the **set\_max\_area** constraint for the current design is violated. In this case, optimization is performed using the value of the **test\_bsd\_control\_cell\_drive\_limit** variable. If the area constraints are not violated, this optimization is not performed.

To determine the current value of this variable, type **printvar test\_bsd\_optimize\_control\_cell**. For a list of **bsd** variables and their current values, type **print\_variable\_group bsd**.

---

### SEE ALSO

**set\_max\_area(2)**  
**test\_bsd\_allow\_tolerable\_violations(3)**  
**test\_bsd\_control\_cell\_drive\_limit(3)**

---

## test\_bsd\_part\_number

Specifies the part number to use to create the value captured in the device identification register during execution of the **insert\_dft** command.

---

### TYPE

integer

---

### DEFAULT

72 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies the part number to use to create the value captured in the device identification register during execution of the **insert\_dft** command. This number, which represents the part number assigned to the IC, should be unique inside the organization.

---

### SEE ALSO

[insert\\_dft\(2\)](#)  
[test\\_bsd\\_version\\_number\(3\)](#)  
[test\\_bsd\\_manufacturer\\_id\(3\)](#)

---

## test\_bsd\_synthesis\_gated\_tck

Specifies whether BSD insertion gates the clock connection of a user-defined test data register with its instruction enable signal.

---

### TYPE

Boolean

---

### DEFAULT

false in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies whether BSD insertion gates the TCK clock connection of a user-defined test data register (UTDR) with its instruction enable signal.

When this variable is set to **false**, which is the default, BSD insertion hooks the UTDR clock pin directly up to TCK. Any existing connections are discarded. No gating logic is inserted to suppress TCK when the instruction is inactive.

When this variable is set to **true**, BSD insertion gates the TCK signal with a MUX, with the select pin driven by the instruction enable signal. The MUX selects TCK when the instruction is active, and it selects the existing connection when the instruction is inactive.

---

### EXAMPLES

Consider the following UTDR definition:

```
set_dft_signal -view spec -type tdi \
  -hookup_pin BIST/WRAPPER_0/debug_in
set_dft_signal -view spec -type tdo \
  -hookup_pin BIST/WRAPPER_0/debug_out
set_dft_signal -view spec -type bsd_shift_en \
  -hookup_pin BIST/WRAPPER_0/debug_en
set_dft_signal -view spec -type capture_clk \
  -hookup_pin BIST/WRAPPER_0/clk

set_scan_path DEBUG_REG -class bsd \
  -view spec \
  -hookup {BIST/WRAPPER_0/debug_in \
    BIST/WRAPPER_0/debug_out \}
```

```
BIST/WRAPPER_0/debug_en \
BIST/WRAPPER_0/clk} \
-exact_length 10
```

When this variable is set to **false**, which is the default, BSD insertion hooks the UTDR clock pin BIST/WRAPPER\_0/clk directly to TCK, and the existing connection is lost.

When this variable is set to **true**, BSD insertion MUXes the existing signal at the UTDR clock pin BIST/WRAPPER\_0/clk with TCK, using the instruction enable signal as the MUX select, so that TCK only drives the clock pin when the instruction is active.

To determine the current value of this variable, type **printvar test\_bsd\_synthesis\_gated\_tck**. For a list of **bsd** variables and their current values, type **print\_variable\_group bsd**.

---

## SEE ALSO

[set\\_bsd\\_instruction\(2\)](#)  
[set\\_scan\\_path\(2\)](#)

---

## test\_bsd\_version\_number

Specifies the version number to use to create the value captured in the device identification register during execution of the **insert\_dft** command.

---

### TYPE

integer

---

### DEFAULT

72 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies the version number to use to create the value captured in the device identification register during execution of the **insert\_dft** command. This represents the version number assigned to this IC and is unique for this IC.

---

### SEE ALSO

[insert\\_dft\(2\)](#)  
[test\\_bsd\\_manufacturer\\_id\(3\)](#)  
[test\\_bsd\\_part\\_number\(3\)](#)

---

## test\_bsdl\_default\_suffix\_name

Specifies the default suffix for the name of the BSDL file generated by the **write\_bsdl** command.

---

### TYPE

string

---

### DEFAULT

bsdl in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable specifies the default suffix for the name of the Boundary-Scan Description Language (BSDL) file that the **write\_bsdl** command generates. If the **write\_bsdl** command does not specify an output file, by default the output file is named *top\_level\_design\_name.suffix*, with *suffix* being the value of **test\_bsdl\_default\_suffix\_name**.

---

### SEE ALSO

[write\\_bsdl\(2\)](#)

---

## **test\_bsdl\_max\_line\_length**

Specifies the maximum number of characters per line for the output BSDL file the **write\_bsdl** command produces.

---

### **TYPE**

integer

---

### **DEFAULT**

95 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### **DESCRIPTION**

This variable specifies the maximum number of characters per line for the output Boundary-Scan Description Language (BSDL) file the **write\_bsdl** command produces. The maximum line length should not be less than 50 or more than 132. If you specify a line length outside this range, **write\_bsdl** uses the default instead.

---

### **SEE ALSO**

[write\\_bsdl\(2\)](#)

---

## test\_cc\_ir\_masked\_bits

Identifies instruction register (IR) bits to be masked during the search by the **check\_bsd** command for all possible implemented instructions.

---

### TYPE

integer

---

### DEFAULT

0

---

### DESCRIPTION

This variable identifies instruction register (IR) bits to be masked during the search by the **check\_bsd** command for all possible implemented instructions. By default, no bits are masked.

Masking IR bits shortens the sequential search. The sequential search becomes exponentially costly as the IR length increases beyond 8 bits. The compliance checker masks bits that contain a 1 in the binary equivalent of the decimal integer in this variable. For example, if you want to mask bits 0 and 3, set the variable with decimal 9, the equivalent of binary 00...1001. Similarly, a value of 7 (binary 00...0111) masks bits 0, 1 and 2; 8 masks bit 3; and so on.

---

### SEE ALSO

[check\\_bsd\(2\)](#)  
[test\\_cc\\_ir\\_value\\_of\\_masked\\_bits\(3\)](#)

---

## **test\_cc\_ir\_value\_of\_masked\_bits**

Specifies values to be forced into bits of the instruction register (IR) that are masked, during the search by the **check\_bsd** command for all possible implemented instructions.

---

### **TYPE**

integer

---

### **DEFAULT**

0

---

### **DESCRIPTION**

This variable specifies values to be forced into bits of the instruction register (IR) that are masked, during the search by the **check\_bsd** command for all possible implemented instructions. The value of the **test\_cc\_ir\_masked\_bits** variable identifies the bits to be masked. By default, 0s are forced into all masked bits.

The compliance checker forces a 0 or a 1 into each masked bit, based on the binary equivalent of the decimal integer value of **test\_cc\_ir\_value\_of\_masked\_bits**, adjusted for the bit-width of the IR. For example, for a 4-bit IR, if bits 0 and 3 are masked and the value of **test\_cc\_ir\_value\_of\_masked\_bits** is 5 (binary 0101), bit 0 receives a value of 1 and bit 3 a value of 0.

---

### **SEE ALSO**

[check\\_bsd\(2\)](#)  
[test\\_cc\\_ir\\_masked\\_bits\(3\)](#)

---

## test\_clock\_port\_naming\_style

Specifies the naming style used by the **insert\_dft** command for global test signal ports created in designs during the addition of test circuitry.

---

### TYPE

string

---

### DEFAULT

test\_c%s

---

### DESCRIPTION

This variable specifies the naming style used by the **insert\_dft** command for global test signal ports created in designs during the addition of test circuitry. If the **set\_dft\_signal** command identifies suitable ports, new ports are not added.

This variable must contain one %s (percent s) character sequence. When adding a port, if the new port name is the same as an existing port name, %s is replaced by a character (a through z) that creates a unique name.

For example, if this variable is set to *MY\_TC%*s when **insert\_dft** adds a new port for the *test clock* signal, the port is named:

MY\_TC

If a port named *MY\_TC* already exists in the design, the new port is named:

MY\_TCa

---

### SEE ALSO

**insert\_dft(2)**  
**set\_dft\_signal(2)**

---

## **test\_core\_wrap\_sync\_ctl\_segment\_length**

Specifies the maximum length of CTL-modeled synchronizer register that can be included in wrapper chains.

---

### **TYPE**

integer

---

### **DEFAULT**

0

---

### **DESCRIPTION**

This variable specifies the maximum segment length of synchronizer register that can be included in wrapper chains as shared wrapper cells in the maximized reuse core wrapping flow. If a synchronizer register longer than this is associated with a port, that port gets a dedicated wrapper cell.

A synchronizer register is a library cell register that has a CTL model with a single scan chain from scan data input to scan data output. Note that a multibit register is something different, and is not affected by this variable.

The default is 0, which indicates that no CTL-modeled register (including single-bit registers) can be included in wrapper chains. Note that in this default case, when tool finds any CTL-modeled cell associated with a design port, a dedicated wrapper cell is added to the port.

By default, synchronizer registers always count as 1 in the fanout threshold computation, regardless of internal synchronizer length. To make them count according to their segment length, set the **test\_core\_wrap\_use\_sync\_ctl\_segment\_length\_for\_fanout\_check** variable to **true**.

If a CTL-modeled cell other than a synchronizer register is associated with a port, that port always gets a dedicated wrapper cell.

This variable is used only in maximized reuse core wrapper flows.

This variable does not apply to synchronizer registers modeled using Liberty library constructs.

---

### **EXAMPLES**

To allow typical dual-register synchronization cells to be included in wrapper chains,

```
prompt> set_app_var test_core_wrap_sync_ctl_segment_length 2
```

## SEE ALSO

`test_core_wrap_use_sync_ctl_segment_length_for_fanout_check(3)`

---

## **test\_core\_wrap\_use\_sync\_ctl\_segment\_length\_for\_fanout\_check**

Specifies whether maximized-reuse fanout computations use the segment length for CTL-modeled cells.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

This variable specifies how the maximized reuse fanout computation should treat the segment length of CTL-modeled synchronizer registers.

A synchronizer register is a library cell register that has a CTL model with a single scan chain from scan data input to scan data output. (Note that a multibit register is something different, and is not affected by this variable.)

When set to **false** (the default), synchronizer registers always count for 1 in the threshold computation, regardless of their segment length. This reflects fanin/fanout count for a port.

When set to **true**, synchronizer registers count as their segment length in the threshold computation. This reflects total scan element count associated with a port.

This variable is used only in maximized reuse core wrapper flows.

This variable does not apply to synchronizer registers modeled using Liberty library constructs.

---

### **SEE ALSO**

[test\\_core\\_wrap\\_sync\\_ctl\\_segment\\_length\(3\)](#)

---

## test\_count\_occ\_chain\_in\_chain\_count

Controls whether external OCC chains are included in the chain count constraint.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable affects only designs that have DFTMAX Ultra compression modes.

When this variable is set to **false** (the default), external clock chains are not included in the **-chain\_count** specification of the **set\_scan\_configuration** command, which means that the actual number of chains architected (including clock chains) is larger than the chain count specification.

This behavior is different than other test modes (compressed and uncompressed), and it is different than the behavior of non-OCC external chains, which can lead to confusion. Although the behavior only occurs when DFTMAX Ultra compression is used, it is applied to other test modes as a result.

When this variable is set to **true**, the chain count is included in the **-chain\_count** specification of the **set\_scan\_configuration** command. This behavior is consistent with other test modes and with the behavior of non-OCC external chains.

---

### SEE ALSO

[set\\_scan\\_configuration\(2\)](#)

---

## test\_dedicated\_clock\_chain\_clock

Enables a dedicated clock-chain clock output for DFT-inserted OCC controllers.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

By default, when the tool inserts an on-chip clocking (OCC) controller and its clock chain, the clock chain clock connection shares the first functional clock output of the OCC controller. This places the clock chain in both the PLL and ATE clock paths.

To use a dedicated clock-chain clock connection from the OCC controller design, set this variable to **true**. This creates a dedicated OCC controller clock output for the clock chain that places it in only the ATE clock path, which prevents it from affecting the high-speed PLL clock path.

In both cases, you should consider how the clock-chain connection interacts with clock tree synthesis (CTS). Depending on the value of this variable and the CTS configuration used for the PLL/ATE clocks, the clock chain might or might not be included in a synthesized clock clock tree. If you are performing CTS at the functional OCC controller output but you are using a dedicated clock chain clock connection, consider hold time effects within the clock chain (if no CTS is performed for the ATE clock domain) and shifting to/from the clock chain (if the clock latency to the clock chain differs from that of the functional clock domain).

This variable can be set to **true** only when the **test\_occ\_insert\_clock\_gating\_cells** variable is also set to **true**.

---

### SEE ALSO

`set_dft_clock_controller(2)`  
`test_occ_insert_clock_gating_cells(3)`

---

## test\_dedicated\_subdesign\_scan\_outs

Instructs the tool to create dedicated scan-out ports on subdesigns.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable instructs the tool to always create dedicated scan-out ports on subdesigns. By default, the tool uses existing subdesign output ports where possible. When this variable is set to **true**, the tool creates new dedicated output ports for scan.

This variable only affects cases where the Q output of flop is directly connected to output of a subblock. If the variable is set to **true**, the tool creates a new, separate output port driven by the register. As a result, the register output net becomes a multiport net and buffers must be added to fix the multiport condition.

If the variable is set to **false** (the default), the functional output port driven by the register gets reused as a scan-out.

If there is no register that directly drives an output port, the tool does not reuse a functional port via a MUX; instead, it creates a new scan-out port.

---

### SEE ALSO

[insert\\_dft\(2\)](#)

---

## test\_default\_bidir\_delay

Defines the default switching time of bidirectional ports in a tester cycle.

---

### TYPE

positive integer

---

### DEFAULT

0

---

### DESCRIPTION

This variable defines the default switching time of bidirectional ports in a tester cycle. The value is a positive real number in nanoseconds. This value is used when a test protocol is generated for ATPG.

For ATPG, **test\_default\_bidir\_delay** defines for the design under test the following:

- The default time at which values are applied (driven) to the bidirectional ports in input mode during the parallel measure cycle.
- The time at which bidirectional ports are released (undriven) during the capture cycle.

The value of **test\_default\_bidir\_delay** must be less than the output strobe time and less than the capture clock active edge value.

The value of this variable affects the outcome of the **dft\_drc** command and the test protocol produced by the **write\_test\_protocol** command. The **dft\_drc** command uses the value of this variable to check a design against the design rules of a scan test methodology.

Changing the value of **test\_default\_bidir\_delay** modifies the content of the inferred or created test protocol generated by **dft\_drc**. You can override the value of this variable by reading in a user-defined test protocol using the **read\_test\_protocol** command.

---

### SEE ALSO

**dft\_drc(2)**  
**read\_test\_protocol(2)**  
**write\_test(2)**  
**write\_test\_protocol(2)**  
**port\_attributes(3)**  
**test\_default\_delay(3)**

```
test_default_period(3)
test_default_strobe(3)
test_default_strobe_width(3)
```

---

## test\_default\_delay

Defines the default time in a tester cycle to apply values to input ports.

---

### TYPE

positive integer

---

### DEFAULT

0

---

### DESCRIPTION

This variable defines the default time in a tester cycle to apply values to input ports. The value is a positive real number in nanoseconds. The default value is 0.0. This variable is used to generate a protocol file for ATPG.

For ATPG, **test\_default\_delay** defines for the design under test the default time at which values are applied (driven) to the primary inputs. The value of **test\_default\_delay** must be less than the output strobe time, and less than the capture clock edge value.

The value of this variable affects the outcome of the **dft\_drc** command and the test program produced by the **write\_test** command. The **dft\_drc** command uses the value of this variable to check a design against the design rules of a scan test methodology.

Changing the value of **test\_default\_delay** modifies the content of the inferred or created test protocol generated by **dft\_drc** or **create\_test\_protocol**. You can override the value of this variable by reading in a user-defined test protocol using the **read\_test\_protocol** command. To generate the test program, **write\_test** uses the value of **test\_default\_delay** in the test protocol attached to the vector data base (.vdb) file.

---

### SEE ALSO

**dft\_drc(2)**  
**read\_test\_protocol(2)**  
**write\_test(2)**  
**write\_test\_protocol(2)**  
**port\_attributes(3)**  
**test\_default\_bidir\_delay(3)**  
**test\_default\_period(3)**  
**test\_default\_strobe(3)**  
**test\_default\_strobe\_width(3)**

---

## test\_default\_period

Defines the length of a test vector cycle.

---

### TYPE

positive nonzero integer

---

### DEFAULT

100

---

### DESCRIPTION

This variable defines the time duration of a test vector cycle. This value translates directly to the speed of application of the test vectors on automated test equipment (ATE). For example, a period of 100 nanoseconds describes ATE running at 10 MHz.

This variable controls the test clock period of the test protocol created by the **create\_test\_protocol** command. Test clocks defined with the **set\_dft\_signal** command must be defined using this period, except for free-running reference clocks defined with **set\_dft\_signal -type refclock**, which can be defined with any period value.

If you read in an external test protocol with the **read\_test\_protocol** command, the test period used in that protocol file is used, and the value of this variable is ignored.

The **create\_bsd\_patterns** command uses the value of this variable when creating the boundary-scan test program.

The value of the **test\_default\_period** variable is a real number whose units are assumed to be nanoseconds. The value must be a positive number.

---

### SEE ALSO

`dft_drc(2)`  
`read_test_protocol(2)`  
`set_dft_signal(2)`  
`write_test(2)`  
`write_test_protocol(2)`  
`test_default_bidir_delay(3)`  
`test_default_delay(3)`  
`test_default_strobe(3)`  
`test_default_strobe_width(3)`  
`test_wrapper_new_wrp_clock_timing(3)`

---

## test\_default\_strobe

Defines the default strobe time in a test cycle for output ports and bidirectional ports in output mode.

---

### TYPE

positive nonzero integer

---

### DEFAULT

40

---

### DESCRIPTION

This variable defines the default strobe time in a test cycle for output ports and bidirectional ports in output mode. The value is a positive real number in nanoseconds. This value is used when a test protocol is generated for ATPG.

For ATPG, **test\_default\_strobe** defines, for the design under test, the default time at which values are strobed on the primary output ports and bidirectional ports in output mode. The value of this variable must be less than or equal to the clock period value.

The value of this variable affects the outcome of the **dft\_drc** command and the test program produced by the **write\_test** command. The **dft\_drc** command uses the value of this variable to check a design against the design rules of a scan test methodology.

Changing the value of **test\_default\_strobe** modifies the content of the inferred or created test protocol generated by **dft\_drc**. You can override the value of this variable for by reading in a user-defined test protocol using the **read\_test\_protocol** command. To generate the test program, **write\_test** uses the value of **test\_default\_strobe** in the test protocol attached to the vector database (.vdb) file.

---

### SEE ALSO

**dft\_drc(2)**  
**read\_test\_protocol(2)**  
**write\_test(2)**  
**write\_test\_protocol(2)**  
**test\_default\_bidir\_delay(3)**  
**test\_default\_delay(3)**  
**test\_default\_period(3)**  
**test\_default\_strobe\_width(3)**

---

## test\_default\_strobe\_width

Defines the default strobe pulse width, which is the default time that specifies how long after invocation the strobe pulse needs to be held active.

---

### TYPE

positive integer

---

### DEFAULT

0

---

### DESCRIPTION

This variable defines the default strobe pulse width, which is the default time that specifies how long after invocation the strobe pulse needs to be held active.

Changing the value of this variable modifies the content of the inferred or created test protocol generated by the **dft\_drc** command. You can overwrite the value of this variable by providing a user-defined test protocol and reading it in using the **read\_test\_protocol** command. The **write\_test** command uses the value of this variable (as stated in the test protocol attached to the design) to generate the test program for vector formats that support the notion of strobe width. For those formats that do not support it, the strobe width value specified is ignored.

The value of the **test\_default\_strobe\_width** variable is a real number value whose units are assumed to be nanoseconds, and the value must be a positive number. The sum of this value and the strobe time value must be less than or equal to the clock period value.

---

### SEE ALSO

[dft\\_drc\(2\)](#)  
[read\\_test\\_protocol\(2\)](#)  
[write\\_test\(2\)](#)  
[write\\_test\\_protocol\(2\)](#)  
[test\\_default\\_bidir\\_delay\(3\)](#)  
[test\\_default\\_delay\(3\)](#)  
[test\\_default\\_period\(3\)](#)  
[test\\_default\\_strobe\(3\)](#)

---

## **test\_disable\_enhanced\_dft\_drc\_reporting**

Prevents the **dft\_drc** command from reporting DRC violations using a new format.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true

---

### **DESCRIPTION**

This variable prevents the **dft\_drc** command from reporting DRC violations using a new format. The default is **true**, which disables the new format and uses the old DRC format for backward compatibility. To use the new format, set this variable to **false**.

---

### **SEE ALSO**

[dft\\_drc\(2\)](#)

---

## test\_disable\_find\_best\_scan\_out

Selects the scan-out pin on a scan cell based on availability instead of timing slack.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable, when set to **false** causes the **insert\_dft** command to select the scan-out pin on a scan cell that has the greatest timing slack. This usually means that **insert\_dft** makes extensive use of Qbar pins to drive the scan-in pins of scan cells. The tool supports inversions on the scan chain.

If you are using tools that do not support inversions, you can disable this behavior by setting this variable to **true**. The **insert\_dft** command does not attempt to find the optimum driver. Instead, the tool selects the driver based on availability, and it chooses the dedicated scan-out driver if any are defined in the library. The chosen driver can still be inverting or noninverting.

---

### SEE ALSO

[insert\\_dft\(2\)](#)

---

## **test\_dont\_fix\_constraintViolations**

Minimizes performance constraint violations.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

This variable minimizes performance constraint violations. When the value of this variable is set to **false** (the default), the **insert\_dft** command attempts to minimize performance constraint violations. You can disable this behavior by setting the variable to **true**.

---

### **SEE ALSO**

[insert\\_dft\(2\)](#)

---

## **test\_enable\_capture\_checks**

Controls checking for capture violations during execution of the **dft\_drc** command.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true

---

### **DESCRIPTION**

This variable controls the checking for capture violations, during the execution of the **dft\_drc** command.

Setting the value of **test\_enable\_capture\_checks** to **true** (the default value) enables capture checks during **dft\_drc** command activity.

Setting the value of **test\_enable\_capture\_checks** to **false** disables capture checks during **dft\_drc** command activity.

---

### **SEE ALSO**

[dft\\_drc\(2\)](#)

---

## test\_enable\_codec\_sharing

Instructs DFTMAX to share the same CODEC architecture across all partition decompressors/compressors.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When you insert adaptive scan compression logic with DFTMAX for multiple partitions at the top level, this variable controls whether a shared CODEC architecture is used across all partition decompressors/compressors (CODECs).

When set to its default value of **false**, smaller partition-specific CODECs are created for each partition. The top-level scan-in and scan-out ports are allocated separately to each partition CODEC, according to the total scan chain counts defined for the Internal\_scan and ScanCompression\_mode modes for each partition. Each scan-in and scan-out port connects to a single partition CODEC. There must be a sufficient number of scan-in and scan-out ports available to satisfy all partition CODEC connections.

When you set this variable to **true**, the scan chain counts are summed across the Internal\_scan and ScanCompression\_mode modes to build a more adaptive CODEC that is shared by all partitions. However, instead of building one large CODEC that connects to all partitions, this common CODEC is replicated for each partition. Functionally, all partitions share the same CODEC. Architecturally, this common CODEC is duplicated to keep routing local within the partition and to minimize top-level congestion.

For each duplicated CODEC, a separate subset of the decompressor outputs and compressor inputs are hooked up to each partition according to the ScanCompression\_mode scan chain count for that partition. The scan-in ports are shared, so that each scan-in port drives all CODECs. The scan-out ports are combined using XOR logic so that the top-level scan-out ports can capture the output from all partition compressors scan outputs. This architecture has similar testability efficiency to having a single top-level CODEC with the same architecture.

With the shared CODEC architecture, each partition's CODEC has only its subset of compressor and decompressor signals connected. After running **insert\_dft**, you should perform an incremental compile with boundary scan optimization enabled to optimize the CODEC logic to each partition.

---

### SEE ALSO

`set_dft_configuration(2)`  
`set_scan_compression_configuration(2)`  
`define_dft_partition(2)`

---

## **test\_enable\_retimining\_flops\_driven\_by\_direct\_scan\_clock\_driver**

Controls whether retiming registers are clocked by the global or locally gated clock.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

test\_variables

---

### **DESCRIPTION**

By default, the clock pin of a retiming register is connected to the clock source signal, even when the scan element it retimes is clocked by a locally gated clock.

When this variable is set to **true**, retiming registers are clocked by the (inverted sense of) the locally gated clock signal instead.

---

### **SEE ALSO**

[insert\\_dft\(2\)](#)

---

## test\_enable\_scan\_reordering\_in\_compile\_incremental

Enables scan chain reordering and repartitioning when an incremental compile is performed in Design Compiler Graphical.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable controls whether scan chain reordering is applied during an incremental compile in Design Compiler Graphical, which is performed by the following command:

```
prompt> compile_ultra -incremental -spg
```

The default is **true**, which enables reordering. To disable reordering, set this variable to **false**.

When reordering is enabled, repartitioning is also performed unless explicitly disabled with the **set\_optimize\_dft\_options -repartitioning\_method none** command.

Two flows are supported, as described in the following sections.

#### Binary DFTMAX Flow

In this flow, native DFT insertion, performed with the **insert\_dft** command, is followed by an incremental topographical compile. This incremental compile performs an incremental placement of the DFT-added logic (such as reconfiguration MUXs and compression logic). When this variable is set to **true**, the incremental compile also performs scan chain reordering to minimize the wire length of the overall scan connectivity.

This flow has the following requirements and limitations:

- Binary design data must be used for the incremental compile. You must perform the incremental compile in the same session as DFT insertion, or store the design in a .ddc file between sessions.
- Only DFTMAX compressed scan designs are supported. Pure standard scan designs are not supported.
- The **set\_optimize\_dft\_options** command is not supported.

#### ASCII Netlist Flow

In this flow, an ASCII netlist from a third-party DFT insertion tool is read in, along with a SCANDEF file describing the scan structures. When this variable is set to **true**, an incremental compile in this flow also performs scan chain reordering to minimize the wire length of the overall scan connectivity.

In this flow, you can use the **set\_optimize\_dft\_options** command to configure scan reordering, just as you would in IC Compiler.

This flow has the following requirements and limitations:

- Hierarchical SCANDEF is not supported; only a flat DFT flow is supported.
- Post-DFT DRC is not supported after reordering. Perform DRC checking in the ATPG tool to verify scan chain integrity.

---

## SEE ALSO

[compile\\_ultra\(2\)](#)

---

## test\_fast\_feedthrough\_analysis

Controls whether DFT DRC uses the TetraMAX fast feedthrough analysis engine.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

A *clock feedthrough* is a logic path in the design where the output pin of the path has the same clock behavior as the input pin of the path. The tool uses feedthrough path information during DRC. When the tool writes out CTL test model information for the design, the model includes any feedthrough paths that span from input to output.

By default, DFT Compiler performs basic analysis of clock network logic to determine clock propagation behavior. However, for complex clock network logic, you can enable advanced clock feedthrough analysis by setting the following variable:

```
prompt> set_app_var test_fast_feedthrough_analysis true
```

This variable setting uses the TetraMAX DRC engine (which the **dft\_drc** command runs internally) to detect clock feedthrough paths in the logic of the current design.

Enabling fast feedthrough analysis can help during both core creation and core integration:

- During core creation, feedthroughs from input port through complex logic to output port can be detected and included in the CTL model of the core.
- During core integration, if you have CTL-modeled cores that contain unidentified feedthrough paths, you can also set the **test\_simulation\_library** variable to configure the TetraMAX DRC engine to use a netlist simulation model for that core.

If you created the core with advanced feedthrough analysis, the CTL model should include any feedthrough paths through complex logic and you should not need to reanalyze the logic using a netlist simulation model. However, verify that the CTL model includes all expected feedthrough paths in this case.

Note that although feedthroughs that vary on a per-test-mode basis can be understood by DFT DRC and insertion of the current design, they cannot be described in the resulting CTL model.

---

### SEE ALSO

dft\_drc(2)

---

## **test\_icg\_n\_ref\_for\_dft**

Defines the integrated clock-gating cell to be used for implementing return-to-one clock gating in the DFT logic.

---

### **TYPE**

string

---

### **DEFAULT**

""

---

### **DESCRIPTION**

When DFT Compiler inserts clock-gating cells as a part of the DFT logic, this variable constrains the insertion process to use the specified library cell to gate any clock signal that has a return-to-one (RTO) waveform. The name must match an available cell in the target libraries, and this cell must be an integrated clock-gating cell.

Specify the cell name without the library name. If the library name is included, the specification is ignored without warning or error.

The cell specified by this variable is used only for the initial logic construction. After insertion, subsequent design optimizations can resize the cell (if allowed by the library cell attributes).

This variable applies to DFT logic inserted by DFTMAX during on-chip clocking (OCC) controller insertion and serializer insertion.

By default, when this variable is not set, DFTMAX will gate clock signals using regular combinational gates.

---

### **SEE ALSO**

[set\\_dft\\_configuration\(2\)](#)  
[set\\_scan\\_compression\\_configuration\(2\)](#)  
[set\\_dft\\_clock\\_controller\(2\)](#)  
[test\\_icg\\_p\\_ref\\_for\\_dft\(3\)](#)

---

## **test\_icg\_p\_ref\_for\_dft**

Defines the integrated clock-gating cell to be used for implementing return-to-zero clock gating in the DFT logic.

---

### **TYPE**

string

---

### **DEFAULT**

""

---

### **DESCRIPTION**

When DFT Compiler inserts clock-gating cells as a part of the DFT logic, this variable constrains the insertion process to use the specified library cell to gate any clock signal that has a return-to-zero (RTZ) waveform. The name must match an available cell in the target libraries, and this cell must be an integrated clock-gating cell.

Specify the cell name without the library name. If the library name is included, the specification is ignored without warning or error.

The cell specified by this variable is used only for the initial logic construction. After insertion, subsequent design optimizations can resize the cell (if allowed by the library cell attributes).

This variable applies to DFT logic inserted by DFTMAX. This includes: on-chip clocking (OCC) controllers, serializer, DFTMAX Ultra, and LogicBIST insertion.

By default, when this variable is not set, DFTMAX will gate clock signals using regular combinational gates.

---

### **SEE ALSO**

`set_dft_configuration(2)`  
`set_scan_compression_configuration(2)`  
`set_dft_clock_controller(2)`  
`test_icg_n_ref_for_dft(3)`

---

## test\_infer\_slave\_clock\_pulse\_after\_capture

Guides protocol inference for master/slave test design methodologies during execution of the **dft\_drc** command.

---

### TYPE

string

---

### DEFAULT

infer

---

### DESCRIPTION

Guides protocol inference for master/slave test design methodologies during execution of the **dft\_drc** command.

When set to **infer** (the default value), **dft\_drc** protocol inference is based on an analysis of the scan cell states.

The other possible values are **pulse** and **no\_pulse**. When set to **pulse**, all slave clocks are pulsed after capture. When set to **no\_pulse**, no slave clocks are pulsed after capture.

If a slave clock is being inferred, and the value of the variable is invalid, the warning message TEST-314 is issued and the compiler uses the **infer** value by default.

---

### SEE ALSO

[dft\\_drc\(2\)](#)

---

## test\_input\_wrapper\_chain\_naming\_style

Specifies the naming style used for input core wrapper chains.

---

### TYPE

string

---

### DEFAULT

""

---

### DESCRIPTION

This variable determines the naming style to be used by the **insert\_dft** command for naming input wrapper chains, which are created when the **-mix\_cells** option of the **set\_wrapper\_configuration** command is set to **false**. (This is the default for maximized reuse core wrapping, but not for simple core wrapping.)

This variable must contain one "%s" (percent s) character sequence. The '%s' is replaced with the ordinal chain number, beginning with 1.

The '%s' must be placed at the end of the string, so that the string represents a prefix. In addition, the string '<testmode>\_i\_' is prefixed to the specified string.

---

### EXAMPLE

For example, to name the input wrapper chains as IP\_IWRAP\_1, IP\_IWRAP\_2, and so on,

```
set_app_var test_wrapper_chain_naming_style {IP_IWRAP_%s}
```

---

### SEE ALSO

[insert\\_dft\(2\)](#)

---

## test\_isolate\_hier\_scan\_out

Prevents the **insert\_dft** command from inserting logic that isolates scan connections at hierarchical boundaries during functional operation.

---

### TYPE

integer

---

### DEFAULT

0

---

### DESCRIPTION

This variable prevents the **insert\_dft** command from inserting logic that isolates scan connections at hierarchical boundaries during functional operation. When the value is set to **1**, the **insert\_dft** command inserts logic that isolates scan connections at hierarchical boundaries during functional operation. This can reduce dynamic switching currents and output loading. When set to **0** (the default), no logic is inserted.

---

### SEE ALSO

[insert\\_dft\(2\)](#)

---

## test\_keep\_connected\_scan\_en

Controls whether existing scan-enable signals are disconnected during DFT insertion.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

During DFT insertion, DFT Compiler identifies the scan-enable pins of scan cells and test models that should be connected to the global scan-enable signal. These are known as scan-enable target pins.

When this variable is set to the default value of **false**, if a scan-enable target pin already has a connection, DFT Compiler disconnects it to make the connection to the global scan-enable pin. During DFT insertion, the **insert\_dft** command issues a TEST-394 warning to note the disconnection:

Warning: Disconnecting pin 'UMEMWRAP/UMEM/SE' to route scan enable. (TEST-394)

When this variable is set to **true**, if a target scan-enable pin already has a connection (besides a test-ready deasserted constant value), DFT Compiler skips that target pin. In this case, the **insert\_dft** command issues a TEST-410 warning to confirm that the existing connection is kept:

Warning: Not disconnecting pin 'UMEMWRAP/UMEM/SE' to route scan enable. (TEST-410)

If you need to make a scan-enable connection somewhere else in the existing logic driving the target pin, you can use the **set\_dft\_connect** command to add additional scan-enable target pins for DFT insertion:

```
set_dft_signal \
-type ScanEnable -usage scan \
-view spec \
-port SCAN_EN -connect_to UMEMWRAP/SCAN_EN
```

During DFT insertion, DFT Compiler may replace existing scan cells. To prevent this behavior the scan-enable target pins of the scan cell must be functionally connected. Set this variable to **true** to keep this connection and avoid replacing the scan cell.

---

### SEE ALSO

`set_dft_connect(2)`

```
set_dft_signal(2)
```

---

## test\_mode\_port\_inverted\_naming\_style

Specifies the naming style to use for the **test\_hold\_logic\_zero** type of test mode signal ports to be created in the design.

---

### TYPE

string

---

### DEFAULT

test\_mode\_i%s

---

### DESCRIPTION

This variable specifies the naming style to use for the **test\_hold\_logic\_zero** type of test-mode signal ports to be created in the design. New ports are not created if suitable ports are identified with the **set\_dft\_signal** command.

This variable must contain one %s (percent s) character sequence. When a new port is added, if its name is the same as that of an existing port, %s is replaced by a character (a through z) that creates a unique name.

For example, if this variable is set to *MY\_TM\_I%*s, when synthesis adds a new port for the test-mode signal, the port is named

MY\_TM\_I

If a port named *MY\_TM\_I* already exists in the design, the new port is named

MY\_TM\_Ia

---

### SEE ALSO

[insert\\_dft\(2\)](#)

---

## test\_mode\_port\_naming\_style

Determines the naming style to be used by the **insert\_dft** command for test mode ports created in designs during the addition of test point circuitry.

---

### TYPE

string

---

### DEFAULT

test\_mode%s

---

### DESCRIPTION

This variable determines the naming style to be used by the **insert\_dft** command for test mode ports created in designs during the addition of test point circuitry. New ports are not created if suitable ports are identified with the **set\_dft\_signal** command.

This variable must contain one %s (percent s) character sequence. When a port is added, if its name is the same as that of an existing port, %s is replaced by a character (a through z) that creates a unique name.

For example, if this variable is set to *MY\_TM%s*, when synthesis adds a new port for the test mode signal, the port is named

*MY\_TM*

If a port named *MY\_TM* already exists in the design, the new port is named

*MY\_TMa*

---

### SEE ALSO

[insert\\_dft\(2\)](#)

---

## test\_mux\_constant\_si

Specifies how scan insertion uses a port you declare as scan input, when the port is tied high or to the ground in functional mode.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable specifies how scan insertion uses a port you declare as scan input, when the port is tied high or to the ground in functional mode.

When this variable is set to **false** (the default value), scan insertion ignores the tie-off logic and directly uses the port as a scan input. This might change the output of the design during functional mode.

When this variable is set to **true**, scan insertion multiplexes the scan input signal with the constant logic, using the scan enable signal to control the multiplexer.

---

### SEE ALSO

[insert\\_dft\(2\)](#)

---

## test\_mux\_constant\_so

Specifies how scan insertion treats specified scan output ports with existing constant connections.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable specifies how scan insertion uses a port you declare as a scan output, when the port has an existing connection to logic zero or logic one before scan insertion.

When this variable is set to **false**, which is default, if the specified port is tied to logic zero or logic one, DFT Compiler ignores the constant value during scan insertion and drives the port directly as a scan output. This behavior ensures that no additional logic is added at the port if it was undriven in the RTL and tied to logic zero during synthesis.

If the existing constant value driving the port is required for proper operation in functional mode, set this variable to **true**. In this case, DFT Compiler multiplexes the scan-out signal with the constant value, using the scan-enable signal to control the multiplexer, so that the functional behavior remains unchanged.

This variable affects only scan output ports that are explicitly defined using the **set\_dft\_signal -type ScanDataOut** command.

---

### SEE ALSO

[insert\\_dft\(2\)](#)

---

## test\_non\_scan\_clock\_port\_naming\_style

Specifies the style the **insert\_dft** command uses to name the ports that clock gating creates for nonscan clocks.

---

### TYPE

string

---

### DEFAULT

test\_nsc\_%s

---

### DESCRIPTION

This variable specifies the style the **insert\_dft** command uses to name the ports that clock gating creates for nonscan clocks.

This variable must contain one %s (percent s) character sequence. The %s is replaced by a string identifying the original clock, its inversion (either *i* for inverted or *n* for noninverted), and the inactive level (either 0 or 1).

The following example shows the renaming of this variable from its setting of MY\_NSC\_%s to MY\_NSC\_clockn0. When **insert\_dft** creates a nonscan clock (from an original clock named "clock") that is noninverted and inactive low, that port is named

MY\_NSC\_clockn0

---

### SEE ALSO

[insert\\_dft\(2\)](#)

---

## test\_occ\_insert\_clock\_gating\_cells

Enables the use of clock-gating cells in the implementation of the on-chip clocking (OCC) controller.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

By default, when a DFT-inserted on-chip clocking (OCC) controller is implemented, combinational multiplexer logic is used to switch between the clocks. You can set this variable to **true** to use latch-based clock-gating clock selection logic instead.

When this variable is set to **true**, the following capabilities are also available:

- If you want to use a particular integrated clock-gating (ICG) cell, you can specify it with the **test\_icg\_p\_ref\_for\_dft** variable.
- If you want to use particular library cells for the clock selection logic, you can specify them with the **occ\_lib\_cell\_nor2**, **occ\_lib\_cell\_andor21**, **occ\_lib\_cell\_andor22**, **occ\_lib\_cell\_clkbuf**, and **occ\_lib\_cell\_clkinv** design attributes (in supported combinations).
- If you want a dedicated OCC clock chain connection that exists only on the ATE clock path, you can set the **test\_dedicated\_clock\_chain\_clock** variable to **true**.

---

### SEE ALSO

`set_dft_configuration(2)`  
`set_dft_clock_controller(2)`  
`test_dedicated_clock_chain_clock(3)`  
`test_icg_p_ref_for_dft(3)`

---

## **test\_output\_wrapper\_chain\_naming\_style**

Specifies the naming style used for output core wrapper chains.

---

### **TYPE**

string

---

### **DEFAULT**

""

---

### **DESCRIPTION**

This variable determines the naming style to be used by the **insert\_dft** command for naming output wrapper chains, which are created when the **-mix\_cells** option of the **set\_wrapper\_configuration** command is set to **false**. (This is the default for maximized reuse core wrapping, but not for simple core wrapping.)

This variable must contain one "%s" (percent s) character sequence. The "%s" is replaced with the ordinal chain number, beginning with 1.

The "%s" must be placed at the end of the string, so that the string represents a prefix. In addition, the string '<testmode>\_o\_' is prefixed to the specified string.

---

### **EXAMPLE**

For example, to name the output wrapper chains as IP\_OWRAP\_1, IP\_OWRAP\_2, and so on,

```
set_app_var test_wrapper_chain_naming_style {IP_OWRAP_2}
```

---

### **SEE ALSO**

**insert\_dft(2)**

---

## **test\_preview\_scan\_shows\_cell\_types**

Shows cell instance types when running the **preview\_dft** command.

---

### **TYPE**

string

---

### **DEFAULT**

false

---

### **DESCRIPTION**

This variable, when set to **true**, shows cell instance types when running the **preview\_dft** command. By default, cell type information is suppressed.

---

### **SEE ALSO**

[preview\\_dft\(2\)](#)

---

## test\_rtldrc\_latch\_check\_style

Specifies the latch check style to use during **rtldrc** command activities.

---

### TYPE

string

---

### DEFAULT

default

---

### DESCRIPTION

Specifies the latch check style to use during **rtldrc** command activities. The value of this variable affects the outcome of the **rtldrc** command, which uses this variable to determine the way latches are checked for violations against the design rules of a scan test methodology. When latch transparency checks are selected, nontransparent latches are flagged as violations (**TEST-1211**). This also suppresses checking for hold data violations (**TEST-965**) and latch controllability violations (**TEST-1210**).

To determine the current value of this variable, enter one of the following commands, depending on which mode you are using:

```
prompt> printvar test_rtldrc_latch_check_style  
or  
dc_shell-t> printvar test_rtldrc_latch_check_style
```

---

### SEE ALSO

`set_scan_configuration(2)`

---

## **test\_scan\_chain\_naming\_style**

Specifies the naming style used for non-wrapper scan chains.

---

### **TYPE**

string

---

### **DEFAULT**

""

---

### **DESCRIPTION**

This variable determines the naming style to be used by the **insert\_dft** command for naming scan chains. (In core-wrapped designs, wrapper chains are named using separate variables.)

This variable must contain one "%s" (percent s) character sequence. The '%s' is replaced with the ordinal chain number, beginning with 1.

The '%s' must be placed at the end of the string, so that the string represents a prefix.

The default is the ordinal chain number, beginning with 1.

---

### **EXAMPLE**

For example, to name the scan chains as IP\_SCAN\_1, IP\_SCAN\_2, and so on,

```
set_app_var test_scan_chain_naming_style {IP_SCAN_%s}
```

---

### **SEE ALSO**

[insert\\_dft\(2\)](#)

---

## test\_scan\_clock\_a\_port\_naming\_style

Determines the naming style to be used by the **insert\_dft** command for test scan clock a ports created in designs during the addition of test scan circuitry.

---

### TYPE

string

---

### DEFAULT

test\_sca%**s**

---

### DESCRIPTION

This variable determines the naming style to be used by the **insert\_dft** command for test scan clock a ports created in designs during the addition of test scan circuitry. This variable is used in the same way as the **test\_clock\_port\_naming\_style** variable is used. If the **set\_dft\_signal** command identifies suitable ports, new ports are not added.

This variable must contain one %**s** (percent s) character sequence. When adding a port, if the new port name is the same as an existing port name, %**s** is replaced by a character (a through z) that creates a unique name.

For example, if this variable is set to **MY\_TSCA%****s** when **insert\_dft** adds a new port for the *test scan clock a* signal, the port is named **MY\_TSCA**

If a port named **MY\_TSCA** already exists in the design, the new port is named

**MY\_TSCAa**

---

### SEE ALSO

**insert\_dft(2)**  
**test\_clock\_port\_naming\_style(3)**  
**test\_scan\_clock\_port\_naming\_style(3)**  
**test\_scan\_clock\_b\_port\_naming\_style(3)**  
**test\_scan\_enable\_inverted\_port\_naming\_style(3)**  
**test\_scan\_enable\_port\_naming\_style(3)**

---

## test\_scan\_clock\_b\_port\_naming\_style

Determines the naming style to be used by the **insert\_dft** command for test scan clock b ports created in designs during the addition of test scan circuitry.

---

### TYPE

string

---

### DEFAULT

test\_scb%s

---

### DESCRIPTION

This variable determines the naming style to be used by the **insert\_dft** command for test scan clock b ports created in designs during the addition of test scan circuitry. This variable must contain one %s (percent s) character sequence. When adding a port, if the new port name is the same as an existing port name, %s is replaced by a character (a through z) that creates a unique name.

For example, if this variable is set to *MY\_TSCB%s*, when **insert\_dft** adds a new port for the *test scan clock b* signal, the port is named

*MY\_TSCB*

If a port named **MY\_TSCB** already exists in the design, the new port is named

*MY\_TSCBa*

---

### SEE ALSO

[insert\\_dft\(2\)](#)  
[set\\_dft\\_signal\(2\)](#)  
[test\\_clock\\_port\\_naming\\_style\(3\)](#)  
[test\\_scan\\_clock\\_port\\_naming\\_style\(3\)](#)  
[test\\_scan\\_clock\\_a\\_port\\_naming\\_style\(3\)](#)  
[test\\_scan\\_enable\\_inverted\\_port\\_naming\\_style\(3\)](#)  
[test\\_scan\\_enable\\_port\\_naming\\_style\(3\)](#)

---

## test\_scan\_clock\_port\_naming\_style

Determines the naming style used by the **insert\_dft** command for global test scan signal ports created in designs during the addition of test circuitry.

---

### TYPE

string

---

### DEFAULT

test\_sc%s

---

### DESCRIPTION

This variable determines the naming style used by the **insert\_dft** command for global test scan signal ports created in designs during the addition of test circuitry. This variable is used in the same way as the **test\_clock\_port\_naming\_style** variable is used. This variable must contain one %s (percent s) character sequence. When adding a port, if the new port name is the same as an existing port name, %s is replaced by a character (a through z) that creates a unique name.

For example, if this variable is set to **MY\_TSC%s** when **insert\_dft** adds a new port for the *test scan clock* signal, the port is named

MY\_TSC

If a port named **MY\_TSC** already exists in the design, the new port is named

MY\_TSCa

---

### SEE ALSO

**insert\_dft(2)**  
**set\_dft\_signal(2)**  
**test\_clock\_port\_naming\_style(3)**  
**test\_scan\_clock\_a\_port\_naming\_style(3)**  
**test\_scan\_clock\_b\_port\_naming\_style(3)**  
**test\_scan\_enable\_inverted\_port\_naming\_style(3)**  
**test\_scan\_enable\_port\_naming\_style(3)**

---

## test\_scan\_enable\_inverted\_port\_naming\_style

Determines the naming style to be used by the **insert\_dft** command for scan-enable inverted ports created in designs during the addition of test scan circuitry.

---

### TYPE

string

---

### DEFAULT

test\_sei%*s*

---

### DESCRIPTION

This variable determines the naming style to be used by the **insert\_dft** command for scan-enable inverted ports created in designs during the addition of test scan circuitry. This variable is used in the same way as the **test\_clock\_port\_naming\_style** variable is used. This variable must contain one %*s* (percent *s*) character sequence. When adding a port, if the new port name is the same as an existing port name, %*s* is replaced by a character (*a* through *z*) that creates a unique name.

For example, if this variable is set to *MY\_TSEI%*s** when **insert\_dft** adds a new port for the *test scan enable inverted* signal, the port is named

MY\_TSEI

If a port named *MY\_TSEI* already exists in the design, the new port is named

MY\_TSEIa

---

### SEE ALSO

[insert\\_dft\(2\)](#)  
[set\\_dft\\_signal\(2\)](#)  
[test\\_clock\\_port\\_naming\\_style\(3\)](#)  
[test\\_scan\\_clock\\_port\\_naming\\_style\(3\)](#)  
[test\\_scan\\_clock\\_a\\_port\\_naming\\_style\(3\)](#)  
[test\\_scan\\_clock\\_b\\_port\\_naming\\_style\(3\)](#)  
[test\\_scan\\_enable\\_port\\_naming\\_style\(3\)](#)

---

## test\_scan\_enable\_port\_naming\_style

Determines the naming style to be used by the **insert\_dft** command for test scan-enable ports created in designs during the addition of test scan circuitry.

---

### TYPE

string

---

### DEFAULT

test\_se%s

---

### DESCRIPTION

This variable determines the naming style to be used by the **insert\_dft** command for scan-enable ports created in designs during the addition of test scan circuitry. This variable is used in the same way as the **test\_clock\_port\_naming\_style** variable is used. This variable must contain one %s (percent s) character sequence. When adding a port, if the new port name is the same as an existing port name, %s is replaced by a character (a through z) that creates a unique name.

For example, if this variable is set to *MY\_TSE%*s when **insert\_dft** adds a new port for the *test scan enable* signal, the port is named

MY\_TSE

If a port named *MY\_TSE* already exists in the design, the new port is named

MY\_TSEa

In the pipelined scan-enable flow, this variable affects the scan-enable signal (of type **ScanEnable**) but not the pipeline-enable signal (of type **LOSPipelineEnable**).

---

### SEE ALSO

[insert\\_dft\(2\)](#)  
[set\\_dft\\_signal\(2\)](#)  
[test\\_clock\\_port\\_naming\\_style\(3\)](#)  
[test\\_scan\\_clock\\_port\\_naming\\_style\(3\)](#)  
[test\\_scan\\_clock\\_a\\_port\\_naming\\_style\(3\)](#)  
[test\\_scan\\_clock\\_b\\_port\\_naming\\_style\(3\)](#)  
[test\\_scan\\_enable\\_inverted\\_port\\_naming\\_style\(3\)](#)

---

## test\_scan\_in\_port\_naming\_style

Specifies the naming style used by the **insert\_dft** command for serial test-signal ports created in designs during the addition of test circuitry.

---

### TYPE

string

---

### DEFAULT

test\_si%s%s

---

### DESCRIPTION

This variable specifies the naming style used by the **insert\_dft** command for serial test-signal ports created in designs during the addition of test circuitry. New ports are not added if suitable ports are identified with the **set\_dft\_signal** command.

This variable must contain two %s (percent s) character sequences. For a design with multiple scan chains, the index of the connecting scan chain replaces the first %s. For designs with single scan chains, %s is replaced by an empty string (""). The second %s is replaced by an alphabetic character if the new port name conflicts with an existing name.

For example, if this variable is set to *SI\_%s%s*, when **insert\_dft** adds a new port for the only scan-in signal of a design with one scan chain, the port is named

SI

If this variable is set to *TDI\_%s%s*, when **insert\_dft** adds a new port for the scan-in signal of the second scan chain in the design, the port is named

TDI\_2

---

### SEE ALSO

[insert\\_dft\(2\)](#)  
[test\\_scan\\_out\\_port\\_naming\\_style\(3\)](#)

---

## **test\_scan\_link\_so\_lockup\_key**

Indicates to the **preview\_dft** command what key to use to identify cells with scan-out lock-up latches in reports.

---

### **TYPE**

string

---

### **DEFAULT**

l

---

### **DESCRIPTION**

This variable specifies to the **preview\_dft** command what key to use to identify cells with scan-out lock-up latches in reports.

---

### **SEE ALSO**

[preview\\_dft\(2\)](#)

---

## **test\_scan\_link\_wire\_key**

Indicates to the **preview\_dft** command the key to use to identify cells that drive wire-scan links in reports.

---

### **TYPE**

string

---

### **DEFAULT**

w

---

### **DESCRIPTION**

This variable indicates to the **preview\_dft** command the key to use to identify cells that drive wire-scan links in reports.

---

### **SEE ALSO**

[preview\\_dft\(2\)](#)

---

## test\_scan\_out\_port\_naming\_style

Specifies the naming style used by the **insert\_dft** command serial test-signal ports created in designs during the addition of test circuitry.

---

### TYPE

string

---

### DEFAULT

test\_so%s%s

---

### DESCRIPTION

This variable specifies the naming style used by the **insert\_dft** command for serial test-signal ports created in designs during the addition of test circuitry. New ports are not added if suitable ports are identified with the **set\_dft\_signal** command.

This variable must contain two %s (percent s) character sequences. For a design with multiple scan chains, the index of the connecting scan chain replaces the first %s. For designs with single scan chains, %s is replaced by an empty string (""). The second %s is replaced by an alphabetic character if the new port name conflicts with an existing name.

For example, if this variable is set to *SO\_%s%s*, when **insert\_dft** adds a new port for the only scan-out signal of a design with one scan chain, the port is named

SO

If this variable is set to *TDO\_%s%s*, when **insert\_dft** adds a new port for the scan-out signal of the second scan chain in the design, the port is named

TDO\_2

---

### SEE ALSO

[insert\\_dft\(2\)](#)  
[test\\_scan\\_in\\_port\\_naming\\_style\(3\)](#)

---

## **test\_scan\_segment\_key**

Instructs the **preview\_dft** command what key to use to identify scan segments in reports.

---

### **TYPE**

string

---

### **DEFAULT**

s

---

### **DESCRIPTION**

This variable instructs the **preview\_dft** command what key to use to identify scan segments in reports.

---

### **SEE ALSO**

[preview\\_dft\(2\)](#)

---

## **test\_scan\_true\_key**

Specifies to the **preview\_dft** command the key to use to identify cells with true-scan attributes in reports.

---

### **TYPE**

string

---

### **DEFAULT**

t

---

### **DESCRIPTION**

This variable specifies to the **preview\_dft** command the key to use to identify cells with true scan attributes in reports.

---

### **SEE ALSO**

[preview\\_dft\(2\)](#)

---

## **test\_scandef\_stop\_skip\_last\_segment\_with\_scanout\_lockup**

Keeps the SCANDEF chains from having a lockup latch as STOP point.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

test\_variables

---

### **DESCRIPTION**

When activated, the SCANDEF information generated by the **insert\_dft** command will not have a lockup latch as a STOP point.

---

### **SEE ALSO**

[insert\\_dft\(2\)](#)  
[write\\_scan\\_def\(2\)](#)  
[check\\_scan\\_def\(2\)](#)

---

## **test\_serialize\_put\_fsm\_clock\_output**

Allows the serializer clock controller outputs to be described in the STIL protocol file.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true

---

### **DESCRIPTION**

By default, when DFTMAX inserts a serializer, it includes information about the outputs of the serializer clock controller in the STIL protocol file for ScanCompression\_mode. The information is placed in a ClockStructure block. This information helps TetraMAX trace the source of the signal clock signals during DRC.

You can prevent the addition of this information by setting this variable to **false**.

---

### **SEE ALSO**

`set_dft_configuration(2)`  
`set_scan_compression_configuration(2)`

---

## **test\_set\_svf\_print\_exclude\_existing\_dft\_se\_alike**

`test_set_svf_print_exclude_existing_dft_se_alike`

---

### **TYPE**

bool

---

### **DEFAULT**

false

---

### **DESCRIPTION**

The default behavior of set\_svf -print path is to automatically include in the guide\_scan\_input of the svf file all signals defined as either set\_dft\_signal -view spec or set\_dft\_signal -view existing\_dft. This behavior for the second case is not correct since already-existing test signal guidance should be specified using set\_dft\_signal -active\_state [0|1].

The default behavior might lead to problems latter in the verification step. The variable `test_set_svf_print_exclude_existing_dft_se_alike` fixes this issue by including only the signals defined using set\_dft\_signal -view spec.

---

### **SEE ALSO**

`set_dft_signal(2)`  
`set_svf(2)`

---

## test\_setup\_additional\_clock\_pulse

Adds an extra clock cycle to all clocks in the design in the initialization procedure during the execution of the **create\_test\_protocol** command.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When this variable is set to **true**, an extra clock cycle is added to all clocks in the design in the initialization procedure during the execution of the **create\_test\_protocol** command.

Set this variable to **true** if you are using clock gating and if the off-state of the clock driving the clock gating (at time=0) is the opposite of the active state of the clock-gating latch enable input.

The extra cycle ensures that all clock-gating latches are at a known state at the end of the initialization procedure.

---

### SEE ALSO

`create_test_protocol(2)`  
`dft_drc(2)`  
`read_test_protocol(2)`  
`write_test_protocol(2)`

---

## test\_shared\_codec\_io\_architecture

Specifies whether a consistent load-mode architecture should be used for DFTMAX codec insertion in the shared codec I/O flow.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable specifies whether codecs inserted by DFTMAX use a consistent load-mode architecture, which can be helpful in the shared codec I/O flow.

When the shared codec I/O feature is enabled with the **-shared\_inputs** option of the **set\_scan\_compression\_configuration** command, the tool shares three categories of input pins across all codecs: load-mode, high X-tolerance, and scan pins. Pins are shared across codecs within each category, but not across the categories.

The high X-tolerance and scan pin counts are predictable, but the load-mode pin count can sometimes vary across codecs, which can make it difficult to know what sharing configuration to use.

You can set this variable to **true** to force newly inserted codecs in the current design to use two load-mode pins. This prevents load-mode pin count variability.

If you leave this variable set to its default of **false**, load-mode pins are still shared, even if their counts differ across codecs.

For more information on shared codec I/O pin categories, see the user guide documentation on determining the fully shared I/O configuration.

---

### SEE ALSO

[set\\_scan\\_compression\\_configuration\(2\)](#)

---

## test\_simulation\_library

Specifies the path name to a Verilog simulation library.

---

### TYPE

list

---

### DESCRIPTION

The **test\_simulation\_library** variable specifies the file names of one or more Verilog simulation libraries used by the **dft\_drc** command. These simulation models are necessary if you have cells which have no functional information in the technology library, such as memories.

If a simulation model is provided for a cell which already has functional information in the technology library, the simulation model takes precedence during **dft\_drc**. This allows complete simulation models to be provided for complex cells which have simplified or dummy functionality in the technology library.

The Verilog functional descriptions for the cells specified with the **test\_simulation\_library** variable must be self-contained. They cannot depend on any functionality of cells defined in the \$link\_library, since **dft\_drc** does not convert the entire \$link\_library; it only converts the cells instantiated by the current design.

---

### EXAMPLES

The following example shows how you can set the simulation library to files containing multiple models each:

```
lappend search_path ./my_lib_models  
set test_simulation_library {all_my_memories.v all_my_reg_files.v}
```

In the above example, the memory and register file model files are located using the search path, and read in to comprise the simulation library.

The **test\_simulation\_library** variable also accepts the asterisk (\*) wildcard character in the file names to allow for the case where multiple files under a certain directory comprise the simulation library files:

```
set test_simulation_library {/root/install/xyz/lib/verilog/*.v}
```

In this example, all files with a ".v" name extension under the /root/install/xyz/lib/verilog/ directory are considered to comprise the simulation library. The asterisk (\*) is the only wildcard character allowed in the library file name. If a wildcard is used in the file name, specify the full path name of the library files. This avoids the combined effect of the search\_path and the wildcard character bringing in unexpected files as the simulation library.

---

### SEE ALSO

dft\_drc(2)

---

## test\_soc\_core\_wrap\_allow\_multibit\_ioregs

Specifies whether multibit registers can be shared wrapper cells in maximized reuse wrapper chains.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable specifies whether multibit registers can be shared wrapper cells in wrapper chains.

When set to **true** (the default), multibit cells can be used in wrapper chains. For best results, configure core wrapping before performing multibit banking with

- The initial **compile\_ultra** command (RTL inference flow)
- The **identify\_register\_banks** command (physical banking flow)

This ensures that multibit cells anticipate the I/O register classification requirements of core wrapping.

When set to **false**, multibit cells cannot be used in wrapper chains. Note that in this case, core wrapping does not place any restrictions on multibit banking of I/O registers. If any port is associated with a multibit cell, a TEST-1067 warning message is issued and the port gets a dedicated wrapper cell. If you see this message, you can improve your QoR by restoring this variable to its default of **true**.

This variable is used only when the maximized reuse wrapper flow is enabled. Multibit cells cannot be shared wrapper cells in the simple wrapper flow.

---

## test\_stil\_max\_line\_length

Specifies the maximum line length for the file written by the **write\_test\_protocol -format stil** command.

---

### TYPE

integer

---

### DEFAULT

72

---

### DESCRIPTION

This variable specifies the maximum line length for the file written by the **write\_test\_protocol -format stil** command. The recognized value is any integer between 60 and 5000. The default value is **72**.

When **write\_test\_protocol -format stil** writes the *design\_name.spf* file, the command inserts a new line at or before the value of this variable, but identifiers and keywords are always preserved. If an identifier is longer than the value of this variable, the command makes an exception to the line length limit so as to preserve the identifier. The identifier begins at a new line and is printed in its entirety before the next new line.

---

### SEE ALSO

[write\\_test\\_protocol\(2\)](#)

---

## test\_suppress\_toggling\_instance\_name\_prefix

Specifies the prefix used for toggle suppression gates inserted at scan cell functional outputs.

---

### TYPE

string

---

### DEFAULT

""

---

### DESCRIPTION

This variable specifies the prefix used in generating cell instance names for toggle suppression gates inserted by the **insert\_dft** command at scan cell functional outputs.

The variable has an effect only when used in conjunction with the **set\_scan\_suppress\_toggling** command, which configures the insertion of toggle suppression logic that prevents unnecessary functional logic toggling during scan shift.

When toggling suppression is enabled, and the variable is set to a string value "*myprefix*", toggle suppression gates added by the **insert\_dft** command will be named in the form:

*<myprefix>\_<register\_cell\_leaf\_name>\_<gated\_output\_pin\_name>*

For example, if you set the variable to QGATE, a gating cell inserted at CORE/ENAB\_reg/Q would be named CORE/QGATE\_ENAB\_reg\_Q. Since the gating cell is placed at the same level of hierarchy as the gated scan cell, they both share the same hierarchical path name.

When this variable is set to an empty string, which is the default, the gating cell instance names are determined by the **compile\_instance\_name\_prefix** variable.

To determine the current value of this variable, use the **printvar test\_suppress\_toggling\_instance\_name\_prefix** command. For a list of compile variables and their current values, use the **print\_variable\_group test** command.

---

### SEE ALSO

`set_scan_suppress_toggling(2)`

---

## **test\_sync\_occ\_1x\_period**

Specifies the clock period for the slowest-frequency PLL clock of a DFT-inserted synchronous OCC controller.

---

### **TYPE**

positive nonzero integer

---

### **DEFAULT**

20

---

### **DESCRIPTION**

When you insert a synchronous OCC controller, you can optionally specify the clock period of the slowest-frequency clock with this variable. It affects the clock period values in the ClockTiming block of the STIL protocol file created by the tool. Although the value does not affect pattern generation in TetraMAX, you can specify it for informational purposes.

This value is used for all synchronous OCC controllers in the design.

This variable must be set so that any 2X or 4X clocks have an integer period value greater than 1 when derived (by division) from this 1X clock period value. If you control any 2X frequency clocks, this value should be at least 4 and be divisible by 2. If you control any 4X frequency clocks, this value should be at least 8 and be divisible by 4.

This variable pertains only to synchronous OCC controllers, whose clocks are specified with the **-1x\_clocks**, **-2x\_clocks**, and **-4x\_clocks** options of the **set\_dft\_clock\_controller** command.

---

### **SEE ALSO**

[set\\_dft\\_clock\\_controller\(2\)](#)

---

## test\_tp\_enable\_logic\_type

Specifies what type of enable logic to implement for test point registers.

---

### TYPE

Boolean

---

### DEFAULT

gate

---

### DESCRIPTION

This variable controls what type of enable logic to implement for test point registers.

When a test point's control signal is deasserted, its test point registers is held at a known static value. This variable controls how that logic is implemented.

The valid values for this variable are:

- **gate** - AND/OR gate at the register Q pin

The register output is ANDed or ORed with the control signal. When the control signal is deasserted, the register output is also deasserted.

- **reset** - asynchronous-reset register

The register is reset to logic zero whenever the control signal is deasserted. (However, the reset is blocked when the scan-enable signal is asserted, to allow for scan operation in test modes where the test point is not active.)

- **set** - asynchronous-set register

This is the same as the **reset** case, except that an asynchronous set is implemented instead.

The logic implementation considers whether the control signal is active-high or active-low, and the type of enable logic specified by this variable, so that deasserting the control signal deactivates the test points.

This variable applies to both automatically inserted and user-defined test point registers. It requires that the **testability** DFT client be enabled with the **set\_dft\_configuration** command.

---

### SEE ALSO

```
preview_dft(2)
set_testability_configuration(2)
set_test_point_element(2)
```

---

## test\_user\_defined\_instruction\_naming\_style

Indicates to the **check\_bsd** command and the **write\_bsdl** command the naming style to use for the user-defined (nonstandard) instructions inferred by these commands.

---

### TYPE

string

---

### DEFAULT

gate

---

### DESCRIPTION

This variable indicates to the **check\_bsd** command and the **write\_bsdl** command the naming style to use for the user-defined (nonstandard) instructions inferred by these commands. The format for the specification is *string%d*; the specification must contain exactly one %d. Names resulting from the default specification (**USER%d**) are USER1, USER2, and so on.

---

### SEE ALSO

[check\\_bsd\(2\)](#)  
[write\\_bsdl\(2\)](#)

---

## test\_user\_test\_data\_register\_naming\_style

Indicates to the **check\_bsd** command and the **write\_bsdl** command the naming style to use for the user-defined (nonstandard) test data registers inferred by these commands.

---

### TYPE

string

---

### DEFAULT

UTDR%d

---

### DESCRIPTION

This variable indicates to the **check\_bsd** command and the **write\_bsdl** command the naming style to use for the user-defined (nonstandard) test data registers inferred by these commands. The format for the specification is *string%d*; the specification must contain exactly one %d. Names resulting from the default specification (*UTDR%d*) are UTDR1, UTDR2, and so on.

---

### SEE ALSO

[check\\_bsd\(2\)](#)  
[write\\_bsdl\(2\)](#)

---

## test\_validate\_test\_model\_connectivity

Instructs the **dft\_drc** command to check the connectivity of test mode and constant pins of design instances that are represented by CTL models.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable, when set to **true**, instructs the **dft\_drc** command to check the connectivity of test mode and constant pins of design instances that are represented by CTL models.

When this feature is enabled, the **dft\_drc** command simulates the **test\_setup** procedure of the **all\_dft** mode of the CTL mode associated with the current design, and then inspects the logical value at the test mode and constant pins of all instantiated designs that are represented by CTL models. The feature then reports any mismatch on a pin in term of actual value (propagated to the pin) versus the expected value (the one that is defined in the **test\_setup** of the instantiated CTL model).

If any mismatch is found, all scan chains in the involved CTL model instance will not be considered in building scan chains in the current design.

---

### SEE ALSO

[dft\\_drc\(2\)](#)  
[use\\_test\\_model\(2\)](#)

---

## test\_wrapper\_chain\_naming\_style

Specifies the naming style used for mixed (input/output) core wrapper chains.

---

### TYPE

string

---

### DEFAULT

""

---

### DESCRIPTION

This variable determines the naming style to be used by the **insert\_dft** command for naming mixed (input/output) wrapper chains, which are created when the **-mix\_cells** option of the **set\_wrapper\_configuration** command is set to **true**. (This is the default for simple core wrapping, but not for maximized reuse core wrapping.)

This variable must contain one "%s" (percent s) character sequence. The '%s' is replaced with the ordinal chain number, beginning with 1.

The '%s' must be placed at the end of the string, so that the string represents a prefix. In addition, the string '<testmode>\_' is prefixed to the specified string.

---

### EXAMPLE

For example, to name the wrapper chains as IP\_WRAP\_1, IP\_WRAP\_2, and so on,

```
set_app_var test_wrapper_chain_naming_style {IP_WRAP_%s}
```

---

### SEE ALSO

[insert\\_dft\(2\)](#)

---

## test\_wrapper\_new\_wrp\_clock\_timing

Defines the test clock waveform for DFT-created dedicated wrapper clock signals.

---

### TYPE

list of positive nonzero integers

---

### DEFAULT

""

---

### DESCRIPTION

This variable specifies the rising-edge and falling-edge times of any dedicated wrapper clock signals created by DFT insertion.

The values are provided in list form, just as with the **-timing** option of the **set\_dft\_signal** command. For example,

```
prompt> set_app_var test_wrapper_new_wrp_clock_timing {50 70}
```

Note the following requirements:

- The rising and falling edge times must be less than the clock period.
- Both edges must be after the strobe time.

The default is an empty string (""), which results in a 10 percent duty cycle (with the rising edge and falling edge at 45 percent and 55 percent of the default clock period, respectively).

To explicitly define your own wrapper clock signal instead of using a DFT-created signal, use the **set\_dft\_signal** command to define a signal with the **wrp\_clock** type, as shown in the following example:

```
prompt> set_dft_signal -view existing_dft -type wrp_clock -port MY_wrp_clk -timing {50 70}
```

```
prompt> set_dft_signal -view spec -type wrp_clock -port MY_wrp_clk
```

---

### SEE ALSO

[test\\_default\\_period\(3\)](#)  
[test\\_default\\_strobe\(3\)](#)  
[test\\_default\\_strobe\\_width\(3\)](#)

---

## **test\_wrp\_new\_power\_domain\_aware\_dw\_insertion\_flow**

Specifies whether new upf aware wrapper cell insertion is enabled or disabled in dft insertion flow.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

This variable is used to turn on or off new upf aware wrapper cell insertion in dft insertion flow.

When set to **false** (the default), wrapper cell insertion is based on variaous other core wrapper variables.

When set to **true**, new upf aware wrapper cell insertion is enabled in dft insertion. In this flow, tool inserts dedicated wrapper cells based on guidance from UPF APIs. Tool will not insert a dedicated wrapper cell if the cell insertion introduces non fixable MV violations.

The variable doesn't have any effect when set\_wrapper\_configuration option -add\_wrapper\_cells\_to\_power\_domains is not enabled.

---

### **EXAMPLES**

To enable new upf aware wrapper cell insertion,

```
prompt> set_wrapper_configuration -class core_wrapper -add_wrapper_cells_to_power_domains enable -test_mode all_dft
prompt> set_app_var test_wrp_new_power_domain_aware_dw_insertion_flow true
```

---

### **SEE ALSO**

---

## text\_attributes

Contains attributes related to text.

---

## DESCRIPTION

Contains attributes related to text.

You can use **get\_attribute** to determine value of an attribute, and use **report\_attribute** to get a report of all attributes on specified object. Specified with **list\_attribute -class text -application**, the definition of attributes can be listed.

### Text Attributes

anchor

Specifies the anchor position for text from its **origin**.

The data type of **anchor** is string.

Its valid values are:

- **lb** - Left Bottom
- **cb** - Center Bottom
- **rb** - Right Bottom
- **lc** - Left Center
- **c** - Center Center
- **rc** - Right Center
- **lt** - Left Top
- **ct** - Center Top
- **rt** - Right Top

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

bbox

Specifies the bounding-box of a text. The **bbox** is represented by a **rectangle**.

The format of a *rectangle* specification is {{llx lly} {urx ury}}, which specifies the lower-left and upper-right corners of the rectangle.

The data type of **bbox** is string.

This attribute is read-only.

#### bbox\_ll

Specifies the lower-left corner of the bounding-box of a text.

The **bbox\_ll** is represented by a **point**. The format of a *point* specification is {x y}.

You can get the **attr\_name** of a text, by accessing the first element of its**bbox**.

The data type of **bbox\_ll** is string.

This attribute is read-only.

#### bbox\_llx

Specifies x coordinate of the lower-left corner of the bounding-box of a text.

The data type of **bbox\_llx** is double.

This attribute is read-only.

#### bbox\_lly

Specifies y coordinate of the lower-left corner of the bounding-box of a text.

The data type of **bbox\_lly** is double.

This attribute is read-only.

#### bbox\_ur

Specifies the upper-right corner of the bounding-box of a text.

The \fbbox\_ur is represented by a **point**. The format of a *point* specification is {x y}.

You can get the **bbox\_ur** of a text, by accessing the second element of its**bbox**.

The data type of **bbox\_ur** is string.

This attribute is read-only.

#### bbox\_urx

Specifies x coordinate of the upper-right corner of the bounding-box of a text.

The data type of **bbox\_urx** is double.

This attribute is read-only.

#### bbox\_ury

Specifies y coordinate of the upper-right corner of the bounding-box of a text.

The data type of **bbox\_ury** is double.

This attribute is read-only.

#### cell\_id

Specifies Milkyway design ID in which a text object is located.

The data type of **cell\_id** is integer.

This attribute is read-only.

#### height

Specifies height of a text object.

The data type of **height** is float.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### layer

Specifies layer name of a text object.

The data type of **layer** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### name

Specifies name of a text object.

The data type of **name** is string.

This attribute is read-only.

#### object\_class

Specifies object class name of a text, which is **text**.

The data type of **object\_class** is string.

This attribute is read-only.

#### object\_id

Specifies object ID in Milkyway design file.

The data type of **object\_id** is integer.

This attribute is read-only.

#### orientation

Specifies orientation of a text object.

The data type of **orientation** is string.

Its valid values are:

- **N**
- **E**
- **S**
- **W**
- **FN**
- **FE**
- **FS**
- **FW**

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### origin

Specifies origin of a text object.

The **origin** is represented by a **point**. The format of a *point* specification is {x y}.

The data type of **origin** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### text

Specifies the text string to create and display.

The data type of **text** is string.

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

---

## SEE ALSO

[get\\_attribute\(2\)](#)  
[list\\_attributes\(2\)](#)  
[report\\_attribute\(2\)](#)  
[set\\_attribute\(2\)](#)

---

## text\_editor\_command

Specifies the command that executes when the **Edit/File** menu is selected in the Design Analyzer text window.

---

### TYPE

string

---

### DEFAULT

xterm -fn 8x13 -e vi %s & in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Specifies the command that executes when the **Edit/File** menu is selected in the Design Analyzer text window.

To determine the current value of this variable, type **printvar text\_editor\_command**. For a list of all **view** variables and their current values, use the **print\_variable\_group view** command.

---

### SEE ALSO

---

## text\_print\_command

Specifies the command that executes when the **File/Print** menu is selected in the Design Analyzer text window.

---

### TYPE

string

---

### DEFAULT

lpr -Plw

---

### DESCRIPTION

Specifies the command that executes when the **File/Print** menu is selected in the Design Analyzer text window.

To determine the current value of this variable, use **printvar text\_print\_command**. For a list of all **view** variables and their current values, use the **print\_variable\_group view** command.

---

### SEE ALSO

---

## **tieoff\_hierarchy\_opt**

Controls whether to allow tie-off optimization down to the lowest hierarchy without port punching during fixing DRC violations of constant nets that cross multiple hierarchies.

---

### **TYPE**

Boolean

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

false in DC Explorer

---

### **DESCRIPTION**

In RMgen reference methodology, tie-off optimization is called at the end of the **place\_opt** or **psynopt** command to fix the DRC violations of constant nets that have maximum capacitance or maximum fanout.

Setting this variable to true allows tie-off optimization down to the lowest hierarchy without port punching to fix constant nets that cross multiple hierarchies.

For example, a violating constant net that drives an input port followed by multiple loads, the tool fixes the violation by inserting an optimized number of tie cells down to the lowest hierarchy to drive the loads and removing the original driving cell. You can choose to keep the original driving cell by setting the **tieoff\_hierarchy\_opt\_keep\_driver** variable.

This variable does not support multivoltage or multicorner-multimode designs. It also skips the constant nets that have the **dont\_touch** attribute.

For multicorner-multimode designs, this variable uses information from the current scenario only.

---

### **SEE ALSO**

[tieoff\\_hierarchy\\_opt\\_keep\\_driver\(3\)](#)  
[set\\_fix\\_multiple\\_port\\_nets\(2\)](#)

---

## **tieoff\_hierarchy\_opt\_keep\_driver**

Controls whether to keep the original driving cell when propagating tie-off optimization down to the lowest hierarchy.

---

### **TYPE**

Boolean

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

false in DC Explorer

---

### **DESCRIPTION**

When the **tieoff\_hierarchy\_opt** variable is set to true, tie-off optimization is allowed to propagate to the lowest hierarchy to fix constant nets that cross multiple hierarchies. By default, the original driving cell of the constant net is removed.

This variable is used to control whether to remove the original driving cell of the constant net. When you set it to true, the original driving cell is not removed.

This variable does not support multivoltage or multicorner-multimode designs. For multicorner-multimode designs, this variable uses the information from the current scenario only.

---

### **SEE ALSO**

[tieoff\\_hierarchy\\_opt\(3\)](#)

---

## timing\_check\_defaults

Defines the default check list in the **check\_timing** command.

---

### TYPE

string

---

### DEFAULT

generated\_clock loops no\_input\_delay unconstrained\_endpoints pulse\_clock\_cell\_type no\_driving\_cell partial\_input\_delay

---

### DESCRIPTION

This variable defines the default checks to be performed when the **check\_timing** command is run without any options. The default check list defined by this variable can be overridden by redefining the check list. The check list modified using the **-override\_defaults**, **-include**, or **-exclude** option of **check\_timing** is valid in only one command.

Note that this variable will not check if the value is correct or not; the check is done by the **check\_timing** command. Each element in the check list can be one of the following strings:

loops  
no\_input\_delay  
unconstrained\_endpoints  
generated\_clock  
pulse\_clock\_cell\_type  
clock\_crossing  
data\_check\_multiple\_clock,  
data\_check\_no\_clock  
multiple\_clock  
generic  
gated\_clock  
ideal\_timing  
retain  
clock\_no\_period

---

### EXAMPLE

The following example defines the value of the **timing\_check\_defaults** variable:

```
prompt> set timing_check_defaults {clock_crossing loops}
```

## SEE ALSO

`check_timing(2)`

---

## timing\_clock\_gating\_propagate\_enable

Allows the gating-enable signal delay to propagate through the gating cell.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable, when set to **true**, allows the delay and slew from the data line of the gating check to propagate. When set to **false**, the tool blocks the delay and slew from the data line of the gating check from propagating; only the delay and slew from the clock line is propagated.

If the output goes to a clock pin of a latch, setting this variable to **false** produces the most desirable behavior.

If the output goes to a data pin, setting this variable to **true** produces the most desirable behavior.

---

### SEE ALSO

`set_clock_gating_style(2)`

---

## timing\_clock\_reconvergence\_pessimism

Selects signal transition sense matching for computing clock reconvergence pessimism removal.

---

### TYPE

string

---

### DEFAULT

normal

---

### DESCRIPTION

This variable determines how the value of the clock reconvergence pessimism removal (CRPR) is computed with respect to transition sense. Allowed values are **normal** (the default) and **same\_transition**.

When set to **normal**, the CRPR value is computed even if the clock transitions to the source and destination latches are in different directions on the common clock path. It is computed separately for rise and fall transitions and the value with the smaller absolute value is used.

When set to **same\_transition**, the CRPR value is computed only when the clock transition to the source and destination latches have a common path and the transition is in the same direction on each pin of the common path. Thus, if the source and destination latches are triggered by different edge types, CRPR is computed at the last common pin at which the launch and capture edges match.

If the variable is set to **same\_transition**, the CRPR for all minimum pulse width checks will be zero, as they are calculated using different (rise and fall) clock edges.

---

### SEE ALSO

report\_timing(2)  
timing\_crpr\_remove\_clock\_to\_data\_crp(3)  
timing\_crpr\_threshold\_ps(3)  
timing\_remove\_clock\_reconvergence\_pessimism(3)

---

## timing\_consider\_internal\_startpoints

Determines whether to report timing paths that start from internal startpoints.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When this variable is set to **true** (the default), timing paths that start from internal startpoints are reported by the **report\_timing** command. When this variable is set to **false**, timing analysis skips the internal startpoints, so these paths are not reported.

Internal startpoints can result from unresolved references, cells with disabled timing arcs, or input ports with only the rising-edge or only the falling-edge input delay specified with the **set\_input\_delay** command.

---

### SEE ALSO

**report\_timing(2)**  
**get\_timing\_paths(2)**  
**set\_input\_delay(2)**

---

## **timing\_crpr\_remove\_clock\_to\_data\_crp**

Allows the removal of clock reconvergence pessimism (CRP) from paths that fan out directly from the clock source to the data pins of sequential devices.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

When this variable is set to **true**, clock reconvergence pessimism (CRP) will be removed for all paths that fan out directly from the clock source pins to the data pins of sequential devices. All sequential devices that reside in the fanout of clock source pins must be handled separately in the subsequent timing update. This might cause a severe performance degradation to the timing update.

---

### **SEE ALSO**

[timing\\_remove\\_clock\\_reconvergence\\_pessimism\(3\)](#)

---

## timing\_crpr\_remove\_muxed\_clock\_crp

Allows clock reconvergence pessimism removal (CRPR) to consider common path reconvergence between related clocks.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable controls the clock reconvergence pessimism removal (CRPR) in cases where two related clocks reconverge in the logic. Two clocks are related if one is a generated clock and the other is its parent, or both are generated clocks of the same parent clock. Although this variable name refers specifically to multiplexers, the variable applies to any situation where two related clocks reconverge within combinational logic.

By default, the separate clock paths up to the multiplexer are treated as reconvergent, and the CRP includes the reconvergence point as well as any downstream common logic. When this variable is set to **false**, the common pin is the last point where the clocks diverged to become related clocks.

If the design contains related clocks that switch dynamically, set this variable to **false** so the CRP is not removed. Related clocks switch dynamically when a timing path launches from one related clock and the clock steering logic switches dynamically so the path captures on the other related clock.

The default value is **true**, which removes the additional CRP.

---

### SEE ALSO

[timing\\_remove\\_clock\\_reconvergence\\_pessimism\(3\)](#)

---

## timing\_crpr\_threshold\_ps

Specifies the amount of pessimism that clock reconvergence pessimism removal (CRPR) is allowed to leave in the report.

---

### TYPE

float

---

### DEFAULT

5

---

### DESCRIPTION

This variable specifies the amount of pessimism that clock reconvergence pessimism removal (CRPR) is allowed to leave in the report. The unit is in pico seconds (ps), regardless of the units of the main library.

The threshold is per reported slack: setting this variable to the value of  $TH1$  means that reported slack is no worse than  $S - TH1$ , where  $S$  is the reported slack when the **timing\_crpr\_threshold\_ps** variable is set close to zero (the minimum allowed value is **2e-5** pico seconds).

The variable has no effect if CRPR is not active; the **timing\_remove\_clock\_reconvergence\_pessimism** variable is set to **false**). The larger the value of **timing\_crpr\_threshold\_ps**, the faster the runtime when CRPR is active. The recommended setting is about half stage (gate plus net) delay of a typical gate in the clock network. It provides a reasonable trade-off between accuracy and runtime in most cases.

You might want to use different settings throughout the design cycle: larger during the design phase, smaller for sign-off. You might want to experiment and set a different value when moving to a different technology.

---

### SEE ALSO

[timing\\_remove\\_clock\\_reconvergence\\_pessimism\(3\)](#)

---

## timing\_disable\_cond\_default\_arcs

Disables the default, nonconditional timing arc between pins that do have conditional arcs.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable disables nonconditional timing arcs between any pair of pins that have at least one conditional arc. By default, these nonconditional timing arcs are not disabled. This variable is primarily intended to deal with the situation between two pins that have conditional arcs, where there is always a default timing arc with no condition.

Set this variable to **true** when the specified conditions cover all possible state-dependent delays, so that the default arc is useless. For example, consider a 2-input XOR gate with inputs as A and B and with output as Z. If the delays between A and Z are specified with 2 arcs with respective conditions 'B' and 'B~', the default arc between A and Z is useless and should be disabled.

---

### SEE ALSO

`report_disable_timing(2)`

---

## timing\_disable\_recovery\_removal\_checks

Controls whether the tool accepts recovery and removal arcs specified in the technology library.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable, when set to **false**, enables the acceptance of recovery and removal arcs specified in the technology library. Recovery or removal timing arcs impose constraints on asynchronous pins of sequential cells. Typically, recovery time specifies the time the inactive edge of the asynchronous signal has to arrive before the closing edge of the clock. Removal time specifies the length of time the active phase of the asynchronous signal must be held after the closing edge of clock.

To enable the **compile**, **report\_timing**, and **report\_constraint** commands to accept recovery or removal arcs specified in the library, set **timing\_disable\_recovery\_removal\_checks** to **false**.

Note that independent of the value of this variable, the **write\_timing** and **report\_delay\_calculation** commands always accept and report recovery or removal timing information.

This variable is the logical opposite of the variable **enable\_recovery\_removal\_arcs**. If you set either one of these variables to **false**, the tool automatically sets the other variable to **true**, and vice versa.

---

### SEE ALSO

**compile**(2)  
**enable\_recovery\_removal\_arcs**(3)

---

## timing\_dont\_traverse\_pg\_net

Normally, timing analysis will be processed only upon signal network and ignore Power/Ground pins. However, command **derive\_pg\_connection** might bring some netlist changes and make PG nets being connected to normal signal network.

In that case, timing analysis will pay huge runtime for traverse in PG networks and then bring some runtime issues. Also, case-analysis needs to honor the logic-constants bounding to PG Power/Ground.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable is used to configures whether timing analysis should touch PG networks or not. By default, timing analysis will touch PG networks and this could bring some runtime issues.

When this variable is set to **true**, timing analysis will skip traverse in PG networks and then save runtime. Meanwhile, case-analysis will honor the logic-constants pins/ports which have been bounded to Power/Ground separately.

When this variable is set to **false**, timing analysis will do traverse in PG networks, along with normal signal networks. The logic-constants pins/ports which have been bounded to Power/Ground will be ignored by case-analysis as well.

The default variable value is **false**.

---

### SEE ALSO

`set_case_analysis(2)`  
`report_timing(2)`

---

## timing\_early\_launch\_at\_borrowing\_latches

Removes clock latency pessimism from the launch times for paths that begin at the data pin of a transparent latch.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When a latch is in its transparent phase, data arriving at the D-pin passes through the element as though it were combinational. To model this situation, whenever the IC Compiler tool determines that time borrowing is occurring at such a D-pin, it creates a timing path starting at the D-pin.

Sometimes there is a difference between the launch and capture latch latencies, due either to reconvergent paths in the clock network or different min and max delays of cells in the clock network. For setup paths, the tool uses the late value to launch and the early value to capture. This achieves the tightest constraint and prevents optimism. However, for paths starting from latch D-pins, this analysis is pessimistic because the data simply passes through and thus does not even "see" the clock edge at the latch.

When this timing variable is set to **true** (the default), such pessimism is eliminated by using the early latch latency to launch the path. Note that only paths that originate from a latch D-pin are affected. When the variable is set to **false**, late clock latency is used to launch all setup paths in the design.

When the **timing\_early\_launch\_at\_borrowing\_latches** and **timing\_remove\_clock\_reconvergence\_pessimism** variables are both set to true, it is not possible to apply both pessimism removal techniques on the same timing path. Therefore, the tool applies early launch pessimism removal to paths that start from a transparent latch D-pin and applies CRPR to the remaining paths.

For a design with long clock paths, it might be preferable to set the **timing\_early\_launch\_at\_borrowing\_latches** variable to **false**. Doing so allows CRPR to be applied to all paths, including those that start from a transparent latch D-pin. When clock paths are long, CRPR can be the more powerful pessimism reduction technique.

On the other hand, for a design with clock paths having long common segments, or where critical paths traverse several latches, leaving the **timing\_early\_launch\_at\_borrowing\_latches** variable set to **true** might result in more pessimism removal overall, even though paths that start from a transparent D-pin do not get any CRPR credit.

---

### SEE ALSO

[report\\_timing\(2\)](#)  
[timing\\_remove\\_clock\\_reconvergence\\_pessimism\(3\)](#)



---

## **timing\_edge\_specific\_source\_latency**

Controls whether or not the generated clock source latency computation considers edge relationship.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

When this variable is set to **true**, only the paths with the same sense relationship derived from generated clock definition are considered.

By default, all paths that fanout to a generated clock source pin are considered and the worst path is selected for generated clock source latency computation.

---

### **SEE ALSO**

[create\\_generated\\_clock\(2\)](#)

---

## timing\_enable\_constraint\_variation

Enables constraint variation in parametric on-chip variation (POCV) analysis.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

If you set this variable to **true** and set the **timing\_pocvm\_enable\_analysis** variable to **true**, constraint variation is considered in parametric on-chip variation (POCV) analysis.

---

### SEE ALSO

`get_timing_paths(2)`  
`report_timing(2)`  
`set_operating_conditions(2)`  
`timing_pocvm_enable_analysis(3)`

---

## timing\_enable\_multiple\_clocks\_per\_reg

Enables analysis of multiple clocks that reach a single register.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable enables analysis of multiple clocks that reach a register clock pin. When set to **true** (the default), all clocks reaching the register are analyzed simultaneously, including interactions between different clocks, such as data launch by one clock and data capture by another. If there are four or more clocks per register and the design contains level-sensitive registers, a high impact on runtime might occur.

If your design has a large number of different interacting clocks, you can set this variable to **false** to eliminate consideration of all clock interactions and get results more quickly. However, to get fully accurate results, leave the variable set to **true** and use the **set\_false\_path** command to explicitly specify the actual false interactions between mutually exclusive clocks.

---

### SEE ALSO

[check\\_timing\(2\)](#)  
[create\\_clock\(2\)](#)  
[create\\_generated\\_clock\(2\)](#)  
[set\\_false\\_path\(2\)](#)

---

## timing\_enable\_non\_sequential\_checks

Enables or disables library nonsequential checks in the design.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable enables or disables analysis of library nonsequential checks in the design. The nonsequential arcs defined in the library will not be used for constraint checking unless this variable is set to **true**. This variable does not affect the data checks defined by the **set\_data\_check** command.

Enabling the nonsequential checks might cause delays if the signals reaching the related pin and the constrained pin do not belong to the same clock domain. Use the **set\_multicycle\_path** command to put appropriate constraints on such paths.

---

### SEE ALSO

`printvar(2)`  
`set_data_check(2)`  
`set_multicycle_path(2)`

---

## timing\_enable\_normalized\_slack

Enables normalized slack analysis during timing updates.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When set to **true**, this variable enables normalized slack analysis during timing updates. When set to **false** (the default), this variable disables normalized slack analysis and reporting.

Normalized slack analysis is an optional analysis method that calculates normalized slack for each timing path:

$\text{normalized\_slack} = \text{path\_slack} / \text{idealized\_allowed\_propagation\_delay\_for\_path}$

The tool computes the allowed propagation delay for the path using ideal clock edges; it ignores setup time, uncertainty, and clock latency. The allowed propagation delay can be a half-cycle, a full cycle, or multiple cycles. It can be more complicated to compute when the launch and capture clocks are different.

Normalized slack analysis can be used to determine the paths that limit the clock frequency. A normalized slack report prioritizes violating paths that are allowed few clock cycles. Fixing these paths first results in the most improvement in the clock period.

If normalized slack analysis is enabled during update timing, you can gather and report paths according to normalized slack by using the commands **report\_timing -normalized\_slack** and **get\_timing\_paths -normalized\_slack**.

---

### SEE ALSO

`printvar(2)`  
`report_timing(2)`  
`timing_max_normalization_cycles(3)`

---

## timing\_enable\_slack\_distribution

Determines whether to distribute slack evenly along time-borrowing paths.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable determines whether to distribute slack evenly along a time-borrowing path containing transparent latches.

By default, this variable is set to **false**, resulting in "greedy" time-borrowing behavior, in which latch time borrowing matches the D pin arrival time, producing zero slack at borrowing latches.

When this variable is set to **true**, during optimization, the tool sets the amount of time borrowing at transparent latches in a manner that distributes negative or positive slack evenly among the latches of a multistage latch path. The runtime and memory usage might be longer using this setting.

Slack distribution spreads all nonzero slack, negative or positive, across all multistage borrowing latch paths. By spreading positive path slacks, hold fixing and area QoR might be improved. This setting affects the behavior of the **compile\_ultra** command in the Synopsys Physical Guidance (SPG) mode.

Slack distribution, when enabled, overrides automatic time borrowing (controlled by the **disable\_auto\_time\_borrow** variable). Automatic time borrowing distributes only the worst negative slack across certain multistage latch paths.

---

### SEE ALSO

[set\\_max\\_time\\_borrow\(2\)](#)  
[disable\\_auto\\_time\\_borrow\(3\)](#)

---

## timing\_enable\_through\_paths

Enables or disables advanced analysis and reporting through transparent latches.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When set to *true*, this variable enables advanced analysis through transparent latches during timing updates and reporting. When set to *false* (the default), this variable disables advanced analysis and reporting through transparent latches.

By default timer analyzes and reports paths through transparent latches as a series of path segments between latches. These segments can be reported together using the **report\_timing** option **-trace\_latch\_borrow**. Max pin slacks (**max\_rise\_slack**, **max\_fall\_slack**) for a pin in the design can be affected by borrowing latches in the fanin of the pin, but are not affected by timing calculations in parts of the design past the first level of latches in the fanout of the pin.

With the advanced analysis through transparent latches, paths through latches can be reported as a single timing path. Pin slacks can be affected by timing calculations past the first level of latches in the fanout. In addition, specific paths through latches can be requested using the **-from**, **-through**, and **-to** options of **report\_timing**, where the options specify objects that are separated by one or more transparent latches.

The advanced analysis is limited when there are latch loops in the design. The tool chooses specific latch data pins in the loops to act as loop breaker latches. For these latch data pins, the behavior is the same as if the variable **timing\_enable\_through\_paths** was set to **false**. Reporting through these special latch data pins is not supported. The tool automatically selects which latch data pins to act as loop breaker latches. The user can guide the selection using the **set\_latch\_loop\_breaker** command. Because of the runtime associated with the advanced analysis, by default the tool also selects some latch data pins outside loops to have the same behavior as if **timing\_enable\_through\_paths** was **false**. The variable **timing\_through\_path\_max\_segments** can be used to control the selection of these pins.

To determine the current setting, use the following command:

```
printvar timing_enable_through_paths
```

---

### SEE ALSO

`printvar(2)`  
`report_timing(2)`

timing\_through\_path\_max\_segments(3)

---

## **timing\_gclock\_source\_network\_num\_master\_registers**

Specifies the maximum allowed number of register clock pins clocked by the master clock in generated clock source latency paths.

---

### **TYPE**

integer

---

### **DEFAULT**

10000000

---

### **DESCRIPTION**

This variable controls the maximum allowed number of register clock pins clocked by the master clock in generated clock source latency paths. The variable does not limit the number of registers traversed in a single path that do not have a clock assigned or are clocked by another generated clock that has the same primary master as the generated clock in question.

Register clock pins or transparent-D pins of registers clocked by unrelated clocks are not traversed in determining generated clock source latency paths. An unrelated clock is any clock with a primary master clock that differs from the generated clock whose source latency paths are being computed.

---

## **timing\_ignore\_paths\_within\_block\_abstraction**

Causes timing paths entirely within a block abstraction to be ignored.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

The process of creating abstract blocks removes as much logic as possible from the internal portions of the block, while keeping cells and nets that are necessary to preserve paths that connect to the outside of the block. However, in a block abstraction, there can be residual paths entirely within the boundary logic that do not traverse outside the block.

Setting this variable to **true** causes the timing on paths that remain entirely within the abstracted block to be ignored. The tool behaves as if there is an implied false path constraint on such paths, both for reporting and for optimization. A path that starts and ends inside an abstracted block, but exits from and returns to the block somewhere in the middle, is not affected by this variable.

When this variable is **true**, it allows transparent interface optimization to focus on paths that traverse outside the abstracted blocks.

---

### **SEE ALSO**

[create\\_block\\_abstraction\(2\)](#)

---

## timing\_input\_port\_default\_clock

Determines whether a default clock is assumed at input ports for which a clock-specific input external delay is not defined.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable affects the behavior of the synthesis timing engine when timing a path from an input port with no clocked input external delay. When set to **true**, all such input ports are given one imaginary clock so that the inputs are constrained. This also causes the clocks along the paths driven by these input ports to become related. By default, no such imaginary clock is assumed.

---

### SEE ALSO

`report_timing(2)`

---

## timing\_library\_derate\_is\_scenario\_specific

This variable determines whether the **set\_timing\_derate** and the **read\_aocvm** commands apply to the current scenario or all scenarios for library cell objects.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

By default, the **set\_timing\_derate** command and the **read\_aocvm** command, when applied to a library cell object, affect the timing of that cell in all scenarios, not just the scenario in which the command is executed. If you set this variable to true, the **set\_timing\_derate** and the **read\_aocvm** commands affect only the scenario in which the commands are executed. The variable is set to false by default.

The variable setting has no effect on the **set\_timing\_derate** and **read\_aocvm** commands applied to instances, in which case the **set\_timing\_derate** setting and the AOCVM tables are always scenario-specific.

Changing this variable at any time removes all timing derate settings and AOCVM tables already applied to library cell objects. To save runtime, set this variable early in the session, before you start using the **set\_timing\_derate** and **read\_aocvm** commands.

This variable is not persistent and is not saved in the Milkyway design database.

#### Multicorner-Multimode Support

This variable determines whether the **set\_timing\_derate** command and the **read\_aocvm** command apply to the current scenario or all scenarios for settings applied to library cell objects.

---

### EXAMPLE

The following example shows the default behavior. Here, for the **set\_timing\_derate** command, the previous setting "1.1" is overwritten by the later setting "1.2," even though they are set in two different scenarios. For the **read\_aocvm** command, AOCVM tables for library cell objects are applied in Scenario1, even though they are loaded in Scenario2.

```
prompt> set_app_var timing_library_derate_is_scenario_specific false  
prompt> current_scenario Scenario1  
prompt> set_timing_derate -max -late 1.1 [get_lib_cells lib_pvt5/AN2]
```

```
prompt> current_scenario Scenario2
prompt> set_timing_derate -max -late 1.2 [get_lib_cells lib_pvt5/AN2]
prompt> read_aocvm lib_cell_table.txt
```

```
prompt> current_scenario Scenario1
prompt> report_aocvm
```

\*\*\*\*\*

Report : aocvm

Design : top

Scenario(s): Scenario1

\*\*\*\*\*

|            | Fully annotated | Partially annotated | Not annotated |   |
|------------|-----------------|---------------------|---------------|---|
| Total      |                 |                     |               |   |
| Leaf cells | 6               | 6                   | 0             | 0 |
| Nets       | 7               | 0                   | 0             | 7 |
|            | 13              | 6                   | 0             | 7 |

1

```
prompt> report_timing_derate -scenario [list Scenario1 Scenario2]
```

\*\*\*\*\*

Report : timing derate

Design : top

Scenario(s): Scenario1 Scenario2

...

\*\*\*\*\*

| Design | Derate | value | Scenario |
|--------|--------|-------|----------|
|--------|--------|-------|----------|

| Cell | Derate | value | Scenario |
|------|--------|-------|----------|
|------|--------|-------|----------|

| Lib Cell | Derate | value |
|----------|--------|-------|
|----------|--------|-------|

|                           |      |  |
|---------------------------|------|--|
| lib_pvt5/AN2              |      |  |
| clk_cell_delay_min_early  | -    |  |
| clk_cell_delay_min_late   | -    |  |
| clk_cell_delay_max_early  | -    |  |
| clk_cell_delay_max_late   | 1.20 |  |
| clk_cell_check_min_early  | -    |  |
| clk_cell_check_min_late   | -    |  |
| clk_cell_check_max_early  | -    |  |
| clk_cell_check_max_late   | -    |  |
| data_cell_delay_min_early | -    |  |
| data_cell_delay_min_late  | -    |  |
| data_cell_delay_max_early | -    |  |
| data_cell_delay_max_late  | 1.20 |  |
| data_cell_check_min_early | -    |  |
| data_cell_check_min_late  | -    |  |
| data_cell_check_max_early | -    |  |
| data_cell_check_max_late  | -    |  |

However, in the non-default state, with the variable set to true, each derate setting or the AOCVM table is specific to the scenario that

is current when the constraint is applied:

```
prompt> set_app_var timing_library_derate_is_scenario_specific true
prompt> current_scenario Scenario1
prompt> set_timing_derate -max -late 1.1 [get_lib_cells lib_pvt5/AN2]
```

```
prompt> current_scenario Scenario2
prompt> set_timing_derate -max -late 1.2 [get_lib_cells lib_pvt5/AN2]
prompt> read_aocvm lib_cell_table.txt
```

```
prompt> current_scenario Scenario1
prompt> report_aocvm
```

\*\*\*\*\*

Report : aocvm

Design : top

Scenario(s): Scenario1

\*\*\*\*\*

No AOCVM derates.

1

```
prompt> report_timing_derate -scenario [list Scenario1 Scenario2]
```

\*\*\*\*\*

Report : timing derate

Design : top

Scenario(s): Scenario1 Scenario2

...

\*\*\*\*\*

| Design | Derate | value | Scenario |
|--------|--------|-------|----------|
|--------|--------|-------|----------|

| Cell | Derate | value | Scenario |
|------|--------|-------|----------|
|------|--------|-------|----------|

| Lib | Cell | Derate | value | Scenario |
|-----|------|--------|-------|----------|
|-----|------|--------|-------|----------|

|                           |      |           |  |  |
|---------------------------|------|-----------|--|--|
| lib_pvt5/AN2              |      |           |  |  |
| clk_cell_delay_min_early  | -    | Scenario1 |  |  |
| clk_cell_delay_min_late   | -    | Scenario1 |  |  |
| clk_cell_delay_max_early  | -    | Scenario1 |  |  |
| clk_cell_delay_max_late   | 1.10 | Scenario1 |  |  |
| clk_cell_check_min_early  | -    | Scenario1 |  |  |
| clk_cell_check_min_late   | -    | Scenario1 |  |  |
| clk_cell_check_max_early  | -    | Scenario1 |  |  |
| clk_cell_check_max_late   | -    | Scenario1 |  |  |
| data_cell_delay_min_early | -    | Scenario1 |  |  |
| data_cell_delay_min_late  | -    | Scenario1 |  |  |
| data_cell_delay_max_early | -    | Scenario1 |  |  |
| data_cell_delay_max_late  | 1.10 | Scenario1 |  |  |
| data_cell_check_min_early | -    | Scenario1 |  |  |
| data_cell_check_min_late  | -    | Scenario1 |  |  |
| data_cell_check_max_early | -    | Scenario1 |  |  |
| data_cell_check_max_late  | -    | Scenario1 |  |  |
| lib_pvt5/AN2              |      |           |  |  |
| clk_cell_delay_min_early  | -    | Scenario2 |  |  |
| clk_cell_delay_min_late   | -    | Scenario2 |  |  |
| clk_cell_delay_max_early  | -    | Scenario2 |  |  |
| clk_cell_delay_max_late   | 1.20 | Scenario2 |  |  |

|                           |      |           |
|---------------------------|------|-----------|
| clk_cell_check_min_early  | -    | Scenario2 |
| clk_cell_check_min_late   | -    | Scenario2 |
| clk_cell_check_max_early  | -    | Scenario2 |
| clk_cell_check_max_late   | -    | Scenario2 |
| data_cell_delay_min_early | -    | Scenario2 |
| data_cell_delay_min_late  | -    | Scenario2 |
| data_cell_delay_max_early | -    | Scenario2 |
| data_cell_delay_max_late  | 1.20 | Scenario2 |
| data_cell_check_min_early | -    | Scenario2 |
| data_cell_check_min_late  | -    | Scenario2 |
| data_cell_check_max_early | -    | Scenario2 |
| data_cell_check_max_late  | -    | Scenario2 |

---

## SEE ALSO

`set_timing_derate(2)`  
`report_timing_derate(2)`  
`set_min_library(2)`

---

## **timing\_library\_max\_cap\_from\_lookup\_table**

Determines whether the tool should use the operating frequency to determine the maximum pin load.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

This variable specifies whether the tool should use the operating frequency to determine the maximum pin load. The tool uses a single value for the maximum pin load by default.

When this variable is set to true, the tool uses the operating frequency to determine the maximum pin load.

To see the current value of this variable, use the **printvar timing\_library\_max\_cap\_from\_lookup\_table** command.

---

### **SEE ALSO**

`set_max_capacitance(2)`  
`report_constraint(2)`

---

## timing\_max\_normalization\_cycles

Sets an upper limit for the denominator when calculating normalized slack.

---

### TYPE

integer

---

### DEFAULT

4

---

### DESCRIPTION

Normalized slack analysis is an optional analysis method that calculates normalized slack for each timing path:

$\text{normalized\_slack} = \text{path\_slack} / \text{idealized\_allowed\_propagation\_delay\_for\_path}$

The tool computes the allowed propagation delay for the path using ideal clock edges; it ignores setup time, uncertainty, and clock latency. The allowed propagation delay can be a half-cycle, a full cycle, or multiple cycles. It can be more complicated to compute when the launch and capture clocks are different.

The **timing\_max\_normalization\_cycles** variable limits the runtime and memory used in this analysis by placing an upper limit on the denominator of the fraction used to calculate the normalized slack. The maximum allowed value of this denominator is this variable setting multiplied by the period of the launch clock for the path.

Setting a larger value supports a larger range of allowed propagation delays, possibly at the cost of more runtime and memory usage.

---

### SEE ALSO

`printvar(2)`  
`report_timing(2)`  
`timing_enable_normalized_slack(3)`

---

## timing\_max\_parallel\_computations

Sets the maximum degree of parallelism used for parallel timing updates.

---

### TYPE

integer

---

### DEFAULT

0

---

### GROUP

timing

---

### DESCRIPTION

This application variable specifies the degree of parallelism used for parallel timing updates. Increasing the parallelism results in reduced runtime at the expense of memory.

When this variable has a value of **0** (the default), the number of cores used for timing update is specified by the value of the **-max\_cores** option of the **set\_host\_options** command.

When this variable has a value of **1**, parallel timing update is disabled.

When this variable has a value that is larger than 1 but smaller than the value of the **set\_host\_options -max\_cores** option, the number of cores being used must not exceed this limit and a smaller memory footprint is achieved.

When this variable has a value that is larger than the value of the **set\_host\_options -max\_cores** option, the number of cores being used must not exceed the limit set with the **set\_host\_options** command and better runtime speedup can be achieved.

The actual degree of parallelism (number of processes/threads) must not exceed the value specified in this variable, but will not always be exactly the same. The tool derives the number internally to achieve the best performance.

---

### SEE ALSO

[set\\_host\\_options\(2\)](#)



---

## timing\_ocvm\_precedence\_compatibility

Specifies whether to fall back to conventional on-chip variation (OCV) derating while advanced on-chip variation (AOCV) or parametric on-chip variation (POCV) is enabled.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When this variable is set to false (the default), for each object, both OCV and AOCV or POCV derate settings are considered, and the more specific setting is used. This is the default order of usage, from highest to lowest priority:

- i. OCV leaf cell derate setting
- ii. AOCV or POCV lib-cell derate setting
- iii. OCV lib-cell derate setting
- iv. AOCV or POCV hier-cell derate setting
- v. OCV hier-cell derate setting
- vi. AOCV or POCV design derate setting
- vii. OCV design derate

When this variable is set to true, the OCV derate settings are always ignored for AOCV or POCV analysis, resulting in the following order of usage, from highest to lowest priority:

- i. AOCV or POCV lib-cell derate setting
- ii. AOCV or POCV hier-cell derate setting
- iii. AOCV or POCV design derate setting

This variable has an effect only when the **timing\_pocvm\_enable\_analysis** variable is set to true.

---

### SEE ALSO

`read_ocvm(2)`  
`remove_ocvm(2)`

```
report_ocvm(2)
timing_pocvm_enable_analysis(3)
```

---

## **timing\_pocvm\_corner\_sigma**

Specifies the standard deviation used to calculate worst-case values from statistical parameters during parametric on-chip variation analysis.

---

### **TYPE**

float

---

### **DEFAULT**

3

---

### **DESCRIPTION**

Parametric on-chip variation (POCV) analysis internally computes arrival times, required times, and slack values based on statistical distributions. When performing comparisons between these statistical quantities, the tool needs to know what values in the distribution are considered worst-case.

The default behavior is to choose values at 3.0 standard deviations away from the mean value. In other words, for an arrival time distribution, the worst-case early arrival is 3.0 standard deviations below the mean, and the worst-case late arrival is 3.0 standard deviations above the mean.

You can use this variable set a different number of standard deviations away from the mean to determine the worst-case values for timing reports. Use a lower value such as 2.5 for less worst-case variation and more relaxed timing constraints. Conversely, use a higher value such as 3.5 for more worst-case variation and more restrictive timing constraints.

---

### **SEE ALSO**

[timing\\_pocvm\\_enable\\_analysis\(3\)](#)

---

## timing\_pocvm\_enable\_analysis

Enables parametric on-chip variation (POCV) timing analysis.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When this variable is set to **true**, the tool performs parametric on-chip variation (POCV) timing analysis. In this analysis mode, the tool internally computes arrival times, required times, and slack values as statistical distributions rather than fixed minimum and maximum values.

To determine the cumulative delay of a path, the POCV mode statistically combines the delay distribution of each stage. This is more accurate than simply adding the worst-case value from each stage. The resulting delay and slack values are more realistic and less pessimistic than values calculated by ordinary addition.

Before you can use POCV analysis, you must specify the statistical delay behavior of the logic gates used in the design and read that information into the tool using the **read\_ocvm** command.

Note that POCV timing analysis uses more runtime than conventional timing analysis.

---

### SEE ALSO

[read\\_ocvm\(2\)](#)  
[report\\_timing\(2\)](#)  
[timing\\_pocvm\\_corner\\_sigma\(3\)](#)

---

## timing\_remove\_clock\_reconvergence\_pessimism

Enables or disables clock reconvergence pessimism removal.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable, when set to **true**, instructs the synthesis timing engine to remove clock reconvergence pessimism from slack calculation and minimum pulse width checks.

Clock reconvergence pessimism (CRP) is a difference in delay along the common part of the launching and capturing clock paths. The most common causes of CRP are reconvergent paths in the clock network and different minimum and maximum delay of cells in the clock network.

Any effective change in the value of the **timing\_remove\_clock\_reconvergence\_pessimism** variable causes a full **update\_timing**. You cannot perform one **report\_timing** operation that considers CRP and one that does not without a full **update\_timing** in between.

To run optimization with CRP removal, the clock network must be set as `dont_touch`:

```
prompt> set_app_var timing_remove_clock_reconvergence_pessimism true
true
prompt> report_timing
```

---

### SEE ALSO

[report\\_timing\(2\)](#)  
[timing\\_crpr\\_threshold\\_ps\(3\)](#)  
[timing\\_clock\\_reconvergence\\_pessimism\(3\)](#)

---

## timing\_report\_attributes

Specifies the list of attributes reported by the **report\_timing -attributes** command.

---

### TYPE

list

---

### DEFAULT

{dont\_touch dont\_use map\_only size\_only ideal\_net infeasible\_paths}

---

### DESCRIPTION

This variable specifies the attributes reported by the **report\_timing -attributes** command. The list can contain any of the following attributes: **dont\_touch**, **dont\_use**, **map\_only**, **size\_only**, **infeasible\_paths** (Design Compiler and DC Explorer only), and **ideal\_net**.

When you use the **-attributes** option of the **report\_timing** command, the report shows the attributes that apply to each path increment under the heading "Attributes". A symbol key at the beginning of the path report lists the letter codes used for the attributes being reported. For example,

Attributes:

- d - dont\_touch
- u - dont\_use
- mo - map\_only
- so - size\_only
- i - ideal\_net or ideal\_network
- inf - infeasible path

To determine the current value of this variable, type **printvar timing\_report\_attributes**. For a list of all timing variables and their current values, type **print\_variable\_group timing**.

---

### SEE ALSO

[compile\(2\)](#)  
[report\\_timing\(2\)](#)

---

## timing\_report\_fast\_mode

Enables the fast **report\_timing** mode, which reports the worst timing paths among all path groups instead of individual path groups.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable, when set to true, selects the fast reporting mode for the **report\_timing** and **get\_timing\_paths** commands.

When this variable is set to false (the default), the worst timing paths are reported separately for each path group. When this variable is set to true, the worst paths in the design are reported, irrespective of path groups, so fewer paths are reported.

Setting this variable to true results in the following changes in reporting behavior:

- The values specified with the **-max\_paths** and **-nworst** options apply to all paths in the design rather than paths in each path group. For example, if the design has 12 path groups and **-max\_paths** is set to 3, only 3 paths are reported instead of 36.
- The paths reported by the command are ordered strictly by slack and are not separated by path group.
- When the **-max\_paths** and **-nworst** options are set to values larger than 1, only paths with negative slack are reported; paths with positive slack are omitted from the report.

Setting this variable to true results in the same reporting behavior as PrimeTime with respect to path groups and the **-max\_paths** and **-nworst** options.

To determine the current value of this variable, type **printvar timing\_report\_fast\_mode**.

---

### SEE ALSO

[get\\_timing\\_paths\(2\)](#)  
[report\\_timing\(2\)](#)

---

## timing\_report\_union\_tns

Specifies whether to use the union method for reporting total negative slack and number of violating endpoints.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When this variable is set to **true** (the default), the tool counts a violating endpoint only once when computing the total negative slack (TNS) and the number of violating endpoints for a path group, scenario, or design. The TNS for a path group is the sum of worst violations for all endpoints in that path group. The TNS for a scenario is the sum of worst violations in that scenario for all endpoints, irrespective of the path group. The TNS for a design is the sum of worst violations for all endpoints, irrespective of path group or scenario.

When this variable is set to **false**, the tool computes the scenario TNS as the sum of TNS for all path groups in that scenario. The multi-scenario TNS is computed as the sum of TNS for all scenarios.

---

### SEE ALSO

[report\\_qor\(2\)](#)

---

## timing\_save\_library\_derate

Controls whether the library cell derate settings are saved with the design (e.g., in milkyway cell or ddc files).

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable controls whether the library cell derate settings are saved with the design.

By default (false), these settings are not saved with the design, and need to be re-applied after re-opening the design in IC Compiler or Design Compiler. To save these settings with the design, set this variable to true before saving the design in IC Compiler or Design Compiler.

---

### SEE ALSO

`read_file(2)`  
`write(2)`  
`set_timing_derate(2)`

---

## timing\_scgc\_override\_library\_setup\_hold

Specifies whether you can override library-specified clock-gating setup and hold values with new values specified with the **set\_clock\_gating\_check** command.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

timing

---

### DESCRIPTION

When this variable is set to **true** (the default), you can use the **set\_clock\_gating\_check** command to specify clock-gating setup and hold values on cells or pins, overriding the library-specified values on those cells or pins.

When this variable is set to **false**, the **set\_clock\_gating\_check** command cannot override library-specified clock-gating setup and hold values on cells or pins.

Note that setup and hold values specified with the **set\_clock\_gating\_check** command, when specified for clocks or the design, always have lower priority than library-specified values, irrespective of this variable setting. This variable only affects values set on cells or pins.

When the variable is set to **true** (the default), you can use the **set\_clock\_gating\_check** command to set the setup and hold times to 0 for clock-gating checks at the design level, which enables automatic clock-gating check inferring and does not override any library values.

---

### SEE ALSO

[set\\_clock\\_gating\\_check\(2\)](#)  
[report\\_clock\\_gating\(2\)](#)  
[report\\_clock\\_gating\\_check\(2\)](#)

```
report_timing(2)
```

---

## timing\_self\_loops\_no\_skew

Affects the behavior, runtime, and CPU usage of **report\_timing** and **compile**.

**Note:** This variable will be obsolete in the next release. Please adjust your scripts accordingly.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

Affects the behavior, runtime, and CPU usage of **report\_timing** and **compile**. When set to *true*, clock skew is eliminated for a path that starts and ends at the same register. When set to *false* (the default value), clock skew is not eliminated. Thus, the timing for such paths is pessimistic. To obtain the more accurate behavior of no clock skew (uncertainty) for such paths, set this variable to *true*. However, note that runtime and memory usage might increase significantly.

To determine the current value of this variable, type **printvar timing\_self\_loops\_no\_skew**. For a list of all **timing** variables and their current values, type **print\_variable\_group timing**.

---

### SEE ALSO

`compile(2)`  
`report_timing(2)`

---

## timing\_separate\_clock\_gating\_group

Specifies if a separate cost group is used for clock-gating checks in timing analysis, reports, and optimization.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

timing

---

### DESCRIPTION

When this variable is set to **true**, a separate cost group named **“clock\_gating\_default”** is created for all clock-gating checks.

When set to **false** (the default), the clock-gating check is applied to the cost group of the clock being gated.

If multiple scenarios exist, a cost group is created for clock-gating checks for each scenario when this variable is **true**.

You can change the weight and critical range settings for this cost group using the **group\_path** command with the **-name “clock\_gating\_default”** option.

---

### SEE ALSO

[get\\_path\\_groups\(2\)](#)  
[group\\_path\(2\)](#)  
[report\\_clock\\_gating\(2\)](#)  
[report\\_clock\\_gating\\_check\(2\)](#)  
[report\\_constraint\(2\)](#)  
[report\\_path\\_group\(2\)](#)  
[report\\_qor\(2\)](#)  
[report\\_timing\(2\)](#)

---

## timing\_through\_path\_max\_segments

Controls the maximum number of latches for reporting paths through latches.

---

### TYPE

Integer

---

### DEFAULT

5

---

### DESCRIPTION

When **timing\_through\_path\_max\_segments** is set to a non-zero value, the tool selects some latch data pins on paths with many transparent latches to behave as they would if **timing\_enable\_through\_paths** were **false**, limiting the reporting on the long path but speeding up analysis. With a small non-zero value, many transparent latch data pins in the design will be selected. With a larger value, fewer will be selected.

When **timing\_through\_path\_max\_segments** is set to 0, no latch data pins are selected. Reporting on paths through many latches is allowed, but analysis may be slower.

The variable **timing\_through\_path\_max\_segments** has no effect if the variable **timing\_enable\_through\_paths** is set to **false**.

To determine the current setting, use the following command:

```
printvar timing_through_path_max_segments
```

---

### SEE ALSO

```
printvar(2)
report_timing(2)
timing_enable_through_paths(3)
```

---

## timing\_use\_ceff\_for\_drc

Specifies whether to use effective capacitance (Ceff) or total capacitance (Ctot) for DRC fixing of maximum capacitance violations.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

When this variable set to **false** (the default), total capacitance (Ctot) values are compared against the maximum capacitance limit during DRC fixing. When this variable is set to **true**, effective capacitance (Ceff) values are used instead.

Total capacitance is the sum of all the capacitance values in an RC network. Effective capacitance is a lumped value that results in a similar delay effect as the full RC network, calculated as the average capacitive loading that a gate observes at the delay trip-point.

The effective capacitance can be very different from the maximum total capacitive loading experienced by the gate. Choosing to use effective capacitance can possibly result in extrapolation errors.

Setting the variable to **true** may result in less pessimistic DRC fixing. Before you set this variable to **true**, be sure to carefully evaluate your capacitance fixing and signoff methodology.

---

### SEE ALSO

[report\\_delay\\_calculation\(2\)](#)  
[set\\_max\\_capacitance\(2\)](#)

---

## timing\_use\_clock\_specific\_transition

Propagate the transition from the specific clock path for latency calculation.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When this variable is set to **true** (the default value), the tool only propagates the transition of the clock path, for the purpose of clock latency calculation. If there are multi-input gates on the clock network, the transition of non-clock inputs are ignored during clock latency calculation.

For generated clocks defined on an output of a gate, the tool propagates the transition from the path connected to its master clock, and uses that transition value for the purpose of calculating the clock latency for the generated clock.

When set to **false**, the tool allow transition from the non-clock input of multi-input gates along the clock path to be used for clock latency calculation.

In addition, when set to **false**, the generated clock defined at the output of a gate uses zero transition at the generated clock source.

---

## timing\_use\_driver\_arc\_transition\_at\_clock\_source

Uses the backward cell arc to compute a realistic driver model at the driver pin for primary clock sources and also a generated clock that cannot trace back to its master clock.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When set to **true** (the default value), the tool uses the backward cell arcs, (when at least one exists), to compute a worst-case driver model. This behavior applies to the primary clock sources, which are defined by the **create\_clock** command, and generated clock sources (defined by the **create\_generated\_clock** command) that cannot trace back to its master clock.

When set to **false** the tool asserts a zero-transition, ideal ramp model at the driver pin.

---

### SEE ALSO

[create\\_clock\(2\)](#)  
[create\\_generated\\_clock\(2\)](#)

---

## timing\_use\_enhanced\_capacitance\_modeling

Specifies whether to use the enhanced capacitance modeling information available in the library description of a pin.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

When this variable is set to **true** (the default), the tool uses the enhanced capacitance modeling information available in the library description of a pin, consisting of different capacitance values for rise and fall transitions, and possibly a range of worst-case values for each type of transition. This setting is recommended for better timing correlation with the PrimeTime tool.

When this variable is set to **false**, the tool uses the single default capacitance value specified in the library description of the pin and ignores any enhanced capacitance information.

The library description of pin in Liberty format can contain both a default capacitance value and more specific values or ranges of capacitance values for rise and fall transitions. For example,

```
pin("IN1") {  
    direction : input;  
    capacitance : 0.0067542;  
    rise_capacitance : 0.0123321;  
    fall_capacitance : 0.0056745;  
    rise_capacitance_range (0.0045670, 0.012345);  
    fall_capacitance_range (0.005656, 0.0123123);  
}
```

When the variable is set to **true**, the tool uses the worst-case capacitance values specified by the rise and fall range attributes (for example, the high value for late arrival timing and the low value for early arrival timing). When the variable is set to **false**, the tool uses the single value specified by the plain "capacitance" attribute and ignores the rise and fall capacitance attributes.

---

### SEE ALSO

[set\\_operating\\_conditions\(2\)](#)

---

## tio\_allow\_mim\_optimization

Enables support for multiply instantiated modules (MIMs) during interface optimization performed using the **route\_opt** and **focal\_opt** commands.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

false in DC Explorer

---

### DESCRIPTION

This variable enables support for multiply instantiated modules (MIMs) during interface optimization performed using the **route\_opt** and **focal\_opt** commands.

When interface optimization is enabled on MIMs,

1. The tool optimizes inside MIMs.
2. The tool ensures that optimization done in any instance improves timing across all the instances of the MIM.
3. The tool replicates the netlist changes across all the instances.
4. At the end of optimization, the reference cell is taken through the block update steps consisting of the **legalize\_placement**, **route\_zrt\_eco**, and **create\_block\_abstraction** commands.

When this variable is set to **false**, the tool cannot optimize the interface of blocks that are multiply instantiated.

---

### SEE ALSO

[set\\_top\\_implementation\\_options\(2\)](#)

---

## tio\_reload\_block\_site\_rows

Specifies the IC Compiler to load sub-block site rows during initial linking in flows involving transparent interface optimization (TIO). This variable is to be used for designs with different site array configurations in top and sub-blocks.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Setting this variable as **true** makes IC Compiler to load the sub-block site rows during initial linking of top-level design. This is useful for flows that need to process site rows and site types of both Top-level and sub-blocks. An example usage is when running transparent interface optimization (TIO) on designs having different site rows in top and sub-blocks.

To use this feature, you must set the variable to **true** in the IC Compiler tool before you open the design.

---

### SEE ALSO

`set_top_implementation_options(2)`

---

## **tio\_preserve\_routes\_for\_block**

Setting this variable to true enables zroute based route preservation inside the blocks when transparent interface optimization is performed using the route\_opt or focal\_opt commands.

---

### **TYPE**

Boolean

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
false in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

During transparent interface optimization, when the tool changes a cell inside a block abstraction, the net identities can also change. For example, when inserting a buffer creates a new net, although the tool seeks to place the new cells along the route and maintain route topology, it does not simultaneously reassign the net identity of the route metallization geometries associated with the net. Route preservation performs this task in a process executed after the optimization phase finishes and before ECO routing begins. The presence of the route segments bound to the nets assist the ECO router to find a similar solution to the one obtained before optimization. In this way, preserving the routes improves correlation of the routing before and after optimization and therefore acts to improve the convergence in timing before and after ECO.

This variable is only active when Zroute is selected. If Zroute is disabled by using the set\_route\_mode\_options -zroute false command, this variable is not active.

---

### **SEE ALSO**

---

## track\_attributes

Contains attributes related to track.

---

## DESCRIPTION

Contains attributes related to track.

You can use **get\_attribute** to determine value of an attribute, and use **report\_attribute** to get a report of all attributes on specified track. Specified with **list\_attribute -class track -application**, the definition of attributes can be listed.

### Track Attributes

**bbox**

Specifies the bounding-box of a track. The **bbox** is represented by a **rectangle**.

The format of a *rectangle* specification is {{llx lly} {urx ury}}, which specifies the lower-left and upper-right corners of the rectangle.

The **bbox** of a track is calculated by the **origin** and **orientation** of its cell and the actual **bbox** of its corresponding terminal from the child MW design.

This attribute is read-only.

**bbox\_ll**

Specifies the lower-left corner of the bounding-box of a track.

The **bbox\_ll** is represented by a **point**. The format of a *point* specification is {x y}.

You can get the **bbox\_ll** of a track by accessing the first element of its **bbox**.

This attribute is read-only.

**bbox\_llx**

Specifies x coordinate of the lower-left corner of the bounding-box of a track.

The data type of **bbox\_llx** is double.

This attribute is read-only.

**bbox\_lly**

Specifies y coordinate of the lower-left corner of the bounding-box of a track.

The data type of **bbox\_lly** is double.

This attribute is read-only.

**bbox\_ur**

Specifies the upper-right corner of the bounding-box of a track.

The **bbox\_ur** is represented by a **point**. The format of a *point* specification is {x y}.

You can get the **bbox\_ur** of a track by accessing the second element of its **bbox**.

This attribute is read-only.

#### bbox\_urx

Specifies x coordinate of the upper-right corner of the bounding-box of a track.

The data type of **bbox\_urx** is double.

This attribute is read-only.

#### bbox\_ury

Specifies y coordinate of the upper-right corner of the bounding-box of a track.

The data type of **bbox\_ury** is double.

This attribute is read-only.

#### cell\_id

Specifies Milkyway design ID in which a track object is located.

This attribute is read-only.

#### count

Specifies the number of grid of a track.

The data type of **count** is integer.

This attribute is read-only.

#### direction

Specifies the routing direction of a track.

The valid values can be: X, Y.

This attribute is read-only.

#### layer

Specifies the layer name where a track object is located on.

This attribute is read-only.

#### name

Specifies the object name of a track.

This attribute is read-only.

#### object\_class

Specifies object class name of a track, which is **track**.

This attribute is read-only.

#### object\_id

Specifies object ID in Milkyway design file.

This attribute is read-only.

#### reserved\_for\_width

Specifies if a track is reserved for specified width.

The data type of **reserved\_for\_width** is boolean.

This attribute is read-only.

#### space

Specifies track step of a track.

The data type of **space** is integer.

This attribute is read-only.

#### start

Specifies start position of a track.

The data type of **start** is coordinate point.

This attribute is read-only.

#### stop

Specifies end position of a track.

The data type of **stop** is coordinate point.

This attribute is read-only.

#### width

Specifies the width of wires associated with the track.

The data type of **width** is double.

This attribute is read-only.

---

## SEE ALSO

[get\\_attribute\(2\)](#)  
[list\\_attributes\(2\)](#)  
[report\\_attribute\(2\)](#)

---

## ungroup\_keep\_original\_design

Controls whether the **ungroup** and **compile** commands keep the original design when a design is ungrouped.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

none

---

### DESCRIPTION

By default, the **ungroup** and **compile** commands delete the original design if all the instances of a design have been ungrouped and there are no other references to the design.

When set to **true**, the original design is preserved.

For example, assume there are two instances of the *mid* design named *mid1* and *mid2*. If you run the **ungroup -flatten -all** command, after the tool collapses the hierarchies, the design called *mid* is deleted from memory if there are no other references to the design. This variable is used to change the behavior. When this variable is set to **true**, the ungrouped design is preserved.

---

### SEE ALSO

[compile\(2\)](#)  
[set\\_ungroup\(2\)](#)  
[ungroup\(2\)](#)

---

## uniquify\_keep\_original\_design

Controls the **uniquify** command to keep the original design when a multiply-instantiated design is uniquified.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

none

---

### DESCRIPTION

By default, the **uniquify** command deletes the original design if all the instances of a design have been uniquified and there are no other references to the design from anywhere else.

When set to **true**, the original design is preserved.

For example, if there are two instances of the *mid* design, **uniquify** creates two new designs named *mid\_1* and *mid\_2*. By default the original design named *mid* is deleted. This variable is used to change this behavior.

---

### SEE ALSO

[uniquify\(2\)](#)

---

## uniquify\_naming\_style

Specifies the naming convention to be used by the **uniquify** command.

---

### TYPE

string

---

### DEFAULT

%s\_%d

---

### DESCRIPTION

This variable specifies the naming convention to be used by the **uniquify** command. The variable string must contain only one %s (percent s) and one %d (percent d) character sequence. To use a percent sign in the design name, two are needed in the string (%%).

---

### SEE ALSO

[uniquify\(2\)](#)

---

## upf\_add\_power\_state\_21\_syntax

Specifies whether the tool uses the UPF pre-2.1 style or UPF 2.1 (and beyond) syntax for the **add\_power\_state** command.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

none

---

### DESCRIPTION

Setting the variable to **true** enforces the UPF 2.1 (and beyond) syntax of the **add\_power\_state** command. Setting the variable to **false** enables the UPF pre-2.1 syntax. The following examples show the different syntax styles.

UPF pre-2.1 syntax: `add_power_state SS -state SS_1 {-supply_expr {power == {FULL_ON 0.9} && ground == {FULL_ON 0.0}}}`

UPF 2.1 syntax: `add_power_state SS -state {SS_1 -supply_expr {power == {FULL_ON 0.9} && ground == {FULL_ON 0.0}}}`

After you set this variable, it is marked read-only. The Design Compiler tool does not allow you to mix the syntax styles of the **add\_power\_state** command. The **add\_power\_state** commands in the UPF can only be in one style or the other. Choose the style by setting the variable before loading the UPF, but you can only do this one time for a Design Compiler session. This restriction ensures that the syntax style is fixed for a session.

---

### SEE ALSO

`add_power_state(2)`

---

## **upf\_allow\_DD\_primary\_with\_supply\_sets**

Allows using domain dependent supply nets of the design as the primary supply of the power domain when supply sets are used in the design.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

When supply sets are used in a design, domain dependent supply nets cannot be used as the primary supply of the power domain. Setting this variable to **true** removes this restriction. The default value of this variable is **false**.

After you read the UPF file, the tool ignores any changes to this variable setting. To change the variable setting, remove the UPF file, change the value of the variable, and reload the UPF file.

---

### **SEE ALSO**

[load\\_upf\(2\)](#)  
[remove\\_upf\(2\)](#)

---

## upf\_allow\_is\_isolated\_output\_check

Controls if is\_isolated attribute is to be ignored on output pins.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable controls whether is\_isolated attribute should be ignored on output pins. The default value of this variable is **true**.

When this variable is set to **true** (the default), tool checks if all load pins are equal or more always on than the driver pin irrespective of whether this pin has is\_isolated attribute or not. If this check fails, MV-514 is issued by the tool. To skip the on\_ness check with receiver for an is\_isolated output pin, set this variable to false.

---

## upf\_allow\_iso\_on\_dont\_touch\_nets

Controls the precedence between isolation strategy and dont\_touch attribute of nets.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

mv

---

### DESCRIPTION

This variable, when set to false, gives precedence to dont\_touch attribute on nets over isolation strategy; i.e., isolation cell insertion will not happen on user specified dont\_touch nets.

The default value is **true**, in which case isolation strategy is given precedence and isolation cells are inserted on dont\_touch nets with a warning.

Use the following command to determine the current value of the variable:

```
prompt> printvar upf_allow_iso_on_dont_touch_nets
```

---

### SEE ALSO

`set_isolation(2)`

---

## upf\_allow\_power\_gating\_cell\_for\_retention

Enables **power\_gating\_cell** attribute to be considered as valid attribute for identifying library cells as retention cells. This variable can be used only in UPF mode and in dc\_shell. It should be defined before RTL is read.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

power

---

### DESCRIPTION

The **upf\_allow\_power\_gating\_cell\_for\_retention** variable enables and disables the **power\_gating\_cell** attribute for identifying retention cells in libraries.

When set to **true** **power\_gating\_cell** attribute will be considered as a valid attribute for identifying retention cells.

When set to **false** **power\_gating\_cell** attribute will not be considered as a valid attribute instead only **retention\_cell** attribute will be considered as a valid attribute for identifying retention cells.

Variable will be deprecated in next major release.

---

### SEE ALSO

---

## upf\_allow\_refer\_before\_define

Allows UPF commands to refer to undefined UPF objects in the nested scope.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

none

---

### DESCRIPTION

When loading the top-only UPF, some UPF commands refer to block-level UPF objects which are not defined in top-only UPF. By default, it is not allowed to refer these undefined UPF objects. These undefined objects must be defined in the block-level UPF.

---

### EXAMPLES

In the following example, assume i\_sub/pd\_sub is not defined yet:

```
prompt> associate_supply_set ss -handle i_sub/pd_sub.primary  
Error: Supply set 'i_sub/pd_sub.primary' does not exist. (UPF-163)  
0
```

When this variable is set to **true**, the reference of undefined block-level UPF objects are allowed.

```
prompt> set upf_allow_refer_before_define true  
true  
prompt> associate_supply_set ss -handle i_sub/pd_sub.primary  
1
```

The i\_sub/pd\_sub.primary object is subsequently defined in the block-level UPF.

## SEE ALSO

`load_upf(2)`  
`save_upf(2)`

---

## upf\_apply\_retention\_attribute\_on\_non\_retention\_macro

Allows specifying non-Retention macros in element list of **set\_retention** and **set\_retention\_elements** commands.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

upf

---

### DESCRIPTION

When this variable is set to true, non-Retention macros will be allowed in element list of **set\_retention** and **set\_retention\_elements** commands. All the Retention attributes will be set on them.

Existing behavior of Design Compiler not mapping non-retention macro cells to retention macro cells will continue to be the same. It is user's responsibility to replace the non-retention macro cells with their retention equivalent. Failure to do so will reflect in check\_mv\_design via UPF-562 and UPF-563 messages.

---

### EXAMPLES

Consider input design has non-Retention macro (MACRO\_1) in power domain PDT:

```
prompt> set_retention RET_PDT -domain PDT -elements { MACRO_1 }
Warning: The cell MACRO_1 specified with the -elements option of the set_retention
or map_retention_cell command is neither sequential nor hierarchical. (UPF-146)
0
prompt> set upf_apply_retention_attribute_on_non_retention_macro true
prompt> set_retention RET_PDT -domain PDT -elements { MACRO_1 }
1
```

## SEE ALSO

`set_retention(2)`  
`set_retention_elements(2)`

---

## upf\_auto\_iso\_clamp\_value

Sets the clamp value for isolation strategies inferred by the DC Explorer tool.

---

### TYPE

string

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

0 in DC Explorer

---

### GROUP

none

---

### DESCRIPTION

This variable sets the clamp value of isolation strategies inferred by the DC Explorer tool. It can be set to either **0** or **1**.

---

### SEE ALSO

`set_isolation(2)`  
`set_isolation_control(2)`

---

## upf\_auto\_iso\_enable\_source

Sets the source of the isolation control signal for isolation strategies inferred by the DC Explorer tool.

---

### TYPE

string

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

`root_cell` in DC Explorer

---

### GROUP

none

---

### DESCRIPTION

This variable determines the source of the isolation control signal for isolation strategies inferred by the DC Explorer tool.

Leave this variable set to `root_cell` (the default) if control signal comes from a power controller block instantiated in the design root scope.

Set this variable to `top_level_port` if the control signal comes from a top-level port.

---

### SEE ALSO

`set_isolation(2)`  
`set_isolation_control(2)`

---

## upf\_auto\_iso\_isolation\_sense

Sets the isolation sense for isolation strategies inferred by the DC Explorer tool.

---

### TYPE

string

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

low in DC Explorer

---

### GROUP

none

---

### DESCRIPTION

This variable sets the logical sense of the isolation control signal for isolation strategies inferred by the DC Explorer tool. It can be set to either **low** or **high**.

---

### SEE ALSO

`set_isolation(2)`  
`set_isolation_control(2)`

---

## upf\_block\_partition

Specifies a list of hierarchical cells to be treated as block-level designs; their UPF is not written out by the **save\_upf** command.

---

### TYPE

list

---

### DEFAULT

""

---

### DESCRIPTION

Use this variable to specify a list of cells to be treated as block-level hierarchies. When you save the top-level UPF using the **save\_upf** command, the tool excludes the UPF associated with these blocks.

This variable is associated with the current design. The specified hierarchical cells must exist in the design when you set the variable. If you change to a different design, you need to set the variable again.

---

### SEE ALSO

[save\\_upf\(2\)](#)  
[check\\_upf\(2\)](#)

---

## upf\_charz\_allow\_port\_punch

Allows UPF-related port punching to occur within the **characterize** command on the blocks being characterized.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

mv

---

### DESCRIPTION

The **upf\_charz\_allow\_port\_punch** variable, when set to **true**, allows the **characterize** command to modify the block interfaces to automatically port punch the control signals of the power management cells from the top design and bring them into the block.

---

### SEE ALSO

[characterize\(2\)](#)

---

## upf\_charz\_enable\_domain\_rescoping

Allows the **characterize** command to work on instances which contain power domains that correspond to a higher scope.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

none

---

### DESCRIPTION

When this variable is set to **false** (the default), the **characterize** command will fail if used on a cell instance that contains a power domain belonging to a scope above that instance.

In order to characterize this sort of instance, this variable must be set to **true**. This will enable **characterize** to change the scope of the subdomain to the scope of the instance being characterized.

Domains which have their scope changed in this manner are not eligible for later domain merging by **propagate\_constraints**.

---

### EXAMPLES

Consider a simple design with the domain partitioning scheme:

```
create_power_domain TOP -include_scope  
create_power_domain MID -elements {x/y}
```

Normally, characterize of the instance **x** is not permitted:

```
prompt> characterize x  
Warning: Characterization of power supply data (UPF constraints, operating_voltages, etc.) to hierarchical cell 'x' have been skipped. (N  
Reason: a descendent cell 'x/y' of 'x' belongs to a power domain 'MID' whose scope is above 'w'.
```

Error: Characterize failed. (CHR-002)

0

When the variable is set to **true**, the operation succeeds and the domain is re-scoped:

```
prompt> set upf_charz_enable_domain_rescoping true
```

```
true
```

```
prompt> characterize x
```

```
Information: The power domain 'MID' has a scope above 'x'. The scope of the domain will be changed in the subdesign.
```

```
Characterizing cell 'x' on design 'mid'
```

```
1
```

---

## SEE ALSO

[characterize\(2\)](#)

---

## upf\_charz\_enable\_supply\_port\_punching

Allows UPF-related supply port punching to occur within the **characterize** command on the blocks being characterized.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

mv

---

### DESCRIPTION

The **upf\_charz\_enable\_supply\_port\_punching** variable, when set to **true**, allows the **characterize** command to modify the block interfaces to automatically punch supply ports to bring required supply nets into the block if they are not already available.

---

### SEE ALSO

[characterize\(2\)](#)

---

## upf\_charz\_max\_srsn\_messages

Sets the maximum number of error and warning messages related to the **set\_related\_supply\_net** command that can be printed when characterizing a block.

---

### TYPE

int

---

### DEFAULT

10

---

### GROUP

upf

---

### DESCRIPTION

To reduce the verbosity of the **characterize** command, a limit is set on the number of messages related to the **set\_related\_supply\_net** command that can be printed during characterization. You can change the verbosity of these messages by assigning an integer value to this variable.

---

### SEE ALSO

[characterize\(2\)](#)  
[set\\_related\\_supply\\_net\(2\)](#)

---

## upf\_check\_bias\_supply\_connections

Determines whether bias connections on a supply net are checked for conflicting PG types.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

mv

---

### DESCRIPTION

This variable determines whether bias connections on a supply net are checked for conflicting PG types.

By default, PG pins of the following types cannot be connected to the same supply net:

1. power and ground
2. nwell and pwell
3. nwell and ground
4. pwell and power

If the variable is set to **false**, only connections of type "a" are disallowed; bias supply connections (types "b," "c," and "d") are not checked.

Use the following command to determine the current value of the variable:

```
prompt> printvar upf_check_bias_supply_connections
```

---

## upf\_create\_implicit\_supply\_sets

Allows creation of supply set handles for the power domains.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable is set to **true** to enable the creation of supply set handles. When this variable is **true**, the tool creates the primary, default\_isolation, and default\_retention supply set handles when creating the power domains. Other user-defined supply set handles defined with the **-supply** option of the **create\_power\_domain** command are also created.

Note:

You must set this variable before creating the power domains. After creating the power domains, this variable is considered read-only. The tool issues the **CMD-013** error message if you change the value of the variable after creating the power domain.

---

### SEE ALSO

[create\\_power\\_domain\(2\)](#)

---

## upf\_derive\_ao\_supply\_on\_exception\_conns

Allow always-on derivation to rederive a new supply on a buffer with an exception connection

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

upf

---

### DESCRIPTION

When this variable is set to **true**, the tool will ignore explicit **connect\_supply\_net** statements which connect a supply to the backup pin of always\_on buffers, if it can derive a better supply (or if no backup supply is necessary).

When the variable is set to **false** (the default), the tool will treat explicit **connect\_supply\_net** statements connecting to the backup pin of always\_on buffers as fixed supplies, and will never derive a better supply or convert the buffer to a non-always\_on buffer.

---

### SEE ALSO

`set_always_on_strategy(2)`  
`connect_supply_net(2)`

---

## upf\_disable\_b2b\_iso\_nor\_optimization\_strategies

Lists the isolation strategies for which back-to-back NOR optimization must be disabled.

---

### TYPE

String

---

### DEFAULT

\*

---

### GROUP

upf

---

### DESCRIPTION

This variable provides a list of isolation strategies for which back-to-back NOR optimization must be disabled.

Value of **upf\_disable\_b2b\_iso\_nor\_optimization\_strategies** is a space seperated string with each token in <power\_domain> <isolation\_startegy\_name> format. First name in the token is full name of power domain. Second name in the token is isolation strategy name. Wildcard characters other than \* are not supported. Regular expressions are not supported.

When **upf\_disable\_b2b\_iso\_nor\_optimization\_strategies** is set to

\*\*\*

- Back-to-back NOR optimization is disabled for all isolation strategies in the design.

\*\*\*

- Back-to-back NOR optimization is enabled for all isolation strategies in the design.

"PD.ISO"

- Back-to-back NOR optimization is disabled for isolation strategy ISO of power domain PD

"PD.ISO mid/PD.ISO"

- Back-to-back NOR optimization is disabled for
  - isolation strategy ISO of power domain PD defined at TOP scope
  - isolation strategy ISO of power domain PD defined at mid scope

Variable is a overwrite variable, provided the new value is in the string format specified above. Variable value once set is valid for the entire Design Compiler session. This variable is applicable only to DC and has no impact on ICC shell.

All the isolation mapping commands like compile\_ultra, compile\_ultra -incr and insert\_mv\_cells will honor this variable setting.

If this variable is set post-compile, then it will be honored by the next mapping command for mapping newly inserted isolation cells. Existing isolation cells in the design will not be fixed as per this new setting.

This variable setting will not be written out in UPF' and also will not be written out in characterized block UPF.

---

## EXAMPLES

In the following UPF

```
prompt> create_power_domain PDTOP
prompt> set_isolation ISO -domain PDTOP -applies_to outputs
prompt> set_scope mid_inst
prompt> create_power_domain PDMID -elements {mid_inst}
prompt> set_isolation ISO -domain PDMID -applies_to outputs
prompt> set_scope /  
  
prompt> set upf_disable_b2b_iso_nor_optimization_strategies "PDTOP.ISO"
      // Back-to-Back NOR optimization is disabled for PDTOP.ISO and
      // will be implemented for mid_inst/PDMID.ISO  
  
prompt> set upf_disable_b2b_iso_nor_optimization_strategies "PDB_ISO"
Error: Variable format is not acceptable: PDB_ISO is not in <domain_name>.<isolation_name> format. (UPF-821)
      // Previous setting will hold good
      // Back-to-Back NOR optimization is disabled for PDTOP.ISO and
      // will be implemented for mid_inst/PDMID.ISO  
  
prompt> set upf_disable_b2b_iso_nor_optimization_strategies "PDTOP.ISO PDB.ISO"
      // Action commands will dump a warning saying PDB power domain is not defined.
      // Back-to-Back NOR optimization is disabled for PDTOP.ISO and
      // will be implemented for mid_inst/PDMID.ISO
```

---

## SEE ALSO

[compile\\_ultra\(2\)](#)  
[insert\\_mv\\_cells\(2\)](#)

---

## upf\_drop\_conflict\_retention\_constraint

Drop Retention constraint which is causing existing implemented retention registers dissociation

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

upf

---

### DESCRIPTION

When this variable is set to true, new Retention constraint causing existing implemented retention registers dissociation will be dropped.

---

### EXAMPLES

The following example explain the usage model of the variable:

```
prompt> set upf_drop_conflict_retention_constraint true
prompt> set_retention RET -domain PDT \
      -elements { mid }
prompt> compile_ultra
prompt> set_retention RET -domain PDT \
      -exclude_elements { mid/reg } -update
```

RET update will be dropped because that will cause mid/reg dissociation from RET.

---

## SEE ALSO

`set_retention(2)`  
`map_retention_cell(2)`  
`compile_ultra(2)`

---

## upf\_enable\_legacy\_block

Allows UPF 1.0-style design blocks to be integrated into a UPF 2.0-style design.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

mv

---

### DESCRIPTION

The **upf\_enable\_legacy\_block** variable, when set to **true**, allows the **legacy\_block** attribute to be applied to a UPF 1.0-style design instance through the **set\_design\_attribute** command. The **legacy\_block** attribute on a UPF 1.0-style design instance allows a UPF 2.0-style domain-independent supply net outside the block to be connected to a domain-dependent net inside at the block boundary. The connection of a domain-independent supply net to a domain-dependent one is illegal otherwise.

---

### SEE ALSO

---

## upf\_enable\_relaxed\_charz

Allows flexible partitioning of power domain and supports **-location parent** for isolation cells in a hierarchical flow.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

mv

---

### DESCRIPTION

The **upf\_enable\_relaxed\_charz** variable, when set to **true**, allows the **characterize** command to handle **-location parent** for isolation cells and also allows greater flexibility in partitioning the design. The **characterize** command can partition a part of power domain.

---

### SEE ALSO

[characterize\(2\)](#)

---

## upf\_extension

Disables writing UPF extension commands in the **save\_upf** command.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

mv

---

### DESCRIPTION

This variable controls whether the **save\_upf** command writes UPF extension commands such as **set\_related\_supply\_net** into UPF files. By default, UPF extension commands are written by **save\_upf** in the following format:

```
if {[info exists upf_extension] && upf_extension} {  
    <upf_extension_command>  
}
```

If **upf\_extension** is set to **false**, these lines are not written by **save\_upf**. The UPF extension command itself continues to be written by the **write\_script** command, and continues to be readable by the **source** and **load\_upf** commands.

All tools, including third party tools, that need to support the UPF extension commands must predefine the **upf\_extension** Tcl variable as **true**.

---

### SEE ALSO

[set\\_related\\_supply\\_net\(2\)](#)

---

## upf\_generate\_pm\_cell\_html

Controls HTML reporting of unmapped power management cells when compile\_ultra (-incr), insert\_mv\_cells and insert\_dft commands are run.

---

### TYPE

Boolean

---

### DEFAULT

Variable is not supported in Design Compiler non-topographical mode, Design Compiler topographical mode, and DC Explorer  
false in Design Compiler NXT non-topographical mode and Design Compiler NXT topographical mode

---

### GROUP

mv

---

### DESCRIPTION

When this variable is set to true, compile\_ultra (-incr) and insert\_dft commands generate HTML report for unmapped isolation, enable level shifter and retention cells. Whereas, insert\_mv\_cells command generates HTML report for unmapped isolation and enable level shifter cells. HTML report is produced only if there are unmapped Power Management cells in the design.

HTML report will list the reasons why each unmapped power management cell could not be mapped. Along with every reason, it will also list the library cells that failed to map to the cell due to that reason. HTML report directory called '**pm\_cells\_map\_failure.<x>**' is dumped into the current working directory every time any of the aforementioned commands is issued and there are unmapped power management cells in the design. Here '<x>' is a number that starts with 0 and increments every time a new HTML report directory is created.

The default value is **false**, in which case no HTML reports are produced.

Use the following command to determine the current value of the variable:

```
prompt> printvar upf_generate_pm_cell_html
```

---

## upf\_imvc\_no\_remap\_iso

Specifies that the insert\_mv\_cells command should not remap non-GTECH cells.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

mv

---

### DESCRIPTION

This variable prevents non-GTECH cells from being remapped during the incremental behavior of the insert\_mv\_cells command. The tool can ignore an isolation cell instance if it's mapped to a valid isolation library cell. A valid isolation library cell:

- Complies with any restrictions related to the isolation strategy that references it. For example, restrictions set by the map\_isolation\_cell command or NOR-style isolation requirements
- Has to match the design operating conditions of the referenced isolation cell.

The tool does not require the isolation cell match any other constraints such as target library subset or link library subset constraints. The tool does not perform conversions, such as isolation cell to enable level-shifter cell, if the isolation cell is mapped to a valid isolation library cell. This means that if there is a voltage violation, it is left unresolved.

To determine or change the current value of this variable, use get\_app\_var or set\_app\_var, respectively.

---

### SEE ALSO

[insert\\_mv\\_cells\(2\)](#)  
[map\\_isolation\\_cell\(2\)](#)

---

## upf\_infer\_complex\_retention\_cells

Controls inference of complex retention cells in place of complex non-retention cells having retention strategies.

A cell is considered complex if it does not have a valid functionality.

---

### TYPE

Boolean

---

### DESCRIPTION

When this variable is set to **false** (the default), tool will not infer any complex retention cells in place of pre-instantiated complex non-retention cells. The pre-instantiated complex non-retention cells will be left as is in the final netlist.

When this variable is set to **true**, tool will infer complex retention cells in place of pre-instantiated complex non-retention cells having retention strategies. This style of inference will be supported both in **compile\_ultra** and **compile\_ultra -incremental**.

Tool will try to infer a complex retention cell during **compile\_ultra** based on pin name matching. Here are the steps that will be performed by the tool during **compile\_ultra**:

1. Pin names of the non-retention cell will be matched with the pin names of the retention library cells specified in the **map\_retention\_cell** command.
2. The first retention library cell whose pin names exactly match (barring the retention save/restore pins) will be picked up and swapped in place of the non-retention cell.
3. If a matching retention library cell is not found, then a warning message will be printed saying that the non-retention cell cannot be converted to retention.

With the pin name matching approach, the tool will pick up the first matching retention library cell from the **map\_retention\_cell** command. If there are multiple matches available in **map\_retention\_cell**, and if the user wants a particular retention library cell to be picked up among the matches, then users will be able to achieve this by setting a new attribute called **retention\_equivalent** on the non-retention library cell. The value of this attribute will be the name of the preferred (equivalent) retention library cell.

Usage -

```
set_attribute {library/non_retention_library_cell_name} retention_equivalent {retention_library_cell_name}
```

If the retention library cell (specified as the attribute value) is invalid, then the tool will fall back to the pin name matching approach. A retention library cell will be considered invalid in the following scenarios:

1. The retention library cell is not present in any of the target libraries.
2. The retention library cell has the **dont\_use** attribute on it.
3. The retention library cell does not have the **retention\_cell** attribute on it.
4. The retention library cell is not present as one of the library cells in the **map\_retention\_cell** command.
5. The non-retention library cell has at least one pin that is not present on the retention library cell.

So, if an invalid retention library cell is found as the attribute value, then the tool will not honor the **retention\_equivalent** attribute, and

it will fall back to the pin name matching approach.

Point # 5 means that all the pins present on the non-retention library cell must also be present on the retention library cell. But it is okay for the retention library cell to have additional pins (other than the retention save/restore pins). Examples for additional pins are scan input and scan enable pins. If a retention library cell having additional pins is inferred by the tool, then **compile\_ultra** will connect the additional pins to constant zero. If a particular pin is not supposed to be connected to constant zero, then the user is expected to fix the connection after **compile\_ultra** (before taking the netlist further down the flow). Whenever a retention library cell having additional pins is inferred, a message will be printed to let the users know about such an inference. This should help the users to watch out for the connections made by the tool to the additional pins. Inferring retention cells with additional pins will be helpful for users who want to replace a non-scan non-retention cell (instantiated in the RTL) with a scan retention cell. **insert\_dft** can later do the required scan stitching with the scan input/scan enable pins.

**Handling mismatching pin names:** Users may have library cells where certain pin names of the non-retention library cell do not match the pin names of the retention library cell. In such cases, users can use the same **retention\_equivalent** attribute to specify the pin mappings between the mismatching pin names.

Usage -

```
set_attribute {library/non_retention_library_cell_name} retention_equivalent {retention_library_cell_name {pin1 pin2} {pin3 |
```

In this usage, the attribute value has the retention library cell name listed first and then the pin mappings between the non-retention library cell and the retention library cell. The above usage means that:

1. **pin1** on the non-retention library cell corresponds to (or is equivalent to) **pin2** on the retention library cell.
2. **pin3** on the non-retention library cell corresponds to **pin4** on the retention library cell.

This information will help the implementation tools to transfer the net connections appropriately. If the pin mappings are invalid, then the tool will fall back to the pin name matching approach. Pin mappings will be considered invalid in the following scenarios:

1. The specified pin name does not exist on the non-retention library cell/retention library cell.
2. Other than the specified pin mappings, the non-retention library cell has at least one pin that is not present on the retention library cell.

---

## upf\_iso\_filter\_elements\_with\_applies\_to

Controls the filtering of design elements specified in the **-elements** option when using the **-applies\_to** option of the **set\_isolation** command.

---

### TYPE

string

---

### DEFAULT

ENABLE

---

### GROUP

mv

---

### DESCRIPTION

This variable controls the filtering of design elements specified in the **-elements** list based on the direction specified in **-applies\_to** option of the **set\_isolation** command.

The default is **ENABLE**, which allows the usage of the **-elements** and **-applies\_to** together in the **set\_isolation** command. The elements are filtered based on the direction specified by the **-applies\_to** option.

Setting the variable to **DISABLE** instructs the tool to ignore the **-applies\_to** option and apply the isolation strategy to all the specified elements.

Use the following command to determine the current value of the variable:

```
prompt> printvar upf_iso_filter_elements_with_applies_to
```

---

### SEE ALSO

[set\\_isolation\(2\)](#)

---

## upf\_iso\_map\_exclude\_zpr\_clamp\_lib\_cells

Controls library cells used to map regular isolation cell when mapping constraint is specified for zero-pin retention clamp cells.

---

### TYPE

string

---

### DEFAULT

false

---

### GROUP

mv

---

### DESCRIPTION

This variable controls the library cells used to map regular isolation cells when a mapping constraint has been specified to map zero-pin retention clamp cells with **map\_retention\_clamp\_cell** command.

The default value is **false**, which allows library cells specified in mapping constraint on zero-pin retention clamp cells to be used to map regular isolation cells. When this variable is set to true, tool will not pick library cells used to map zero-pin retention clamp cells to map regular isolation cells. However, if a library cell is specified with both **map\_retention\_clamp\_cell** and **map\_isolation\_cell** command, **map\_isolation\_cell** gets higher precedence, and the cell can still be used to map regular isolation cells under the cell's isolation strategy. Global control does not play any role in this scenario.

If the design has regular isolation cells mapped to a library cell mentioned in **fBmap\_retention\_clamp\_cell** command, the next mapping command will remap this cell to a library cell not specified as part of **map\_retention\_clamp\_cell** command.

```
prompt> printvar upf_iso_map_exclude_zpr_clamp_lib_cells
```

---

### SEE ALSO

[map\\_retention\\_clamp\\_cell\(2\)](#)

---

## upf\_isolation\_enable\_relax\_self\_dependency\_check

Controls the mode (warn vs error) of self dependency check of an isolation control.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

none

---

### DESCRIPTION

Setting the variable to **false** enforces the self dependency check to be error.

UPF: set\_isolation ISO1 -domain PD\_TOP -elements {CTRL} -isolation\_signal {CTRL}

CTRL has a self dependency because CTRL enable signal is also CTRL. Default tool will flag a warning. When the variable is set to **false** tool will flag an error for this case.

---

### SEE ALSO

set\_isolation(2)

---

## upf\_isols\_allow\_instances\_in\_elements

Controls the specification of instances in the **-elements** option of the **set\_isolation** command.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

mv

---

### DESCRIPTION

This variable controls the specification of instances as the target elements for the **set\_isolation** command. By default, you can specify any hierarchical cell, macro, or black box as the target element for isolation.

Set this variable to **false** if you do not want the **set\_isolation** command to honor the specification of instances in its **-elements** list.

Use the following command to determine the current value of the variable:

```
prompt> printvar upf_isols_allow_instances_in_elements
```

---

### SEE ALSO

[set\\_isolation\(2\)](#)

---

## upf\_levshi\_on\_constraint\_only

Inserts level shifters only at the domain boundaries with a level shifter strategy.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

mv

---

### DESCRIPTION

This variable controls whether level shifter cells can be inserted at power domain boundaries without a strategy. By default, level shifters can be inserted at domain boundaries without a strategy. This gives more flexibility to the tool and has better QoR.

If you want to restrict the tool to insert level shifters only at the boundaries where the **set\_level\_shifter** command is specified, set the variable to **true**. The tool will not insert level shifters at all of the boundaries with **set\_level\_shifter**. The tool can insert level shifters only at the boundaries with the **set\_level\_shifter** constraint.

---

### SEE ALSO

[set\\_level\\_shifter\(2\)](#)

---

## **upf\_Is\_strategy\_in\_inst\_name**

Controls if level shifter strategy name should be included in level shifter and enable level shifter cell names.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

This variable controls whether level shifter strategy name and power domain should be included in level shifter and enable level shifter cell names. on output pins. The default value of this variable is **false**, level shifter and enable level shifter cells will not have level shifter strategy and power domain name included in cell name.

---

## upf\_name\_map

Specifies the name map files to be used during reapplication of golden UPF to designs.

---

### TYPE

list

---

### DEFAULT

""

---

### GROUP

mv

---

### DESCRIPTION

This variable specifies the name of the mapping file to be used for each design during reapplication of golden UPF to the designs. The variable can specify a single design name and its corresponding map file, or it can list multiple pairs of design names and corresponding map file names.

For example, to set a single design name and map name:

```
prompt> set upf_name_map [list {my_design my_design.map}]
```

To set multiple designs and corresponding map names:

```
prompt> set upf_name_map [list {top top.map} \
{mid mid.map}]
```

In a golden UPF session, the tool can change object names as a result of ungrouping and expansion of wildcard names to full names. When the golden UPF and supplemental UPF are applied to a design in a later tool session, the object names used in the golden UPF file must be properly mapped to the new names used in the design netlist. Synopsys Galaxy flow tools all use the same renaming conventions to keep track of changed names.

However, the default renaming conventions cannot handle some complex renaming situations. In those cases, the **write -format verilog** command, in addition to writing out the Verilog netlist, also writes an explicit name mapping file containing the renaming rules for the specific design. It also inserts a link to the name mapping file into the Verilog netlist, in the form of a pragma statement.

In a later tool session, when you read in this Verilog netlist, the tool automatically finds the applicable name map file and properly maps the object names, and it is not necessary to set the **upf\_name\_map** variable. However, if the name map file has been moved to a new location, or if the Verilog file no longer contains the pragma statement, you can set this variable to specify the location of the

name mapping file. The variable setting overrides any conflicting location specified by a pragma in the Verilog netlist file.

The name mapping file is a Tcl script containing Tcl built-in commands and two Synopsys commands: **set\_query\_rules**, which defines renaming rules for rule-based query, and **define\_name\_maps**, which defines the name mapping for specific objects. The file is provided information only; you should not edit or modify it.

The following is an example of a name mapping file:

```
# Query Rules
set_query_rules hierarchical_separator {/ _} bus_notation {} __

# Tcl built-in: local variables
set hier_1 A/B/C/D
set hier_2 A_B/B2/this/is/a/long/path

# Explicit name maps
define_name_maps \
    -application golden_upf \
    -design_name design \
    -columns {class pattern options names} \
    {[list cell $hier_1/A_reg [list leaf]      [list $hier_2/ger_A]      ] \
     [list cell A/B/X*_reg  [list nocase leaf] [list A_B/zar_reg A_B/Y_reg3]]}

# cleanup
unset hier_1
unset hier_2
```

To determine the current value of this variable, use **printvar upf\_name\_map** command. For a list of all mv variables and their current values, use the **print\_variable\_group mv** command.

---

## SEE ALSO

```
load_upf(2)
save_upf(2)
enable_golden_upf(3)
define_name_maps(2)
set_query_rules(2)
write(2)
```

---

## upf\_nor\_iso\_macro\_allow\_enable\_supply\_check

Controls if on-ness checks are to be done for all enable pins of nor(or nand) isolated macro output pins with multi-input isolation enable condition.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable controls how the tool performs on-ness checks between enable pins of a nor(or nand) isolated macro output pin. By default the value of this variable is **true**. A warning message (MV-570) is issued if any enable pin is less always on or unrelated to one(or more) load pin(s).

User has a way to avoid this warning by setting this variable to **false**. In this case, tool only requires at least one enable pin be equal or more always on than all load pins.

---

## upf\_pm\_data\_net\_force\_scalar

Remove signal nets connected to an isolation cell data pin from their original bus to handle them separately.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

mv

---

### DESCRIPTION

When set to true the tool will remove, from any signal net connected to a tool inserted isolation cell, any attribute that identifies it as part of a data bus.

This will stop **change\_names** from renaming affected nets based on bus naming related rules, also the net will not be written as part of a bus when writing out the resulting verilog file.

---

### SEE ALSO

[change\\_names\(2\)](#)  
[write\(2\)](#)

---

## upf\_power\_model\_library

This variable specifies a list of power model UPF files tool should read.

---

### TYPE

String

---

### DEFAULT

""

---

### DESCRIPTION

This variable specifies a list of power model UPF files in the directory specified by the variable upf\_power\_model\_search\_path that tool should read at the beginning of the load\_upf command. Only the define\_power\_model command in these UPF files will be processed.

This variable should be set before the first load\_upf command is executed.

Example:

```
prompt> set upf_power_model_library "model_1.upf model_2.upf"
```

---

### SEE ALSO

define\_power\_model(2)  
apply\_power\_model(2)  
report\_power\_model(2)  
upf\_power\_model\_search\_path(3)

---

## upf\_power\_model\_search\_path

This variable specifies the path to search for power model UPF files.

---

### TYPE

String

---

### DEFAULT

""

---

### DESCRIPTION

This variable specifies a list of directory paths that store power model UPF files. Tool should search for power model UPF files specified by variable upf\_power\_model\_library in this list of directory paths.

Power models will be read in the same order as directory paths and library files appear in these variables. Duplicated power models with the same names will be skipped.

This variable should be set before the first load\_upf command is executed.

Example:

```
prompt> set upf_power_model_search_path "/usr/lib/power_model_lib ./power_model_lib"
```

---

### SEE ALSO

define\_power\_model(2)  
apply\_power\_model(2)  
report\_power\_model(2)  
upf\_power\_model\_library(3)

---

## upf\_preserve\_logic\_in\_boolean\_expr

preserve logic signal referenced in the **-logic\_expr** option of the **set\_port\_attributes** command

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

mv

---

### DESCRIPTION

Normally, the tool makes no effort in preserving any logic signals referenced in the **-logic\_expr** option of the **set\_port\_attributes** command, dropping the expression if it becomes invalid due to the tool optimizing away some of the logic elements referenced in it.

Setting this variable to true restricts the tool from performing optimization or removing any logic elements referenced in the **-logic\_expr** option of the **add\_power\_state** command, so that the statement remains valid during the flow. This might impact QoR.

---

### SEE ALSO

[add\\_power\\_state\(2\)](#)

---

## upf\_print\_voltages\_with\_states

Controls whether voltage values will be printed along with state names in MV-231 message.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable controls whether voltage values will be printed along with state names in MV-231 message. The default value of this variable is **false**.

When this variable is set to **false** (default value), only state names are printed in MV-231 message.

Example:

```
prompt> check_mv_design
Warning: Pin 'ABC'(SN1[state_0_8,state_1]) cannot drive 'XYZ'(SN2[state_0_8,state_1]) due to PST voltage range differences (effect
```

When this variable is set to **true**, voltage values corresponding to the states are also printed in MV-231.

Example:

```
prompt> check_mv_design
Warning: Pin 'ABC'(SN1[state_0_8(0.86),state_1(1.08)]) cannot drive 'XYZ'(SN2[state_0_8(0.86),state_1(1.08)]) due to PST voltage r
```

---

## **upf\_proceed\_on\_bias\_rail\_order\_error**

Allows the **compile** and **insert\_mv\_cells** commands to proceed when bias rail order errors are found

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

mv

---

### **DESCRIPTION**

When set to **true** tool will proceed when bias rail order errors are reported (e.gUPF-659), instead of stopping until the issues are fixed.

---

## **upf\_relax\_target\_library\_subset\_for\_pm\_cells**

Set this variable to relax set\_target\_library\_subset constraint.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **GROUP**

upf

---

### **DESCRIPTION**

To map the power management cells, tool abides by both UPF constraints and target\_library\_subset constraint. If there is no overlap between UPF and target\_library\_subset libcells, tool leaves the power management cells unmapped or level shifter violations unaddressed. Thus, setting the variable will help relaxing the set\_target\_library\_subset constraint and use only UPF constraint during mapping. This helps avoiding unmapped power management cells. Currently, the variable takes effect only for isolation, level shifter and enable level shifter cells.

---

### **EXAMPLE**

Consider matching isolation library cells present in the target libraries are, ISO\_1, CKISO

UPF:  
prompt> **set upf\_relax\_target\_library\_subset\_for\_pm\_cells true**  
prompt> **set\_target\_library\_subset -clock\_path -dont\_use {CKISO} -top**  
prompt> **create\_power\_domain PD1**  
prompt> **set\_isolation iso\_mid1 -domain PD1**  
prompt> **map\_isolation\_cell -lib\_cells {CKISO}**  
prompt> **compile\_ultra**

With the variable set to false, tool will not consider libcell  
CKISO for isolation mapping as it is marked as dont\_use via

`set_target_library_subset` command. However, with the variable set to true, `set_target_library_subset` constraint will be relaxed and tool will consider CKISO libcell for isolation mapping.

---

## SEE ALSO

`set_target_library_subset(2)`

---

## upf\_report\_isolation\_matching

Specifies whether to report occurrences of an isolation strategy being applied to an existing isolation cell.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

mv

---

### DESCRIPTION

The **upf\_report\_isolation\_matching** variable, when set to **true**, causes the tool to report a UPF-073 information message whenever an isolation strategy is applied to an existing isolation cell.

If an isolation strategy is specified for a port that already has an isolation cell, the tool verifies that the existing isolation cell satisfies all of the parameters of the isolation strategy, except the power and ground nets. If these parameters are satisfied, the tool uses the existing cell and does not create another isolation cell for the port.

Set this variable to **true** if you want occurrences of this condition to be reported as UPF-073 information messages.

---

### SEE ALSO

`set_isolation(2)`

---

## upf\_skip\_ao\_check\_for\_els\_input

Specifies whether enable level shifters inserted by the tool are allowed to use a power supply that is more always-on than the driver supply.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

none

---

### DESCRIPTION

When this variable is set to **true** (the default), enable level shifters inserted by the tool can use a power supply that is either equally always-on or more always-on than the supply for the driver of the inputs of the enable level shifter.

When this variable is set to **false**, enable level shifters inserted by the tool must use a power supply that is equally always-on compared to the supply for the driver of the inputs of the enable level shifter.

An enable level shifter is a power management cell that performs both isolation and level shifting between two power domains.

---

### SEE ALSO

[compile\\_ultra\(2\)](#)  
[insert\\_mv\\_cells\(2\)](#)

---

## upf\_skip\_retention\_on\_dft\_cells

Skips Retention Register mapping of registers newly introduced by insert\_dft

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

upf

---

### DESCRIPTION

When this variable is set to true, all the registers newly introduced by insert\_dft will not undergo Retention mapping. They will be mapped to non-retention registers.

However, independent of the value set for this variable, scan replacement of existing Retention Registers that happens as part of insert\_dft will continue to honor Retention constraints.

One element level **set\_retention -no\_retention** strategy per power domain will be generated for the newly introduced DFT registers on which retention mapping is skipped.

A unique name will be generated as **snps\_no\_retention\_<domain\_name>** for each retention strategy for a given power domain. If a -no\_retention strategy exists with name **snps\_no\_retention\_<domain\_name>** during insert\_dft flow, the same will be updated to include newly inserted DFT cells.

compile\_ultra and compile\_ultra -incr will also honor this variable, if set to true.

---

### EXAMPLES

The following example generates retention strategy for newly introduced DFT cells {SCAN1 SCAN2} in power domain PDT:

```
prompt> set upf_skip_retention_on_dft_cells true
```

```
prompt> set_retention snps_no_retention_PDT -domain PDT \
-elements { SCAN1 SCAN2 } -no_retention
```

---

## SEE ALSO

`set_retention(2)`  
`compile_ultra(2)`  
`insert_dft(2)`

---

## upf\_suppress\_etm\_model\_checking

Disables model checking when referring to the UPF of a macro cell.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

mv

---

### DESCRIPTION

This variable controls model checking on the UPF for a macro cell. By default, when using the **create\_supply\_net** and **create\_supply\_port** commands on a power domain defined at the scope of a macro cell, the tool checks consistency against the cell's power and ground pin definitions. By setting this variable to **true**, these checks are skipped.

---

### SEE ALSO

[create\\_supply\\_net\(2\)](#)  
[create\\_supply\\_port\(2\)](#)

---

## upf\_suppress\_message\_in\_black\_box

Suppresses warning messages caused missing objects when UPF commands are loaded at the black box scope.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

none

---

### DESCRIPTION

When loading UPF at scope of a black box (Verilog stub), netlist objects inside the block are not accessible. If the UPF for the black box contains commands that refer to netlist objects inside the block, those objects are ignored.

When this variable is set to **true** (the default), no warning message is displayed for missing objects. For example,

```
prompt> connect_supply_net sn -port sub/sp  
prompt>
```

When this variable is set to **false**, warning messages are displayed for missing objects. For example,

```
prompt> set upf_suppress_message_in_black_box false  
false  
prompt> connect_supply_net sn -port sub/sp  
Warning: Can't find supply ports or power pins matching 'sub/sp' in design 'mid'. (UID-95)  
prompt>
```

---

### SEE ALSO

UPF-623(n)  
UPF-626(n)

UPF-627(n)

---

## upf\_suppress\_message\_in\_etm

Suppresses warning messages when the current scope is an extracted timing model (ETM) and you use disallowed UPF commands.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### GROUP

none

---

### DESCRIPTION

When loading UPF at the scope of an extracted timing model (ETM) instance, only the `create_power_domain`, `add_port_state` and `set_scope` UPF commands are allowed. Any other UPF commands are ignored.

When this variable is set to `true` (the default), no warning message is issued for ignored commands. For example,

```
prompt> create_supply_net sn
sn
prompt>
```

When this variable is set to `false`, the tool issues a warning message when disallowed commands are ignored. For example,

```
prompt> set_app_var upf_suppress_message_in_etm false
false
prompt> create_supply_net sn
Warning: UPF Command 'create_supply_net' is skipped under ETM scope 'I_SUB'. (UPF-628)
prompt>
```

---

### SEE ALSO

UPF-628(n)



---

## upf\_use\_driver\_receiver\_for\_io\_voltages

Controls if related supply of top level ports is derived from related supply of connected pad pins.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

This variable controls how the tool derives supply for top-level ports. By default the value of this variable is **true**. If a top-level port has one or more connected cell pins with `is_pad` attribute true, related supply will be derived from pad pins. This supply will be used even if user has set related supply on such ports with `set_port_attributes` or `set_related_supply_net` command in their UPF.

User has the option to not use pad supply for top-level ports by setting this variable to **false**.

---

## upf\_write\_only\_rtlpg\_to\_pg\_netlist

Controls the feature to write out only the RTLPG connections to the PG Verilog netlist in the presence of UPF.

---

### TYPE

Boolean

---

### DESCRIPTION

When this variable is set to **true**, "write -format verilog -pg" will write out only the RTLPG connections to the PG Verilog netlist in the presence of UPF.

When this variable is set to **false** (the default), "write -format verilog -pg" will write out the full PG Verilog netlist in the presence of UPF.

This variable needs to be set before reading in the RTL.

Below is how the flow will look like in the presence of this variable.

```
>>>
set dc_allow_rtl_pg true
set upf_write_only_rtlpg_to_pg_netlist true

read_verilog

load_upf

convert_pg
write -format verilog -pg
>>>
```

---

### SEE ALSO

[dc\\_allow\\_rtl\\_pg\(3\)](#)

---

## **use\_port\_name\_for\_osc**

Specifies that when off-sheet connectors for nets also have ports on them, they are given the name of the port.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

This variable specifies that when off-sheet connectors for nets also have ports on them, they are given the name of the port.

By default, the connectors are given the name of the net.

---

### **SEE ALSO**

---

## vao\_feedthrough\_module\_name\_prefix

Variable to specify the prefix for the name of new hierarchies created during voltage area aware always-on synthesis.

---

### TYPE

string

---

### DEFAULT

""

---

### GROUP

mv

---

### DESCRIPTION

In the voltage area aware always-on synthesis triggered by the **psynopt** or the **place\_opt** command, new hierarchies are created to hold the newly inserted always-on buffers, to fix DRC violations. Using this variable you can specify prefix for the new hierarchy created during voltage area aware always-on synthesis.

#### Multicorner-Multimode Support

This variable has no dependency on scenario-specific information.

---

### EXAMPLE

For the new hierarchies to start with the prefix SNPS\_VAO, set the variable as follows:

```
set_app_var vao_feedthrough_module_name_prefix {SNPS_VAO}
```

---

### SEE ALSO

## **verbose\_messages**

Causes more explicit system messages to be displayed during the current session.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true

---

### **DESCRIPTION**

This variable causes more explicit system messages to be displayed during the current session.

---

### **SEE ALSO**

---

## verilogout\_equation

Writes Verilog "assign" statements (Boolean equations) for combinational gates, rather than gate instantiations.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable writes Verilog "assign" statements (Boolean equations) for combinational gates, rather than gate instantiations.

By default, gate instantiations are written.

---

### SEE ALSO

---

## **verilogout\_higher\_designs\_first**

Writes Verilog "modules" so that the higher-level designs come before lower-level designs, as defined by the design hierarchy.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

This variable writes Verilog "modules" so that higher-level designs come before lower-level designs, as defined by the design hierarchy. The default is to write lower-level designs first.

---

### **SEE ALSO**

---

## verilogout\_ignore\_case

Instructs the compiler not to consider the case when comparing identifiers to Verilog reserved words.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### GROUP

hdl\_variables

---

### DESCRIPTION

This variable instructs the compiler not to consider the case when comparing identifiers to Verilog reserved words.

When an identifier is equal to a reserved word, the identifier is escaped by putting a backslash (`\`) in front of it. When this variable is set to **false**, case is considered. When set to **true**, case is ignored in the comparison.

Therefore, if **verilogout\_ignore\_case** is set to **true**, the default allows an identifier BUF to pass unchanged, BUF becoming \BUF.

---

### SEE ALSO

---

## verilogout\_include\_files

Specifies to the **write -f verilog** command to write an include statement that will have the name of the value you set for this variable.

---

### TYPE

list

---

### DEFAULT

""

---

### GROUP

hdl\_variables

---

### DESCRIPTION

This variable specifies to the **write -f verilog** command to write an include statement that will have the name of the value you set for this variable. For example, when you specify **verilogout\_include\_files={"my\_header.v"}**, you see an include "my\_header.v" in your Verilog output.

---

### SEE ALSO

[write\(2\)](#)

---

## verilogout\_indirect inout connection

Uses nets snps\_logic\_zero and snps\_logic\_one to indirectly connect inout ports to Logic 0 or 1.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

By default the Verilog Writer will write any port connected to Logic 0 or 1 as connected to "1'b0" or "1'b1". The Verilog Standard is more strict, however, and it asks that inout ports use an intermediate net for this kind of connections. When this variable is set to true the Verilog Writer will use snps\_logic\_zero and snps\_logic\_one nets, which are in turn assigned to their corresponding logic.

---

### SEE ALSO

---

## **verilogout\_inout\_is\_in**

Instructs the tool to treat inout ports as inputs, changing from the default of output, in the Verilog output netlist. This can have an effect on simulation results if tristates are disabled by setting the **verilogout\_no\_tri** variable.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

Instructs the tool to treat inout ports as inputs in the Verilog output netlist.

---

### **SEE ALSO**

---

## verilogout\_no\_tri

Declares three-state nets as Verilog wire instead of tri. This variable is useful to eliminate assign primitives and tran gates in the Verilog output. If there are real inout ports in the design, you need tristates to be able to read and write to them without any direction or cycle issues in simulation; that is, tran gates allow interfacing two drivers. For synthesis, an assign statement is not directional. It is a simple wire used as an electrical connection, but for simulation it is directional and could result in simulation issues if you deactivate tristates.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

Declares three-state nets as Verilog wire instead of tri. Use this variable to eliminate assign primitives and tran gates in the Verilog output.

---

### SEE ALSO

---

## **verilogout\_show\_unconnected\_pins**

Instructs the Verilog writer to write out all of the unconnected instance pins, when connecting module ports by name. For example, modb b1 (.A(in),.Q(out),.Qn()).

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

This variable instructs the Verilog writer to write out all of the unconnected instance pins, when connecting module ports by name. For example, modb b1 (.A(in),.Q(out),.Qn()).

By default, the Verilog writer does not write out any unconnected pins. For example, modb b1 (.A(in),.Q(out)).

---

### **SEE ALSO**

---

## **verilogout\_single\_bit**

Instructs the compiler not to output vectored ports in the Verilog output. All vectors are written as single bits.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

This variable instructs the compiler not to output vectored ports in the Verilog output. All vectors are written as single bits.

---

### **SEE ALSO**

---

## verilogout\_unconnected\_prefix

Instructs the Verilog writer to use the name SYNOPSYS\_UNCONNECTED\_ to create unconnected wire names. The general form of the name is SYNOPSYS\_UNCONNECTED\_%d.

---

### TYPE

string

---

### DEFAULT

SYNOPSYS\_UNCONNECTED\_

---

### DESCRIPTION

This variable instructs the Verilog writer to use the name (SYNOPSYS\_UNCONNECTED\_) to create unconnected wire names. The general form of the name is SYNOPSYS\_UNCONNECTED\_%d.

The purpose of this variable is to avoid conflict with the name already used in the design.

---

### SEE ALSO

---

## vhdlout\_bit\_type

Sets the basic bit type in a design written to VHDL.

---

### TYPE

string

---

### DEFAULT

std\_logic

---

### DESCRIPTION

The **vhdlout\_bit\_type** variable sets the basic bit type in a design written to VHDL. This is useful when you base your design methodology on a logic value system other than std\_logic.

---

### SEE ALSO

[vhdlout\\_bit\\_vector\\_type\(3\)](#)  
[vhdlout\\_one\\_name\(3\)](#)  
[vhdlout\\_three\\_state\\_name\(3\)](#)  
[vhdlout\\_zero\\_name\(3\)](#)

---

## **vhdlout\_bit\_vector\_type**

Sets the basic bit vector type in a design written to VHDL.

---

### **TYPE**

string

---

### **DEFAULT**

std\_logic\_vector

---

### **DESCRIPTION**

The **vhdlout\_bit\_vector\_type** variable sets the basic bit vector type in a design written to VHDL. This is useful when your design methodology is based on a logic value system other than std\_logic.

---

### **SEE ALSO**

[vhdlout\\_bit\\_type\(3\)](#)  
[vhdlout\\_one\\_name\(3\)](#)  
[vhdlout\\_three\\_state\\_name\(3\)](#)  
[vhdlout\\_zero\\_name\(3\)](#)

---

## **vhdlout\_dont\_create\_dummy\_nets**

Instructs the VHDL writer not to create dummy nets to connect unused pins or ports in your design.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

The **vhdlout\_dont\_create\_dummy\_nets** variable instructs the VHDL writer that it is not to create dummy nets to connect unused pins or ports in your design.

If you want the VHDL writer to create dummy nets to connect unused pins or ports in your design, set the value of this variable as **false** (the default value).

---

### **SEE ALSO**

---

## vhdlout\_equations

Defines how the tool is to write combinational logic and sequential logic.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable specifies to the tool how it is to write combinational logic and sequential logic. When you set the value of this variable as **true**, the compiler does the following:

- Writes combinational logic as technology-independent Boolean equations
- Writes sequential logic as technology-independent wait statements.

If you set the value of this variable to **false** (the default value), the tool writes all logic as technology-specific netlists.

Note that if you define a bit type, make sure that Boolean equations are defined for the bit type.

---

### SEE ALSO

---

## **vhdlout\_follow\_vector\_direction**

Specifies how the tool is to use the original range direction when it writes out an array.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

The **vhdlout\_follow\_vector\_direction** variable defines the way in which the tool is to use the original range direction when it writes out an array.

To achieve this result, do the following:

- Set the value of this variable as **true** (the default value)
- Set the value of the **vhdlout\_single\_bit** variable to the type mode of **VECTOR**, not the ascending range.

For example, when you set the value of the **vhdlout\_follow\_vector\_direction** variable as **true** (the default value), the HDL Compiler writes out the correct array range direction, such as 10 down to 0, if the original is 10 down to 0.

Note that if **vhdlout\_follow\_vector\_direction** is set to **true**, the tool automatically sets the type mode to **VECTOR**.

---

### **SEE ALSO**

[vhdlout\\_bit\\_type\(3\)](#)  
[vhdlout\\_bit\\_vector\\_type\(3\)](#)  
[vhdlout\\_preserve\\_hierarchical\\_types\(3\)](#)  
[vhdlout\\_single\\_bit\(3\)](#)

---

## **vhdlout\_local\_attributes**

This variable is obsolete.

---

## vhdlout\_lower\_design\_vector

Determines the way in which the **write -f vhdl** command writes out ports on lower-level designs

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

The **vhdlout\_lower\_design\_vector** variable determines the way in which the **write -f vhdl** command writes out ports on lower-level designs. A lower-level design is instantiated by any of the designs being written out. The **vhdlout\_top\_design\_vector** variable controls ports on top-level designs.

When the value of this variable is set to **false**, all ports on lower-level designs are written with their original data types. The value of **false** affects only designs read in VHDL format.

When set to **true** (the default) all ports on lower-level designs are written as bused ports, which means the ports keep their names and are not bit-blasted. The ports are written with the type you define using the **vhdlout\_bit\_vector\_type** variable or, for single-bit ports, using the **vhdlout\_bit\_type** variable. This setting often results in the most efficient description for simulation. Bus ranges are always in ascending order beginning with 0, regardless of the range description in the original VHDL. If you set this variable as **true**, you must ensure that **vhdlout\_bit\_vector\_type** is defined as an array type whose elements are of **vhdlout\_bit\_type**.

Note that you cannot set the value of the **vhdlout\_lower\_design\_vector** variable to **false**, if the value of the **vhdlout\_top\_design\_vector** variable is set to **true**.

Also note that if **vhdlout\_follow\_vector\_direction** is set to **true**, the value of the **vhdlout\_lower\_design\_vector** variable is automatically set to **true**.

---

### SEE ALSO

**write(2)**  
**vhdlout\_bit\_type(3)**  
**vhdlout\_bit\_vector\_type(3)**  
**vhdlout\_follow\_vector\_direction(3)**  
**vhdlout\_top\_design\_vector(3)**

---

## **vhdlout\_one\_name**

Determines the literal name for constant bit value 1 in a design written in VHDL.

---

### **TYPE**

string

---

### **DEFAULT**

'1'

---

### **DESCRIPTION**

The value you specify for the **vhdlout\_one\_name** variable determines the literal name for the constant bit value 1 in a design written in VHDL.

This variable is useful when your design methodology is based on a more general logic value than BIT. Use this variable with the **vhdlout\_bit\_type** variable.

---

### **SEE ALSO**

[vhdlout\\_bit\\_type\(3\)](#)  
[vhdlout\\_bit\\_vector\\_type\(3\)](#)  
[vhdlout\\_three\\_state\\_name\(3\)](#)  
[vhdlout\\_zero\\_name\(3\)](#)

---

## vhdlout\_package\_naming\_style

Determines the name the tool is to use for the type conversion packages written out by the VHDL writer (VHDLout).

---

### TYPE

string

---

### DEFAULT

CONV\_PACK\_%d

---

### DESCRIPTION

The **vhdlout\_package\_naming\_style** variable determines the name the tool is to use for the type conversion packages written out by the VHDL writer (VHDLout). The value for this variable can contain a string made up of letters, digits, and underscores. The string **%d** is replaced by the name of the current design (**%d** and **%D** are synonymous), as shown as the default value. The tool gives unique names to all conversion packages that are written out.

The tool verifies that the generated name is a valid VHDL identifier and that it is a unique name. If the name is invalid, an error occurs.

---

### SEE ALSO

---

## vhdlout\_preserve\_hierarchical\_types

Affects the way in which the **write -f vhdl** command writes out ports on lower-level designs

---

### TYPE

string

---

### DEFAULT

VECTOR

---

### DESCRIPTION

The **vhdlout\_preserve\_hierarchical\_types** variable affects the way in which the **write -f vhdl** command writes out ports on lower-level designs. A lower-level design is instantiated by any of the designs being written out. Another variable, **vhdlout\_single\_bit**, controls ports on top-level designs.

Valid values are as follows:

#### USER

All ports on lower-level designs are written with their original data types. The value of **USER** affects only designs that are read in VHDL format.

#### VECTOR

All ports on lower-level designs are written with their ports bused, which means that ports keep their names and are not bit-blasted. The ports are written with the type defined by **vhdlout\_bit\_vector\_type** or, for single-bit ports, by **vhdlout\_bit\_type**. This setting of **VECTOR** (the default value) often results in the most efficient description for simulation. Bus ranges are always in ascending order, beginning with 0, regardless of the range description in the original VHDL. If you use **VECTOR**, you must ensure that the value of the **vhdlout\_bit\_vector\_type** variable is an array type whose elements are defined by the **vhdlout\_bit\_type** variable.

#### BIT

All typed ports are bit-blasted, which means that a port that is  $n$  bits wide is written to the VHDL file as  $n$  separate ports. Each port is given a type as defined by the **vhdlout\_bit\_type** variable.

Note that if **vhdlout\_single\_bit = BIT**, the tool ignores **vhdlout\_preserve\_hierarchical\_types** and writes out the entire design hierarchy as bit-blasted. Also, **vhdlout\_preserve\_hierarchical\_types** cannot take on a higher value than the current value defined for the **vhdlout\_single\_bit** variable. The descending order is **USER**, **VECTOR**, and **BIT**. Thus, the combination **vhdlout\_single\_bit = VECTOR** and **vhdlout\_preserve\_hierarchical\_types = USER** is not possible.

Also note that if **vhdlout\_follow\_vector\_direction = true**, the type mode is automatically set to **VECTOR**.

## SEE ALSO

`write(2)`  
`vhdlout_bit_type(3)`  
`vhdlout_bit_vector_type(3)`  
`vhdlout_follow_vector_direction(3)`  
`vhdlout_single_bit(3)`

---

## **vhdlout\_separate\_scan\_in**

Affects the way in which the **write -f vhdl** command writes out the scan chain in VHDL.

---

### **TYPE**

string

---

### **DEFAULT**

false

---

### **DESCRIPTION**

The **vhdlout\_separate\_scan\_in** variable affects the way in which the **write -f vhdl** command writes out the scan chain in VHDL.

By default, the tool writes out the scan chain in the same file as the design. The scan chain is not visible in the testbench, and, therefore, parallel loading is not possible.

When the value is set to **true**, the tool writes out the scan chain as a package to a separate file. The design must be written out in a single hierarchical file, and it must contain the scan-chain package, before simulation or synthesis takes place.

You receive a message only when the scan-chain package is written successfully. Otherwise, no message appears.

---

### **SEE ALSO**

[write\(2\)](#)

---

## vhdlout\_single\_bit

Affects the way in which the **write -f vhdl** command writes out ports on the top-level design.

---

### TYPE

string

---

### DEFAULT

USER

---

### DESCRIPTION

This variable affects the way in which the **write -f vhdl** command writes out ports on the top-level design.

Valid values are as follows:

**USER**

All ports on the top-level design are written out with their original data types. The **USER** value affects only designs that are read in VHDL format.

**VECTOR**

All ports on the top-level design are written with their ports bused, which means that ports keep their names and are not bit-blasted. The ports are written with the type defined by the **vhdlout\_bit\_vector\_type** variable, or for single-bit ports, the **vhdlout\_bit\_type** variable. Lower-level design ports are controlled by the **vhdlout\_preserve\_hierarchical\_types** variable. (A design is lower-level if it is instantiated by any of the designs being written out.)

Bus ranges are always in ascending order, beginning with 0, regardless of the range description in the original VHDL. If you use **VECTOR**, you must ensure that the value of the **vhdlout\_bit\_vector\_type** variable is an array type whose elements are defined by the **vhdlout\_bit\_type** variable.

**BIT**

All typed ports are bit-blasted, which means that a port that is  $n$  bits wide is written to the VHDL file as  $n$  separate ports. Each port is given a type, as defined by the **vhdlout\_bit\_type** variable.

Note that if **vhdlout\_follow\_vector\_direction = true**, the type mode is automatically set to VECTOR.

---

### SEE ALSO

```
write(2)
vhdlout_bit_type(3)
vhdlout_bit_vector_type(3)
vhdlout_preserve_hierarchical_types(3)
```

---

## **vhdlout\_target\_simulator**

Names the target simulator to which the tool writes the VHDL file.

---

### **TYPE**

string

---

### **DEFAULT**

""

---

### **DESCRIPTION**

The **vhdlout\_target\_simulator** variable names the target simulator to which the tool is to write the VHDL file. The only valid value is **xp**. The default is an empty string.

If you set the value of **vhdlout\_target\_simulator** as **xp**, be sure also to specify the **vhdlout\_use\_packages** variable to include the following instructions (or the written description does not analyze correctly):

SYNOPSYS.attributes.all

---

### **SEE ALSO**

[vhdlout\\_use\\_packages\(3\)](#)

---

## **vhdlout\_three\_state\_name**

Names the high-impedance bit value used for three-state device values.

---

### **TYPE**

string

---

### **DEFAULT**

'Z'

---

### **DESCRIPTION**

This variable names the high-impedance bit value used for three-state device values. The default value is **Z**.

---

### **SEE ALSO**

[vhdlout\\_bit\\_type\(3\)](#)  
[vhdlout\\_bit\\_vector\\_type\(3\)](#)  
[vhdlout\\_one\\_name\(3\)](#)  
[vhdlout\\_zero\\_name\(3\)](#)

---

## vhdlout\_three\_state\_res\_func

Names a user-supplied three-state resolution function that must be in one of the packages specified by the **vhdlout\_use\_packages** variable.

---

### TYPE

string

---

### DEFAULT

""

---

### DESCRIPTION

The **vhdlout\_three\_state\_res\_func** variable names a user-supplied three-state resolution function that must be in one of the packages specified by the **vhdlout\_use\_packages** variable.

By default, the tool writes out (if needed) a default three-state resolution function. The default three-state resolution function drives a signal to "unknown," if the signal is driven more than once by logic 0 or logic 1.

---

### SEE ALSO

```
write(2)
vhdlout_use_packages(3)
vhdlout_wired_and_res_func(3)
vhdlout_wired_or_res_func(3)
```

---

## vhdlout\_top\_configuration\_arch\_name

Determines the name of the outside architecture, depending on the value you defined for the **vhdlout\_write\_top\_configuration** variable, and causes the VHDL writer (VHDLout) to write out a configuration statement.

---

### TYPE

string

---

### DEFAULT

A

---

### DESCRIPTION

The value you define for the **vhdlout\_top\_configuration\_arch\_name** variable determines the name of the outside architecture, depending on the value you defined for the **vhdlout\_write\_top\_configuration** variable, and causes the VHDL writer (VHDLout) to write out a configuration statement.

For example, assume the top-level design being written has an entity named *Ten* and architecture named *Tar*. The configuration statement binds *Ten*, *Tar*, and an outside entity named *Oen* with an outside architecture named *Oar* to instantiate *Ten* as a component. You set the variable as shown in the following example:

```
set_app_var vhdlout_top_configuration_arch_name {Oar}
```

An example of an outside architecture is a testbench that you provide to drive simulation with test vectors.

---

### SEE ALSO

[write\(2\)](#)  
[vhdlout\\_top\\_configuration\\_entity\\_name\(3\)](#)  
[vhdlout\\_top\\_configuration\\_name\(3\)](#)  
[vhdlout\\_write\\_top\\_configuration\(3\)](#)

---

## vhdlout\_top\_configuration\_entity\_name

Determines the name of the outside entity, depending on the value you defined for the **vhdlout\_write\_top\_configuration** variable, and causes the VHDL writer (VHDLout) to write out a configuration statement.

---

### TYPE

string

---

### DEFAULT

E

---

### DESCRIPTION

The value you specify for the **vhdlout\_top\_configuration\_entity\_name** variable determines the name of the outside entity, depending on the value you defined for the **vhdlout\_write\_top\_configuration** variable, and causes the VHDL writer (VHDLout) to write out a configuration statement.

For example, assume the top-level design being written has an entity named *Ten* and an architecture named *Tar*. The configuration statement binds *Ten*, *Tar*, and an outside entity named *Oen* with an architecture named *Oar*, to instantiate *Ten* as a component. You set the variable as shown in the following example:

```
set_app_var vhdlout_top_configuration_entity_name {Oen}
```

An example of an outside architecture is a testbench that you provide to drive simulation with test vectors.

---

### SEE ALSO

`write(2)`  
`vhdlout_top_configuration_arch_name(3)`  
`vhdlout_top_configuration_name(3)`  
`vhdlout_write_top_configuration(3)`

---

## vhdlout\_top\_configuration\_name

Determines the name of the configuration statement the **write -f vhdl** command writes out, when the **vhdlout\_write\_top\_configuration** variable is set to **true**.

---

### TYPE

string

---

### DEFAULT

CFG\_TB\_E

---

### DESCRIPTION

The value you specify for the **vhdlout\_top\_configuration\_name** variable determines the name of the configuration statement the **write -f vhdl** command writes out, when the **vhdlout\_write\_top\_configuration** variable is set to **true**.

---

### SEE ALSO

[write\(2\)](#)  
[vhdlout\\_top\\_configuration\\_entity\\_name\(3\)](#)  
[vhdlout\\_write\\_top\\_configuration\(3\)](#)

---

## **vhdlout\_top\_design\_vector**

Affects the way in which the **write -f vhdl** command writes out ports on the top-level design.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false

---

### **DESCRIPTION**

The value you specify for the **vhdlout\_top\_design\_vector** variable determines the way in which the **write -f vhdl** command writes out ports on top-level designs.

By default, all ports on top-level designs are written out with their original data types.

If you set the value of this variable to **true**, all ports on top-level designs are written as bused ports, which means the ports keep their names and are not bit-blasted. The ports are written with the type you define using the **vhdlout\_bit\_vector\_type** variable or, for single-bit ports, using the **vhdlout\_bit\_type** variable.

Bus ranges are always in ascending order beginning with 0, regardless of the range description in the original VHDL. If you set this variable to **true**, you must ensure that **vhdlout\_bit\_vector\_type** is an array type whose elements are of **vhdlout\_bit\_type**.

Note that if **vhdlout\_follow\_vector\_direction** is set to **true**, the value of the **vhdlout\_top\_design\_vector** variable is automatically set to **true**.

---

### **SEE ALSO**

**write(2)**  
**vhdlout\_bit\_type(3)**  
**vhdlout\_bit\_vector\_type(3)**  
**vhdlout\_follow\_vector\_direction(3)**  
**vhdlout\_lower\_design\_vector(3)**

---

## vhdlout\_unconnected\_pin\_prefix

Affects the way in which the **write -f vhdl** command writes out unconnected pin names.

---

### TYPE

string

---

### DEFAULT

n

---

### DESCRIPTION

The **vhdlout\_unconnected\_pin\_prefix** variable affects the way in which the **write -f vhdl** command writes out unconnected pin names. You can set the value to any string, but to work with the **change\_names** command's default naming prefix, the recommended value for this variable is **SYNOPSYS\_UNCONNECTED\_**.

---

### SEE ALSO

[write\(2\)](#)  
[vhdlout\\_dont\\_create\\_dummy\\_nets\(3\)](#)

---

## **vhdlout\_unknown\_name**

Specifies the value the tool is to use to drive a signal to the "unknown" state.

---

### **TYPE**

string

---

### **DEFAULT**

'X'

---

### **DESCRIPTION**

The **vhdlout\_unknown\_name** variable specifies the value the tool is to use to drive a signal to the "unknown" state.

---

### **SEE ALSO**

[vhdlout\\_one\\_name\(3\)](#)  
[vhdlout\\_three\\_state\\_name\(3\)](#)  
[vhdlout\\_zero\\_name\(3\)](#)

---

## **vhdlout\_upcase**

This variable is obsolete.

---

## vhdlout\_use\_packages

Instructs the **write -f vhdl** command to write into the VHDL file a "use clause" that contains a list of package names for each of the packages described in this man page, for all entities.

---

### TYPE

list

---

### DEFAULT

IEEE.std\_logic\_1164

---

### DESCRIPTION

This variable instructs the **write -f vhdl** command to write into the VHDL file a use clause containing a list of package names, for each of the packages this man page describes, for all entities.

The **write -f vhdl** command also writes out clauses called "library clauses" as needed. If this variable is set to an empty list (""), the variable has no effect on the **write -f vhdl** command, and library clauses are not written out.

The process by which each package is printed out depends on the number of dots (.) in the package name, as follows:

- No dots prepends "work." and appends ".all" to the name.
- One dot appends ".all" to the name.
- Two dots simply prints the package name.

For example:

```
types      ==> library work  use work.types.all
my.types   ==> library my    use my.types.all
my.types.and ==> library my  use my.types.and
```

---

## SEE ALSO

`write(2)`

---

## **vhdlout\_wired\_and\_res\_func**

Specifies the name of a "wired and" resolution function.

---

### **TYPE**

string

---

### **DEFAULT**

""

---

### **DESCRIPTION**

The **vhdlout\_wired\_and\_res\_func** variable specifies the name of a "wired and" resolution function. The name of this user-supplied function must be included in one of the packages the **vhdlout\_use\_packages** variable specifies. If this variable is set to an empty string, a default "wired and" resolution function is written out, if needed.

---

### **SEE ALSO**

[vhdlout\\_three\\_state\\_res\\_func\(3\)](#)  
[vhdlout\\_use\\_packages\(3\)](#)  
[vhdlout\\_wired\\_or\\_res\\_func\(3\)](#)

---

## **vhdlout\_wired\_or\_res\_func**

Specifies the name of a "wired or" resolution function.

---

### **TYPE**

string

---

### **DEFAULT**

""

---

### **DESCRIPTION**

The **vhdlout\_wired\_or\_res\_func** variable specifies the name of a "wired or" resolution function. The name of this user-supplied function must be included in one of the packages the **vhdlout\_use\_packages** variable specifies. If this variable is set to an empty string, a default "wired or" resolution function is written out, if needed.

---

### **SEE ALSO**

[vhdlout\\_three\\_state\\_res\\_func\(3\)](#)  
[vhdlout\\_use\\_packages\(3\)](#)  
[vhdlout\\_wired\\_and\\_res\\_func\(3\)](#)

---

## vhdlout\_write\_architecture

Instructs the **write -format vhdl** command to write out architecture declarations.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

The **vhdlout\_write\_architecture** variable instructs the **write -format vhdl** command to write out architecture declarations. When set to **false**, no architecture declarations are written.

Use this variable with the **vhdlout\_write\_entity** and **vhdlout\_write\_top\_configuration** variables to control the information the **write -format vhdl** command writes out.

---

### SEE ALSO

[write\(2\)](#)  
[vhdlout\\_write\\_entity\(3\)](#)  
[vhdlout\\_write\\_top\\_configuration\(3\)](#)

---

## vhdlout\_write\_components

Instructs the **write -format vhdl** command to write out component declarations for cells mapped to a technology library.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

The **vhdlout\_write\_components** variable instructs the **write -format vhdl** command to write out component declarations for cells mapped to a technology library.

When set to **false**, no component declarations are written. The VHDL format requires component declarations. If you set this variable to **false**, make sure that the **vhdlout\_use\_packages** variable includes a package containing the necessary component declarations.

---

### SEE ALSO

`write(2)`  
`vhdlout_use_packages(3)`

---

## vhdlout\_write\_entity

Instructs the **write -format vhdl** command to write out entity declarations.

---

### TYPE

Boolean

---

### DEFAULT

true

---

### DESCRIPTION

The **vhdlout\_write\_entity** variable instructs the **write -format vhdl** command to write out entity declarations.

When set to **false**, no entity declarations are written.

Use this variable with the **vhdlout\_write\_architecture** and **vhdlout\_write\_top\_configuration** variables to control the information the **write -format vhdl** command writes out.

---

### SEE ALSO

`write(2)`  
`vhdlout_write_architecture(3)`  
`vhdlout_write_top_configuration(3)`

---

## vhdlout\_write\_top\_configuration

Instructs the **write -format vhdl** command to write out a configuration statement, if necessary, such as when ports on the top-level design are written as vectors instead of user types.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

The **vhdlout\_write\_top\_configuration** variable to instructs the **write -format vhdl** command to write out a configuration statement, if necessary, such as when ports on the top-level design are written as vectors instead of user types. The port map of the configuration statement contains calls to type conversion functions.

For more information, see the man pages for the **vhdlout\_single\_bit** and **vhdlout\_preserve\_hierarchical\_types** variables.

By default, the tool does not write out a configuration statement.

The configuration statement binds the (written out) top-level design to an entity and architecture outside of the .db file. The outside architecture is assumed to instantiate as a component the written top-level design. An example of an outside architecture is a user-supplied testbench that drives simulation with test vectors.

For example, if the testbench uses user types, but the top-level design's ports are written as vectors, the ports do not interface to the testbench directly because of type mismatches. The use of type conversions in the configuration statement solves this problem. The **write -format vhdl** command does not write a configuration statement for bit-blasted designs.

Inout ports cannot be handled by conversion functions, because there is no way of determining whether to convert for a sink (output) or for a source (input). When **write -format vhdl** encounters an inout port, it checks the netlist. If the port functions as a true bidirectional signal, the tool issues error message VHDL-17. If the inout port functions only as a sink or as a source, **write -format vhdl** creates the correct type conversion.

You can use this variable with the **vhdlout\_write\_architecture** and **vhdlout\_write\_entity** variables to control the information **write -format vhdl** writes out.

---

### SEE ALSO

**write**(2)  
**vhdlout\_preserve\_hierarchical\_types**(3)

```
vhdlout_single_bit(3)
vhdlout_top_configuration_arch_name(3)
vhdlout_top_configuration_entity_name(3)
vhdlout_top_configuration_name(3)
vhdlout_write_architecture(3)
vhdlout_write_entity(3)
```

---

## vhdlout\_zero\_name

Determines the literal name for constant bit value 0 in a design written in VHDL.

---

### TYPE

string

---

### DEFAULT

'0'

---

### DESCRIPTION

The **vhdlout\_zero\_name** variable determines the literal name for the constant bit value 0 in a design written in VHDL.

This variable is useful when your design methodology is based on a more general logic value than BIT. Use this variable with the **vhdlout\_bit\_type** variable.

---

### SEE ALSO

[write\(2\)](#)  
[vhdlout\\_bit\\_type\(3\)](#)  
[vhdlout\\_bit\\_vector\\_type\(3\)](#)  
[vhdlout\\_one\\_name\(3\)](#)  
[vhdlout\\_three\\_state\\_name\(3\)](#)

---

## via\_attributes

Contains attributes related to via.

---

## DESCRIPTION

Contains attributes related to via.

You can use the **get\_attribute** command to determine value of an attribute, and use the **report\_attribute** command to get a report of all attributes on a specified object. List the definitions of attributes using **list\_attribute -class via -application**,

### Via Attributes

#### array\_size

Specifies the array size of a via object. The format is **{col row}**.

The data type of **array\_size** is string.

This attribute is read-only.

#### bbox

Specifies the bounding box of a via. The **bbox** is represented by a **rectangle**.

The format of a **rectangle** specification is  **{{llx lly} {urx ury}}**, which specifies the lower-left and upper-right corners of the rectangle.

The data type of **bbox** is string.

This attribute is read-only.

#### bbox\_ll

Specifies the lower-left corner of the bounding box of a via.

The **bbox\_ll** is represented by a **point**. The format of a **point** specification is **{x y}**.

You can get the **bbox\_ll** of a via by accessing the first element of its **bbox**.

The data type of **bbox\_ll** is string.

This attribute is read-only.

#### bbox\_llx

Specifies the x coordinate of the lower-left corner of the bounding box of a via.

The data type of **bbox\_llx** is integer.

This attribute is read-only.

#### bbox\_lly

Specifies the y coordinate of the lower-left corner of the bounding box of a via.

The data type of **bbox\_lly** is integer.

This attribute is read-only.

**bbox\_ur**

Specifies the upper-right corner of the bounding box of a via.

The **bbox\_ur** is represented by a **point**. The format of a *point* specification is {x y}.

You can get the **bbox\_ur** of a via, by accessing the second element of its **bbox**.

The data type of **bbox\_ur** is string.

This attribute is read-only.

**bbox\_urx**

Specifies the x coordinate of the upper-right corner of the bounding box of a via.

The data type of **bbox\_urx** is integer.

This attribute is read-only.

**bbox\_ury**

Specifies the y coordinate of the upper-right corner of the bounding box of a via.

The data type of **bbox\_ury** is integer.

This attribute is read-only.

**cell\_id**

Specifies the Milkyway design ID in which a via object is located.

The data type of **cell\_id** is integer.

This attribute is read-only.

**center**

Specifies the center position of a via object.

The data type of **center** is string.

This attribute is read-only.

**col**

Specifies the number of horizontal columns of a via object.

The data type of **col** is integer.

This attribute is read-only.

**is\_via\_ladder**

Specifies the via ladder is true or not.

The data type of **is\_via\_ladder** is boolean.

This attribute is writable.

**layer**

Specifies the layer name list with which a via object is associated. The format is {**via\_layer lower\_layer upper\_layer**}.

The data type of **layer** is string.

This attribute is read-only.

**lower\_layer**

Specifies the lower layer name.

The data type of **lower\_layer** is string.

This attribute is read-only.

#### lower\_layer\_double\_pattern\_mask\_constraint

Specifies the coloring information for lower layer of the via. This information is needed in the double patterning flow.

The data type of **lower\_layer\_double\_pattern\_mask\_constraint** is string.

The following values are valid:

- **any\_mask**
- **mask1\_soft**
- **mask1\_hard**
- **mask2\_soft**
- **mask2\_hard**
- **same\_mask**

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### lower\_layer\_multiple\_pattern\_mask\_constraint

Specifies the coloring information for lower layer of the via. This information is needed in the multiple patterning flow.

The data type of **lower\_layer\_multiple\_pattern\_mask\_constraint** is string.

The following values are valid:

- **any\_mask**
- **mask1\_soft**
- **mask1\_hard**
- **mask2\_soft**
- **mask2\_hard**
- **mask3\_soft**
- **mask3\_hard**
- **same\_mask**

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### name

Specifies the name of a via object.

The data type of **name** is string.

This attribute is read-only.

#### net\_id

Specifies the object ID of the net associated with a via object.

The data type of **net\_id** is integer.

This attribute is writable. Use the **set\_attribute** command to modify its value on a specified object.

#### net\_type

Specifies the type of net associated with a via object.

The data type of **net\_type** is string.

This attribute is read-only.

#### object\_class

Specifies the object class name of a via object, which is **via**.

The data type of **object\_class** is string.

This attribute is read-only.

#### object\_id

Specifies the object ID in a Milkyway design file.

The data type of **object\_id** is integer.

This attribute is read-only.

#### object\_type

Specifies the object type name, which can be **via**, **via\_array**, or **via\_cell**.

The data type of **object\_type** is string.

This attribute is read-only.

#### orientation

Specifies the orientation of a via object.

The data type of **orientation** is string.

The following values are valid:

- **N**
- **E**
- **S**
- **W**
- **FN**
- **FE**
- **FS**
- **FW**

This attribute is writable. Use the **set\_attribute** command to modify its value on a specified object. However, when the object type is **via\_cell**, you cannot change its **orientation**.

#### owner

Specifies the Milkyway design file name in which a via is located.

The data type of **owner** is string.

This attribute is read-only.

#### owner\_net

Specifies the net name to which a via is connected.

The data type of **owner\_net** is string.

This attribute is writable. Use the **set\_attribute** command to modify its value on a specified object.

#### route\_type

Specifies the route type of a via.

The data type of **route\_type** is string.

The following values are valid:

- User Enter or **user\_enter**
- Signal Route or **signal\_route**
- Signal Route (Global) or **signal\_route\_global**
- P/G Ring or **pg\_ring**
- Clk Ring or **clk\_ring**
- P/G Strap or **pg\_strap**
- Clk Strap or **clk\_strap**
- P/G Macro/IO Pin Conn or **pg\_macro\_io\_pin\_conn**
- P/G Std. Cell Pin Conn or **pg\_std\_cell\_pin\_conn**
- Zero-Skew Route or **clk\_zero\_skew\_route**
- Bus or **bus**
- Shield (fix) or **shield**
- Shield (dynamic) or **shield\_dynamic**
- Fill Track or **clk\_fill\_track**
- Unknown or **unknown**

The Tcl variable **mw\_attr\_value\_no\_space** determines whether **get\_attribute** or **report\_attribute** returns route\_type containing spaces or underscores.

This attribute is writable. Use the **set\_attribute** command to modify its value on a specified object.

#### row

Specifies the number of vertical rows in a via object.

The data type of **row** is integer.

This attribute is read-only.

#### upper\_layer

Specifies the upper layer name.

The data type of **upper\_layer** is string.

This attribute is read-only.

#### upper\_layer\_double\_pattern\_mask\_constraint

Specifies the coloring information for upper layer of the via. This information is needed in the double patterning flow.

The data type of **upper\_layer\_double\_pattern\_mask\_constraint** is string.

The following values are valid:

- **any\_mask**
- **mask1\_soft**
- **mask1\_hard**
- **mask2\_soft**
- **mask2\_hard**
- **same\_mask**

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**upper\_layer\_multiple\_pattern\_mask\_constraint**

Specifies the coloring information for upper layer of the via. This information is needed in the multiple patterning flow.

The data type of **upper\_layer\_multiple\_pattern\_mask\_constraint** is string.

The following values are valid:

- **any\_mask**
- **mask1\_soft**
- **mask1\_hard**
- **mask2\_soft**
- **mask2\_hard**
- **mask3\_soft**
- **mask3\_hard**
- **same\_mask**

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**via\_layer**

Specifies the via layer name.

The data type of **via\_layer** is string.

This attribute is writable. Use the **set\_attribute** command to modify its value on a specified object.

**via\_layer\_double\_pattern\_mask\_constraint**

Specifies the coloring information for via layer of the via. This information is needed in the double patterning flow.

The data type of **via\_layer\_double\_pattern\_mask\_constraint** is string.

The following values are valid:

- **any\_mask**
- **mask1\_soft**
- **mask1\_hard**
- **mask2\_soft**
- **mask2\_hard**
- **same\_mask**

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

**via\_layer\_multiple\_pattern\_mask\_constraint**

Specifies the coloring information for via layer of the via. This information is needed in the multiple patterning flow.

The data type of **via\_layer\_multiple\_pattern\_mask\_constraint** is string.

The following values are valid:

- **any\_mask**
- **mask1\_soft**
- **mask1\_hard**
- **mask2\_soft**
- **mask2\_hard**
- **mask3\_soft**
- **mask3\_hard**
- **same\_mask**

This attribute is writable. You can use **set\_attribute** to modify its value on a specified object.

#### via\_master

Specifies the via master's name defined in the library's technology file; for via\_cell, it is the library cell's name.

The data type of **via\_master** is string.

This attribute is writable. Use the **set\_attribute** command to modify its value on a specified object.

#### x\_pitch

Specifies the center-to-center spacing of a via object in the horizontal direction.

The data type of **x\_pitch** is float.

This attribute is writable. Use the **set\_attribute** command to modify its value on a specified object.

#### y\_pitch

Specifies the center-to-center spacing of a via object in the vertical direction.

The data type of **y\_pitch** is float.

This attribute is writable. Use the **set\_attribute** command to modify its value on a specified object.

---

## SEE ALSO

`get_attribute(2)`  
`list_attributes(2)`  
`report_attribute(2)`  
`set_attribute(2)`  
`mw_attr_value_no_space(3)`

---

## via\_region\_attributes

Contains attributes related to via region.

---

## DESCRIPTION

Contains attributes related to via region.

You can use **get\_attribute** to determine value of an attribute, and use **report\_attribute** to get a report of all attributes on specified object. Specified with **list\_attribute -class via\_region -application**, the definition of attributes can be listed.

### Via Region Attributes

**bbox**

Specifies the bounding-box of a via region. The **bbox** is represented by a **rectangle**.

The format of a *rectangle* specification is {{llx lly} {urx ury}}, which specifies the lower-left and upper-right corners of the rectangle.

The data type of **bbox** is string.

This attribute is read-only.

**bbox\_ll**

Specifies the lower-left corner of the bounding-box of a via region.

The **bbox\_ll** is represented by a **point**. The format of a *point* specification is {x y}.

You can get the **attr\_name** of a via region, by accessing the first element of its**bbox**.

The data type of **bbox\_ll** is string.

This attribute is read-only.

**bbox\_llx**

Specifies x coordinate of the lower-left corner of the bounding-box of a via region.

The data type of **bbox\_llx** is double.

This attribute is read-only.

**bbox\_lly**

Specifies y coordinate of the lower-left corner of the bounding-box of a via region.

The data type of **bbox\_lly** is double.

This attribute is read-only.

**bbox\_ur**

Specifies the upper-right corner of the bounding-box of a via region.

The **bbox\_ur** attribute is represented by a point. The format of a point specification is {x y}.

You can get the **bbox\_ur** of a via region, by accessing the second element of its**bbox**.

The data type of **bbox\_ur** is string.

This attribute is read-only.

#### bbox\_urx

Specifies x coordinate of the upper-right corner of the bounding-box of a via region.

The data type of **bbox\_urx** is double.

This attribute is read-only.

#### bbox\_ury

Specifies y coordinate of the upper-right corner of the bounding-box of a via region.

The data type of **bbox\_ury** is double.

This attribute is read-only.

#### cell\_id

Specifies Milkyway design ID in which a via region object is located.

The data type of **cell\_id** is integer.

This attribute is read-only.

#### name

Specifies name of a via region object.

The data type of **name** is string.

This attribute is read-only.

#### number\_of\_points

Specifies the number of points to illustrate the boundary of a via region object.

The data type of **number\_of\_points** is integer.

You can refer to the attribute **points**. The list length of **points** is the value of **number\_of\_points**.

This attribute is read-only.

#### object\_class

Specifies object class name of a via region, which is **via\_region**.

The data type of **object\_class** is string.

This attribute is read-only.

#### object\_id

Specifies object ID in Milkyway design file.

The data type of **object\_id** is integer.

This attribute is read-only.

#### owner\_port

Specifies port name which a via region object is associated with.

The data type of **owner\_port** is string.

This attribute is read-only.

**points**

Specifies points of the boundary of a via region. A via region can be a rectangle, a rectilinear polygon, or multiple rectangles.

When a via region is either a rectangle or a rectilinear polygon, its **points** is represented by a list of points. The last element of the list is the same as the first element.

When a via region consists of multiple rectangles, its **points** is represented by a list of points of rectangles. Every five points represent one rectangle.

The data type of **points** is string.

This attribute is read-only.

**is\_rotate90**

Specifies whether a via region is used for the contactCode object who is rotated 90 degree.

The data type of **is\_rotate90** is boolean.

This attribute is read-only.

**via\_master**

Specifies the name of the via master associated with a via region object.

The data type of **via\_master** is string.

This attribute is read-only.

---

## SEE ALSO

[get\\_attribute\(2\)](#)  
[list\\_attributes\(2\)](#)  
[report\\_attribute\(2\)](#)

---

## **view\_analyze\_file\_suffix**

Specifies, in a list of file extensions, the files shown in the File/Analyze dialog box of Design Analyzer.

---

### **TYPE**

string

---

### **DEFAULT**

v vhdl in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

Specifies, in a list of file extensions, the files shown in the File/Analyze dialog box of Design Analyzer. The default value is {v, vhdl}.

To determine the current value of this variable, type **printvar view\_analyze\_file\_suffix**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### **SEE ALSO**

---

## **view\_arch\_types**

Sets the contents of the architecture option menu. Contains a list of host machine architectures you can use for background jobs from the Design Analyzer viewer.

---

### **TYPE**

list

---

### **DEFAULT**

sparcOS5 hpx10 rs6000 sgimips in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### **DESCRIPTION**

This variable sets the contents of the architecture option menu. It contains a list of host machine architectures you can use for background jobs from the Design Analyzer viewer.

---

### **SEE ALSO**

---

## view\_background

Specifies the background color of the Design Analyzer viewer.

---

### TYPE

string

---

### DEFAULT

black in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

Specifies the background color of the Design Analyzer viewer. Valid settings are *white* (the default) and *black*.

To determine the current value of this variable, type **printvar view\_background**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### SEE ALSO

---

## **view\_cache\_images**

Specifies to Design Analyzer that the tool is to cache bitmaps for fast schematic drawing.

---

### **TYPE**

string

---

### **DEFAULT**

true in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

Specifies that the tool is to cache bitmaps for fast schematic drawing. The default is *true*.

To determine the current value of this variable, type **printvar view\_cache\_images**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### **SEE ALSO**

---

## **view\_command\_log\_file**

Names a file and its location that is to contain all text written to the Design Analyzer Command window.

---

### **TYPE**

string

---

### **DEFAULT**

`./view_command.log` in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### **DESCRIPTION**

Names a file and its location that is to contain all text written to the Design Analyzer Command window. The default is to set this variable.

To determine the current value of this variable, use **printvar view\_command\_log\_file**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### **SEE ALSO**

`command_log_file(3)`  
`view_log_file(3)`

---

## **view\_command\_win\_max\_lines**

Contains the maximum number of lines to be saved in the Design Analyzer command window.

---

### **TYPE**

integer

---

### **DEFAULT**

1000 in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

Contains the maximum number of lines to be saved in the Design Analyzer command window. When the number of lines of output added to the command window exceed the number this variable specifies, the older lines at the top of the list are removed.

This variable should be set to 1000 or more. Values up to tens of thousands are also useful.

To determine the current value of this variable, type **printvar view\_command\_win\_max\_lines**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### **SEE ALSO**

---

## **view\_dialogs\_modal**

Requires that the question and error dialogs in Design Analyzer be confirmed, before you can continue entering commands.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

Requires that the question and error dialogs in Design Analyzer be confirmed, before you can continue entering commands.

To determine the current value of this variable, use **printvar view\_dialogs\_modal**. For a list of all **view** variables and their current values, type the **print\_variable\_group view**.

---

### **SEE ALSO**

---

## **view\_disable\_cursor\_warping**

Causes the cursor to be automatically "warped" (moved). When *false*, the cursor is automatically "warped" (or moved) to dialog boxes.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

Causes the cursor to be automatically "warped" (moved). When *false*, the cursor is automatically "warped" (or moved) to dialog boxes. The default is *true*.

To determine the current value of this variable, use **printvar view\_disable\_cursor\_warping**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### **SEE ALSO**

---

## **view\_disable\_error\_windows**

Instructs Design Analyzer not to post the error windows when errors occur.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

Instructs Design Analyzer not to post the error windows when errors occur. The default is *false*.

To determine the current value of this variable, type **printvar view\_disable\_error\_windows**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### **SEE ALSO**

---

## **view\_disable\_output**

Disables output to the Design Analyzer command window.

---

### **TYPE**

Boolean

---

### **DEFAULT**

false in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

Disables output to the Design Analyzer command window, when set to *true*. This variable is useful when you run Design Analyzer over slow networks, such as telephone lines. The default value is *false*.

To determine the current value of this variable, type **printvar view\_disable\_output**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### **SEE ALSO**

---

## **view\_error\_window\_count**

Specifies the maximum number of errors Design Analyzer reports for a command.

---

### **TYPE**

integer

---

### **DEFAULT**

6 in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

Specifies the maximum number of errors Design Analyzer reports for a command. The default value is 6. If more than the specified number of errors occurs, you are informed that you can see additional errors in the command window. The error window is suppressed until the end of the command.

To display all errors, set this variable to 0. To display no errors, set this variable to a negative number or set the **view\_disable\_error\_windows** variable to *true*.

To determine the current value of this variable, type **printvar view\_error\_window\_count**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### **SEE ALSO**

[view\\_disable\\_error\\_windows\(3\)](#)

---

## **view\_execute\_script\_suffix**

Displays only files with the stated suffixes, from directories you select in the Execute Script option window of the Setup menu of Design Analyzer.

---

### **TYPE**

list

---

### **DEFAULT**

Variable is not supported in DC Explorer

---

### **DESCRIPTION**

Displays only files with the stated suffixes, from directories you select in the Execute Script option window of the Setup menu of Design Analyzer.

To determine the current value of this variable, type **printvar view\_execute\_script\_suffix**. For a list of all **suffix** variables and their current values, type **print\_variable\_group suffix**.

---

### **SEE ALSO**

---

## **view\_info\_search\_cmd**

Invokes, if set, the online information viewer through the optional menu item On-Line Information.

---

### **TYPE**

string

---

### **DEFAULT**

""

---

### **DESCRIPTION**

Invokes, if set, the online information viewer through the optional menu item On-Line Information. Set the value of this variable to the UNIX path name to the online information viewer.

To determine the current value of this variable, type **printvar view\_info\_search\_cmd**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### **SEE ALSO**

---

## **view\_log\_file**

Specifies the file in which the tool stores events that occur in the viewer.

---

### **TYPE**

string

---

### **DEFAULT**

"" in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

Specifies the file in which the tool stores events that occur in the viewer. This variable is useful for error reporting. You can execute this variable with the Execute Script option of the Setup menu, or insert the file, using the **include** command in Design Analyzer.

To determine the current value of this variable, type **printvar view\_log\_file**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### **SEE ALSO**

---

## **view\_on\_line\_doc\_cmd**

Invokes, if set, the online documentation viewer, through the optional menu item On-Line Documentation.

---

### **TYPE**

string

---

### **DEFAULT**

""

---

### **DESCRIPTION**

Invokes, if set, the online documentation viewer, through the optional menu item On-Line Documentation. Set the value of this variable to the UNIX command to invoke the online documentation view: for example, /vobs/snps/synopsys/sold.

To determine the current value of this variable, type **printvar view\_on\_line\_doc\_cmd**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### **SEE ALSO**

---

## **view\_read\_file\_suffix**

Displays only files with the stated suffixes, from directories you select with the Read option of the File menu of Design Analyzer.

---

### **TYPE**

list

---

### **DEFAULT**

db gdb sdb edif eqn fnc lsi mif NET pla st tdl v vhd vhdl xnf

---

### **DESCRIPTION**

Displays only files with the stated suffixes, from directories you select with the Read option of the File menu of Design Analyzer.

To determine the current value of this variable, type **printvar view\_read\_file\_suffix**. For a list of all **suffix** variables and their current values, type **print\_variable\_group suffix**.

---

### **SEE ALSO**

---

## **view\_script\_submenu\_items**

Allows users to add to the Design Analyzer Setup pulldown menu valid items to invoke user scripts.

---

### **TYPE**

string

---

### **DEFAULT**

"DA to SGE Transfer" write\_sge in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

Allows users to add to the Design Analyzer Setup pulldown menu valid items to invoke user scripts. The variable should contain a list of strings, grouped into pairs. The first member of the pair is the text that will appear in the submenu. The second member is the string that gets sent to the dc\_shell command line for execution. You can use any valid dc\_shell command sequence.

For example,

```
view_script_submenu_items = {"List", "list_instances", "ls", "sh ls -IR", "Update", "include update.dcsh"}
```

creates a submenu under the Scripts menu item on the Setup pulldown menu. The submenu contains the strings List, ls, and Update. Selecting one of these entries executes the commands **list\_instances**, **sh ls -IR**, or **include update.dcsh**, respectively.

The tool reads this variable only at startup time, so any changes after the Design Analyzer is initialized are not reflected.

To determine the current value of this variable, type **list view\_script\_submenu\_items**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### **SEE ALSO**

---

## **view\_set\_selecting\_color**

Specifies the color to use for selecting and zooming.

---

### **TYPE**

string

---

### **DESCRIPTION**

Specifies the color to use for selecting and zooming. You can set this variable in the **.synopsys\_dc.setup** initialization file. Any color in **/usr/lib/X11/rgb.txt** is valid.

To determine the current value of this variable, type **printvar view\_set\_selecting\_color**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### **SEE ALSO**

---

## view\_tools\_menu\_items

Permits partial configuration of the Tools pulldown menu to add a new menu item for invoking user scripts.

---

### TYPE

string

---

### DEFAULT

"" in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

Permits partial configuration of the Tools pulldown menu to add a new menu item for invoking user scripts. This .synopsys\_dc.setup file variable contains a list of strings, grouped into pairs. The first member of the pair is the text that appears in the submenu. The second member is the string that is sent to the dc\_shell command line for execution. You can use any valid dc\_shell command sequence.

For example,

```
view_tools_menu_items = {"List", "list_instances", "ls", "sh ls -IR", "Update", "include update.dcs"}
```

adds three more items to the Tools menu: List, ls, and Update. Selecting one of these entries executes one of the commands. For instance, if you selected **update**, the **include update.dcs** command would be executed.

The tool reads this variable only at start-up time. Any changes after the Design Analyzer is initialized are not reflected.

To determine the current value of this variable, type **printvar view\_tools\_menu\_items**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### SEE ALSO

---

## **view\_use\_small\_cursor**

Specifies to the tool that the X display is to support only 16 x 16-bit map size cursors.

---

### **TYPE**

string

---

### **DEFAULT**

true in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

Specifies to the tool that the X display is to support only 16 x 16-bit map size cursors. To achieve this result, set the value of this variable to *true*. The default is "".

To determine the current value of this variable, type **printvar view\_use\_small\_cursor**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### **SEE ALSO**

---

## **view\_use\_x\_routines**

Enables the use of internal arc-drawing routines (instead of X routines).

---

### **TYPE**

Boolean

---

### **DEFAULT**

true in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **DESCRIPTION**

Enables the use of internal arc-drawing routines (instead of X routines). If there is a math coprocessor chip on the same machine that the X server is on, X arc-drawing routines are faster. Otherwise, internal arc-drawing routines are faster. The default value is *true*.

To determine the current value of this variable, type **printvar view\_use\_x\_routines**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### **SEE ALSO**

---

## **view\_write\_file\_suffix**

Displays only files with the stated suffixes, from directories you select with the Save As option of the File menu of Design Analyzer.

---

### **TYPE**

list

---

### **DEFAULT**

gdb db sdb do edif eqn fnc lsi NET neted pla st tdl v vhd vhdl xnf

---

### **DESCRIPTION**

Displays only files with the stated suffixes, from directories you select with the Save As option of the File menu of Design Analyzer.

To determine the current value of this variable, type **printvar view\_write\_file\_suffix**. For a list of all **suffix** variables and their current values, type **print\_variable\_group suffix**.

---

### **SEE ALSO**

---

# voltage\_area\_attributes

---

## DESCRIPTION

This man page describes the attributes related to voltage areas.

You can use the **get\_attribute** command to determine the value of an attribute and the **report\_attribute** command to get a report of all the attributes on a specified object.

To see a list of all voltage area attributes, use the **list\_attributes -application -class voltage\_area** command.

### Voltage Area Attributes

**bbox**

Specifies the bounding box of a voltage area.

The bounding box is represented by a rectangle. The format of a rectangle specification is  $\{\{llx\} \{lly\} \{urx\} \{ury\}\}$ , which specifies the lower-left and upper-right corners of the rectangle.

The data type of **bbox** is string.

This attribute is read-only.

**bbox\_ll**

Specifies the lower-left corner of the bounding box of a voltage area.

The **bbox\_ll** is represented by a point. The format of a point specification is  $\{x\} \{y\}$ .

You can get the **bbox\_ll** of a voltage area by accessing the first element of its **bbox**.

The data type of **bbox\_ll** is string.

This attribute is read-only.

**bbox\_llx**

Specifies the x-coordinate of the lower-left corner of the bounding box of a voltage area.

The data type of **bbox\_llx** is double.

This attribute is read-only.

**bbox\_lly**

Specifies the y-coordinate of the lower-left corner of the bounding box of a voltage area.

The data type of **bbox\_lly** is double.

This attribute is read-only.

**bbox\_ur**

Specifies the upper-right corner of the bounding box of a voltage area.

The **bbox\_ur** is represented by a point. The format of a point specification is  $\{x\} \{y\}$ .

You can get the **bbox\_ur** of a voltage area by accessing the second element of its **bbox**.

The data type of **bbox\_ur** is string.

This attribute is read-only.

#### bbox\_urx

Specifies the x-coordinate of the upper-right corner of the bounding box of a voltage area.

The data type of **bbox\_urx** is double.

This attribute is read-only.

#### bbox\_ury

Specifies the y-coordinate of the upper-right corner of the bounding box of a voltage area.

The data type of **bbox\_ury** is double.

This attribute is read-only.

#### cell\_id

Specifies the identification number of the Milkyway design in which the voltage area object is located.

The data type of **cell\_id** is integer.

This attribute is read-only.

#### color

Specifies the color for a voltage area and its leaf cells.

The data type of **color** is string.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

#### guardband

Specifies the guardband spacing around a voltage area.

Its format is {**guardband\_x** **guardband\_y**}.

The guardband is the spacing along the boundary of a voltage area where cells cannot be placed because of the lack of power supply rails.

The data type of **guardband** is string.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

#### guardband\_x

Specifies the guardband width in the horizontal direction.

The data type of **guardband\_x** is float.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

#### guardband\_y

Specifies the guardband width in the vertical direction.

The data type of **guardband\_y** is float.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

#### is\_fixed

Specifies whether a voltage area is in a fixed location and therefore ignored during shaping.

The data type of **is\_fixed** is Boolean.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

#### max\_buffer\_distance

Specifies maximum net length that is allowed to be routed in the particular voltage area. The virtual router and Zroute global router honor it.

The data type of **max\_buffer\_distance** is float and the unit is microns.

This attribute is writable. You can use the **set\_attribute** command to modify its value on a specified object.

#### modules

Specifies the collection of top node cells inside a voltage area.

The data type of **modules** is collection.

This attribute is read-only.

#### name

Specifies the name of a voltage area object.

The data type of **name** is string.

This attribute is read-only.

#### object\_class

Specifies the object class name of a voltage area, which is **voltage\_area**.

The data type of **object\_class** is string.

This attribute is read-only.

#### object\_id

Specifies the object identification number in the Milkyway design database.

The data type of **object\_id** is integer.

This attribute is read-only.

#### points

Specifies the point list of the voltage area's boundary.

The data type of **points** is string.

This attribute is read-only.

#### utilization

Specifies the utilization of a voltage area, the fraction of the area that is occupied by cells.

The data type of **utilization** is float.

This attribute is read-only.

#### within\_block\_abstraction

Specifies whether the voltage area is part of a block abstraction model.

The data type of **within\_block\_abstraction** is Boolean.

This attribute is read-only and cannot be modified.

#### within\_ilm

Specifies whether the voltage area is part of an interface logic model (ILM).

The data type of **within\_ilm** is Boolean.

This attribute is read-only and cannot be modified.

---

## SEE ALSO

[create\\_voltage\\_area\(2\)](#)  
[get\\_attribute\(2\)](#)  
[list\\_attributes\(2\)](#)  
[report\\_attribute\(2\)](#)  
[set\\_attribute\(2\)](#)

---

# wildcards

Describes supported wildcard characters and ways in which they can be escaped.

---

## DESCRIPTION

The following characters are supported as wildcards:

- Asterisks (\*) substitute for a string of characters of any length.
- Question marks (?) substitute for a single character.

The following commands support wildcard characters:

```
get_cells  
get_clocks  
get_designs  
get_lib_cells  
get_lib_pins  
get_libs  
get_multibits  
get_nets  
get_pins  
get_ports  
get_references  
list_designs  
list_instances  
list_libs  
trace_nets  
untrace_nets
```

In addition to these commands, commands that perform an implicit get also support the wildcarding feature.

### Escaping Wildcards

Wildcard characters must be escaped using double backslashes (\\\) to remove their special regular expression meaning. See the EXAMPLES section for more information.

### Escaping Escape Character (\\\)

This is similar to that of escaping wildcard characters, but needs one escape character each to escape the escape character. See the EXAMPLES section for more information.

---

## EXAMPLES

The following are examples of using wildcard characters.

### Using Wildcards

The following example gets all nets in the current design that are prefixed by in and followed by any two characters:

```
prompt> get_nets in??
{"in11" "in21"}
```

The following example gets all cells in the current design that are prefixed by U and followed by a string of characters of any length:

```
prompt> get_cells U*
 {"U1" "U2" "U3" "U4"}
```

## Escaping Wildcards

The following are examples of escaping wildcard characters.

The following example gets design test?1 in the system.

```
prompt> get_designs {test\?1}
 {"test?1"}
```

The same example can be written using the Tcl **list** command:

```
prompt> get_designs [list {test\?1}]
 {"test?1"}
```

If neither curly braces nor the **list** command is used, the syntax is as follows:

```
prompt> get_designs test\\\\\\?1
 {"test?1"}
```

## Escaping Escape Character (\\\\")

The following are examples of escaping an escape character.

The following example finds design test\\1 in the system.

```
prompt> get_designs {test\\\\\\1}
 {"test\\1"}
```

The same above example can written using the Tcl **list** command:

```
prompt> get_designs [list {test\\\\\\1}]
 {"test\\1"}
```

If neither curly braces nor the **list** command is used, the syntax is as follows:

```
prompt> get_designs test\\\\\\\\\\\\\\1
 {"test\\1"}
```

---

## writeConvertedTfSyntax

Controls whether the **write\_mw\_lib\_files** command writes out the converted rule tables when the technology file uses the alternative syntax for area-based fat metal contact rules and fat metal extension contact rules.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable controls the syntax used by the **write\_mw\_lib\_files** command for the area-based fat metal contact rules and fat metal extension contact rules when these rules are defined in the technology file using the alternative syntax.

The alternative syntax defines these rules by using the enclosureTbl and minCutsTbl tables in the Layer section of the technology file. Internally, the tool converts these rules to ContactCode sections and via rules in the Layer section.

By default, the **write\_mw\_lib\_files** command writes these rules using the syntax from the input technology file. If you set this variable to **true**, the **write\_mw\_lib\_files** command writes these rules using the internally-derived syntax (the Contact Code sections and via rules in the Layer sections).

For details about the technology file syntax for these rules, see the *IC Compiler Technology File and Routing Rules Reference Manual*.

---

### SEE ALSO

[write\\_mw\\_lib\\_files\(2\)](#)

---

## write\_name\_nets\_same\_as\_ports

Specifies to the tool that nets are to receive the same names as the ports to which the nets are connected.

---

### TYPE

Boolean

---

### DEFAULT

false

---

### DESCRIPTION

This variable specifies to the tool that nets are to receive the same names as the ports to which the nets are connected. This variable affects nets in design descriptions written in EDIF, LSI, or TDL format. (Other nets might be renamed to avoid creating shorts.)

Note that in the EDIF format, even if the **edifout\_power\_and\_ground\_representation** variable is set to **port**, the power and ground nets will not be named the same as the power and ground ports that are written in the interface construct of each cell construct.

Net names in the design database are unchanged; that is, only the file being written out is affected and not the original design data.

---

### SEE ALSO

---

## **write\_sdc\_output\_lumped\_net\_capacitance**

Determines whether or not the **write\_sdc** and **write\_script** commands output net loads.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true

---

### **DESCRIPTION**

This variable instructs the **write\_sdc** and **write\_script** commands to output net loads when set to **true**.

When set to **false**, **write\_sdc** and **write\_script** do not output net loads. The net loads are output through **set\_load** command statements during **write\_sdc** and **write\_script**.

By default all net loads are output during **write\_sdc** and **write\_script** execution.

---

### **SEE ALSO**

**set\_load(2)**  
**write\_sdc(2)**  
**write\_script(2)**

---

## **write\_sdc\_output\_net\_resistance**

Determines whether or not the **write\_sdc** and **write\_script** commands output net resistance.

---

### **TYPE**

Boolean

---

### **DEFAULT**

true

---

### **DESCRIPTION**

This variable instructs the **write\_sdc** and **write\_script** commands to output net resistance. When set to false, **write\_sdc** and **write\_script** do not output net resistance. The net resistances are output through **set\_resistance** statements during **write\_sdc** and **write\_script**.

By default, all net resistances are output during **write\_sdc** and **write\_script** execution.

---

### **SEE ALSO**

`set_resistance(2)`  
`write_sdc(2)`  
`write_script(2)`

---

## write\_test\_formats

Specifies the test vector formats recognized and created by the **write\_test** command.

---

### TYPE

list

---

### DEFAULT

synopsys tssi\_ascii tds verilog vhdl wgl

---

### DESCRIPTION

This variable specifies the test vector formats recognized and created by the **write\_test** command.

---

### SEE ALSO

[write\\_test\(2\)](#)

---

## **write\_test\_include\_scan\_cell\_info**

Specifies to the **write\_test** command to include in the vector files scan-chain, cell, and inversion information for vector formats.

---

### **TYPE**

string

---

### **DEFAULT**

true

---

### **DESCRIPTION**

This variable instructs the **write\_test** command to include in the vector files scan-chain, cell, and inversion information for vector formats.

For a simulator to execute a parallel load of scan chains, it is necessary to establish the instance names of all elements in the scan registers and to know whether there is inversion between each element and the scan-data input or output. This is the information that **write\_test** includes by default.

To exclude the information from the vector files, set the **write\_test\_include\_scan\_cell\_info** variable to **false**.

---

### **SEE ALSO**

[write\\_test\(2\)](#)

---

## write\_test\_input\_dont\_care\_value

Controls the logic value that the **write\_test** command outputs when you have an input with a don't care condition.

---

### TYPE

string

---

### DEFAULT

X

---

### DESCRIPTION

This variable controls the logic value that the **write\_test** command outputs when you have an input with a don't care condition.

For example, in a design with multiple scan chains of unequal lengths, the serial input streams for the shorter chains need to be padded with arbitrary logic values.

This variable can have the value **1**, **0**, **X** or **x**. These values correspond to a don't care condition of logic 1, logic 0, or logic don't care, respectively. The default is **don't care (X)**.

For test equipment or test vector formats that do not support an input don't care value, use this variable to assign logic 1 or logic 0.

---

### SEE ALSO

[write\\_test\(2\)](#)

---

## **write\_test\_max\_cycles**

Controls the automatic partitioning of long test sets across multiple files by specifying the maximum number of tester cycles any one vector file can contain.

---

### **TYPE**

integer

---

### **DEFAULT**

0

---

### **DESCRIPTION**

This variable controls the automatic partitioning of long test sets across multiple files by specifying the maximum number of tester cycles any one vector file can contain. One tester cycle corresponds to one cycle of parallel (nonshift) operation of the device under test or to the shifting of scan data one bit in the scan chains.

Each vector file is self-contained; that is, the vectors within a specific file are independent of the state of the device under test and specifically do not require the vectors in other files to have been previously applied. This implies that **write\_test\_max\_cycles** is used only for full-scan designs, and that test sets are not partitioned for partial scan designs. Additionally, the partitioning of the vector set has no effect on fault coverage.

By default, this variable is set to **0**, which implies there are no limits. Thus, automatic file partitioning is not performed. Work with your ASIC vendors to determine an appropriate value.

---

### **SEE ALSO**

[write\\_test\\_max\\_scan\\_patterns\(3\)](#)  
[write\\_test\\_vector\\_file\\_naming\\_style\(3\)](#)

---

## write\_test\_max\_scan\_patterns

Controls the automatic partitioning of long test sets across multiple files, by specifying the maximum number of scan test patterns any one vector file can contain.

---

### TYPE

integer

---

### DEFAULT

0

---

### DESCRIPTION

This variable controls the automatic partitioning of long test sets across multiple files, by specifying the maximum number of scan test patterns any one vector file can contain. The application of a scan test pattern encompasses the serial loading and unloading of the scan chains and consumes many tester cycles. Typically this correlates directly to the number of scan test patterns the **create\_test\_patterns** command generates. For designs with multiple system clocks, however, it might be necessary to repeat a number of times the application of each scan test pattern.

Each vector file is self-contained; that is, the vectors within a specific file are independent of the state of the device under test and do not require the vectors in other files to have been previously applied. This implies that **write\_test\_max\_scan\_patterns** is used only for full-scan designs, and that test sets are not partitioned for partial-scan designs. Additionally, the partitioning of the vector set has no effect on fault coverage for full-scan designs.

By default, this variable is set to **0**, which implies there are no limits. Thus, automatic file partitioning is not performed. Work with your ASIC vendors to determine an appropriate value. Setting this variable to any value less than 2 results in no file partitioning.

---

### SEE ALSO

[write\\_test\\_max\\_cycles\(3\)](#)  
[write\\_test\\_vector\\_file\\_naming\\_style\(3\)](#)

---

## **write\_test\_pattern\_set\_naming\_style**

Specifies how to name pattern sets when long test sets are partitioned across multiple files.

---

### **TYPE**

string

---

### **DEFAULT**

TC\_Syn\_%d

---

### **DESCRIPTION**

This variable specifies how to name pattern sets when long test sets are partitioned across multiple files. The pattern set name is a documentation aid and appears inside a comment header in the vector files.

The value of this variable is a format string containing one `%d` token that corresponds to the file number index. The file number index starts at 0 and, if the test set is partitioned, is incremented by 1 as additional files are needed.

---

### **SEE ALSO**

---

## **write\_test\_round\_timing\_values**

Specifies to the **write\_test** command to round all timing values to the nearest integer.

---

### **TYPE**

string

---

### **DEFAULT**

true

---

### **DESCRIPTION**

This variable specifies to the **write\_test** command to round all timing values to the nearest integer. The values are input delay, output strobe time, bidir delay, clock period, and clock edge times.

If you do not want the timing values to be rounded to the nearest integer, set the value of this variable to **false**.

When this variable is set to **false**, the maximum resolution of the timing values generated by **write\_test** is 0.01. For finer resolution, change the time units (for example, from ns to ps).

---

### **SEE ALSO**

[write\\_test\(2\)](#)

---

## **write\_test\_scan\_check\_file\_naming\_style**

Specifies how to name the file containing the vectors that test the scan chain logic.

---

### **TYPE**

string

---

### **DEFAULT**

%s\_schk.%s

---

### **DESCRIPTION**

This variable specifies how to name the file containing the vectors that test the scan chain logic.

The value of this variable is a format string containing two %s tokens. The first token pertains to the base name of the file specified by the **-output** option of the **write\_test** command, or the value defaults to the design name. The second token is a file extension based on the targeted vector format, such as .v, for Verilog formatted vectors.

---

### **SEE ALSO**

`write_test(2)`  
`write_test_max_cycles(3)`  
`write_test_max_scan_patterns(3)`

---

## write\_test\_vector\_file\_naming\_style

Specifies how to name scan vector files when long test sets are partitioned across multiple files.

---

### TYPE

string

---

### DEFAULT

%s\_%d.%s

---

### DESCRIPTION

This variable specifies how to name scan vector files when long test sets are partitioned across multiple files.

The value of this variable is a format string containing the %s, %d, and %s tokens, in this exact order. The first token, %s, pertains to the base name of the file specified by the **-output** option of the **write\_test** command, or the value defaults to the design name. The second token, %d, corresponds to the file number index. The file number index starts at 0 and if the test set is partitioned, is incremented by 1 as additional files are needed. The third token, %s, is a file extension based on the targeted vector format, such as .v for Verilog formatted vectors.

---

### SEE ALSO

`write_test(2)`  
`write_test_max_cycles(3)`  
`write_test_max_scan_patterns(3)`

---

## write\_test\_vhdlout

Determines whether the **write\_test -format vhdl** command generates a VHDL test program in TEXTIO format.

---

### TYPE

string

---

### DEFAULT

inline

---

### DESCRIPTION

This variable specifies whether or not the **write\_test -format vhdl** command generates a VHDL test program in TEXTIO format.

If you set the value of this variable as **textio**, the tool writes the VHDL test program in TEXTIO format. If you set the value to **inline** (the default), TEXTIO format is not used.

Compiling a large number of patterns (and placing them in memory) can sometimes cause swapping during simulation. Using TEXTIO format is helpful in such a situation. Both serial load and parallel load testbench generation are supported. To generate a parallel loadable testbench, use the **write\_test -parallel** command.

---

### SEE ALSO

[write\\_test\(2\)](#)

---

## x11\_set\_cursor\_background

Specifies background color of the cursor in the Design Analyzer menus and viewer.

---

### TYPE

string

---

### DEFAULT

"" in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

Specifies background color of the cursor in the Design Analyzer menus and viewer. This variable can be set in the **.synopsis\_dc.setup** initialization file. Any color in **/usr/lib/X11/rgb.txt** is valid.

To determine the current value of this variable, type **printvar x11\_set\_cursor\_background**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### SEE ALSO

---

## x11\_set\_cursor\_foreground

Specifies foreground color of the cursor in the Design Analyzer menus and viewer.

---

### TYPE

string

---

### DEFAULT

magenta

---

### DESCRIPTION

Specifies foreground color of the cursor in the Design Analyzer menus and viewer. This variable can be set in the **.synopsys\_dc.setup** initialization file. Any color in **/usr/lib/X11/rgb.txt** is valid.

To determine the current value of this variable, type **printvar x11\_set\_cursor\_foreground**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### SEE ALSO

---

## x11\_set\_cursor\_number

Specifies the cursor, from the standard X cursor font used by the Design Analyzer menus and viewer.

---

### TYPE

integer

---

### DEFAULT

-1 in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXT non-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

Specifies the cursor, from the standard X cursor font used by the Design Analyzer menus and viewer.

If this variable is not set, or is set to -1 (the default), the cursor in the X background is also used for all windows and menus. Set this variable in the **.synopsys\_dc.setup** initialization file.

To determine the current value of this variable, type **printvar x11\_set\_cursor\_number**. For a list of all **view** variables and their current values, type **print\_variable\_group view**.

---

### SEE ALSO

---

## xt\_filter\_logic\_constant\_aggressors

Affects the behavior of the **report\_noise**, **report\_timing**, and **compile** commands with crosstalk or noise effect enabled. Specifies if logic constant nets should be considered as aggressors in crosstalk and static noise analysis and optimization.

---

### TYPE

Boolean

---

### DEFAULT

true in Design Compiler non-topographical mode, Design Compiler topographical mode, Design Compiler NXTnon-topographical mode, and Design Compiler NXT topographical mode

Variable is not supported in DC Explorer

---

### DESCRIPTION

This variable affects the behavior and correlation of the **report\_noise**, **report\_timing**, and **compile** commands. By default, logic constant aggressors are not included in crosstalk or static noise analysis and optimization. Aggressor nets can be logic constant because they are connected to tie-off cells or because of case analysis. The **case\_analysis\_with\_logic\_constants** timing variable may also determine if an aggressor net is logic constant.

When set to **false**, logic constant aggressors are included in crosstalk or static noise analysis and optimization. To obtain the more accurate behavior of crosstalk timing and static noise analysis, set this variable to **true**.

---

### SEE ALSO

`compile(2)`  
`report_timing(2)`  
`case_analysis_with_logic_constants(3)`

---

## xterm\_executable

Specifies the path to an xterm program spawned to run Synopsys analysis tools (for example, RTL Analyzer).

---

### TYPE

string

---

### DEFAULT

xterm in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode

Variable is not supported in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### DESCRIPTION

This variable specifies the path to an xterm program spawned to run Synopsys analysis tools (for example, RTL Analyzer).

If an xterm is not found in your path, set this variable to point to an xterm executable. For example, if your xterm is not in your \$path, but is located at /usr/bin/X11/xterm, set this variable as follows:

```
prompt> set_app_var xterm_executable {/usr/bin/X11/xterm}
```

---

### SEE ALSO

---

## **zrt\_max\_parallel\_computations**

Sets the maximum degree of parallelism in multicore Zroute.

---

### **TYPE**

integer

---

### **DEFAULT**

Variable is not supported in Design Compiler non-topographical mode and Design Compiler NXT non-topographical mode  
0 in Design Compiler topographical mode, DC Explorer, and Design Compiler NXT topographical mode

---

### **GROUP**

Zroute

---

### **DESCRIPTION**

This application variable specifies the degree of parallelism in multicore Zroute. Increasing parallelism results in reduced runtime.

When set to **0** (the default), the number of cores used for Zroute is specified directly by the value of the **set\_host\_options** command with the **-max\_cores** option value.

When set to **1**, multicore Zroute is disabled.

When the value is smaller than the **-max\_cores** value of the **set\_host\_options** command, the number of cores being used will not exceed this limit.

There is no benefit to setting the value to larger than **-max\_cores**. The actual degree of parallelism (number of processes/threads) will not exceed the value specified here, but may not always be exactly the same. The tool derives the number internally to achieve best performance.

---

### **SEE ALSO**

[set\\_host\\_options\(2\)](#)