

# Synopsys Design Constraints (SDC) Basics

[vlsi-expert.com/2011/02/synopsys-design-constraints-sdc-basics.html](http://vlsi-expert.com/2011/02/synopsys-design-constraints-sdc-basics.html)

**Full form of SDC:** - Synopsys Design Constraints.

**What is SDC:** - SDC is a format used to specify the design intent, including the timing, power and area constraints for a design. SDC is tcl based.

**Tool used this format:** - DC (Design compiler), ICC (IC compiler), Prime Time (PT).

**Information In the SDC:** - There are mainly 4 type of the information.

1. The SDC version (optional)
2. The SDC units (optional)
3. The Design Constraints
4. Comments (Optional)

## 1. SDC version:

Variable name: sdc\_version  
E.g:- set sdc\_version  
Default Version: 1.9

## 2. SDC units:

Command name: set\_units  
Description: using above command you can specify the units for capacitance, resistance, time, voltage, current, and power  
E.g:  
set\_units -capacitance cap\_unit -resistance res\_unit \  
-time time\_unit -voltage voltage\_unit \  
-current current\_unit -power power\_unit

## 3. Design Constraints:

You can specify design constraints using Synopsys constraints commands. (Note: If you want to know further details of each and every constraints- Please refer the [Design Constraint Blog](#))

| Type of information  | Commands                 |
|----------------------|--------------------------|
| Operating conditions | set_operating_conditions |

|                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Wire load models                                | <code>set_wire_load_min_block_size</code><br><code>set_wire_load_mode</code><br><code>set_wire_load_model</code><br><code>set_wire_load_selection_group</code>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| System interface                                | <code>set_drive</code><br><code>set_driving_cell</code><br><code>set_fanout_load</code><br><code>set_input_transition</code><br><code>set_load</code><br><code>set_port_fanout_number</code>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <u>Design rule constraints</u>                  | <u><code>set_max_capacitance</code></u><br><u><code>set_max_fanout</code></u><br><u><code>set_max_transition</code></u><br><u><code>set_min_capacitance</code></u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Timing constraints                              | <code>create_clock</code><br><code>create_generated_clock</code><br><code>group_path</code><br><code>set_clock_gating_check</code><br><code>set_clock_groups</code><br><code>set_clock_latency</code><br><code>set_clock_sense</code><br><code>set_clock_transition</code><br><code>set_clock_uncertainty</code><br><code>set_data_check</code><br><code>set_disable_timing</code><br><code>set_ideal_latency</code><br><code>set_ideal_network</code><br><code>set_ideal_transition</code><br><code>set_input_delay</code><br><code>set_max_time_borrow</code><br><code>set_output_delay</code><br><code>set_propagated_clock</code><br><code>set_resistance</code><br><code>set_timing_derate</code> |
| Timing exceptions                               | <code>set_false_path</code><br><code>set_max_delay</code><br><code>set_min_delay</code><br><code>set_multicycle_path</code>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Area constraints                                | <code>set_max_area</code>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Multivoltage and power optimization constraints | <code>create_voltage_area</code><br><code>set_level_shifter_strategy</code><br><code>set_level_shifter_threshold</code><br><code>set_max_dynamic_power</code><br><code>set_max_leakage_power</code>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Logic assignments                               | <code>set_case_analysis</code><br><code>set_logic_dc</code><br><code>set_logic_one</code><br><code>set_logic_zero</code>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

Most of the constraint commands require a design object as a command argument.

### Design Objects:

| Design object | Access command                         | Description                                                                                                 |
|---------------|----------------------------------------|-------------------------------------------------------------------------------------------------------------|
| design        | current_design                         | A container for cells. A block.                                                                             |
| clock1        | get_clocks<br>all_clocks               | A clock in a design. All clocks in a design.                                                                |
| port          | get_ports<br>all_inputs<br>all_outputs | An entry point to or exit point from a design. All entry points to a design. All exit points from a design. |
| cell          | get_cells.                             | An instance of a design or library cell                                                                     |
| pin           | get_pins                               | An instance of a design port or library cell pin.                                                           |
| net           | get_nets                               | A connection between cell pins and design ports                                                             |
| library       | get_libs                               | A container for library cells                                                                               |
| lib_cell      | get_lib_cells                          | A primitive logic element.                                                                                  |
| lib_pin       | get_lib_pins                           | An entry point to or exit point from a lib_cell.                                                            |
| register      | all_registers                          | A sequential logic cell.                                                                                    |

### 4. Comments:

You can add comments to an SDC file either as complete lines or as fragments after a command. To identify a line as a comment, start the line with a pound sign (#).

E.g : # This is an SDC comment line.

To add a comment after a command, end the command using a semicolon, then precede the comment with a pound sign (#).

E.g: create\_clock -period 10 [get\_ports CLK]; # comment fragment

### How to generate The SDC file Automatically:

Using Synopsys Tool like DC, ICC or PrimeTime you can generate the SDC. There may be slight variation between the generated SDC across the different tool.

Command for generation: - write\_sdc

### **Validation of manually generated SDC files:-**

Command file: read\_sdc -syntax\_only