Version 0.2

# **Design Constraints Working Group**





# **Revision History**

| Revision | Date   | Name      | Comments                                                                |
|----------|--------|-----------|-------------------------------------------------------------------------|
| 0.2      | 7/6/98 | Mark Hahn | Added a table of contents, clock constraints, and did some reformatting |
| 0.1      | 6/8/98 | Mark Hahn | Initial Creation                                                        |

## **Table Of Contents**

| 1. Timing Domain                                                                                                                                                              | 4                |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 1.1 Clock Constraints                                                                                                                                                         | 4                |
| <i>Clock</i><br>Specifies a set of points in the design at which a clock waveform originates                                                                                  | <b>4</b><br>4    |
| <i>Clock Delay</i><br>Constraint on the timing characteristics of a clock network or a portion of a hierarchical clock<br>network                                             | 5<br>5           |
| <i>Clock Mode</i><br>Default for whether the ideal characteristics of clock networks should be used for analysis, or<br>whether the actual characteristics should be computed | <b>7</b><br>7    |
| <i>Derived Waveform</i><br>A waveform which is derived from another waveform (by a clock multiplier or divider, for example                                                   | <b>8</b><br>le)8 |
| <i>Waveform</i><br>A description of an abstract waveform                                                                                                                      | <b>9</b><br>9    |

# 1. Timing Domain

### 1.1 Clock Constraints

#### Clock

Specifies a set of points in the design at which a clock waveform originates

| Туре        | Environment condition                  |                                  |                                   |  |
|-------------|----------------------------------------|----------------------------------|-----------------------------------|--|
| Applies To  | Hierarchical pins or primitive outputs |                                  |                                   |  |
| Depends On  | Waveform, Derived W                    | Waveform, Derived Waveform       |                                   |  |
| Verified By | None                                   |                                  |                                   |  |
| Parameters  |                                        |                                  |                                   |  |
| Name        | Value Type                             | Restrictions                     | Semantics                         |  |
| Waveform    | String                                 | Waveform can only have two edges | The name of the abstract waveform |  |

### Clock Delay

Constraint on the timing characteristics of a clock network or a portion of a hierarchical clock network

| Туре        | Constraint                             |
|-------------|----------------------------------------|
| Applies To  | Hierarchical pins or primitive outputs |
| Depends On  | Clock                                  |
| Verified By | Timing analysis                        |

Parameters

| Name               | Value Type        | Restrictions | Semantics                                                                                                                                                                                                                                                                                                                                        |
|--------------------|-------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Root               | Pin name          |              | Name of hierarchical pin or primitive output which drives the clock<br>network. Either a pin name or a waveform name may be specified as<br>the root, but not both. Values specified using a pin name override<br>those specified using a waveform name.                                                                                         |
|                    | Waveform name     |              | When a waveform name is given, it specifies default values which affect all clock networks driven by that waveform, including virtual clock networks referenced in <i>Arrival</i> and <i>Required Time</i> constraints.                                                                                                                          |
| Analysis mode      | ideal or actual   |              | This specifies whether the ideal insertion delay, skew, and transition<br>times within the clock network should be used, or whether the actual<br>values should be computed. Generally the analysis mode is set to<br>ideal prior to inserting the clock network, and actual afterwards.<br>This overrides the default Clock Mode specification. |
| Explicit leaf pins | List of pin names |              | These override the default rules, specifying that pins which would<br>otherwise lie within the default clock network should be treated as<br>leaf pins, or grouping a set of default leaf pins in order to override<br>the default constraints.                                                                                                  |
| Excluded leaf pins | List of pin names |              | These override the default rules, specifying a group of pins which<br>should be ignored for the purpose of computing skew. These pins<br>may be default leaf pins or they may lie within the default clock<br>network. The forward trace stops at these pins. Transition times may                                                               |

| Name                        | Value Type                                    | Restrictions | Semantics                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------------|-----------------------------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             |                                               |              | still be specified explicitly or by default on these pins.                                                                                                                                                                                                                                                                                                             |
| Default insertion delay     | Float<br>for each edge                        | Non-negative | The nominal cumulative delay from the root to the default leaf pins, as well as the default value for explicit leaf pins.                                                                                                                                                                                                                                              |
| Explicit insertion delay    | Float<br>for each edge                        | Non-negative | This overrides the default, specifying a different insertion delay for a group of explicit leaf pins                                                                                                                                                                                                                                                                   |
| Default skew                | Float<br>min, max for each edge               | Non-negative | The range of differences in insertion delay allowed between any pair<br>of leaf pins, except for the excluded leaf pins.                                                                                                                                                                                                                                               |
| Explicit skew               | Float<br>min, max for each edge               | Non-negative | The range of differences in in insertion delay between any pair of explicit leaf pins in a group.                                                                                                                                                                                                                                                                      |
| Default transition time     | Float<br>min, max for each edge               | Non-negative | The range of transition (ramp) times allowed at each default leaf pin, as well as the default value for explicit leaf pins.                                                                                                                                                                                                                                            |
| Explicit transition time    | Float<br>min, max for each edge               | Non-negative | The range of transition (ramp) times allowed at a group of explicit leaf pins.                                                                                                                                                                                                                                                                                         |
| Default overshoot<br>limit  | Float<br>min, max                             |              | For board level analysis, the default overshoot allowed at each default leaf pin, as well as the default value for explicit leaf pins                                                                                                                                                                                                                                  |
| Explicit overshoot<br>limit | Float<br>min, max                             |              | For board level analysis, the overshoot allowed at a group of explicit leaf pins                                                                                                                                                                                                                                                                                       |
| Active                      | List of<br>rise, fall, high, low<br>or<br>all |              | This specifies the active portion of the clock for the sequential<br>elements downstream from a group of explicit leaf pins. It is<br>required when the leaf pins are the root of another clock network, or<br>when the leaf pin is an output port. Rise and fall are used for edge-<br>triggered devices, while high and low are used for level-sensitive<br>devices. |
| Source arrival time         | Float<br>min, max for each edge               |              | The nominal cumulative delay from the root of a hierarchical clock<br>network to the root of this partial clock network. The total insertion<br>delay to leaf pins in this partial clock network is the sum of the<br>source arrival time and the insertion delay within this clock network.                                                                           |
| Jitter                      | Float                                         | Non-negative | Potential variation in clock period across different clock cycles.                                                                                                                                                                                                                                                                                                     |

### Clock Mode

Default for whether the ideal characteristics of clock networks should be used for analysis, or whether the actual characteristics should be computed

| Туре          | Control         |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------|-----------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Applies To    | Design          |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Depends On    | None            |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Verified By   | None            |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Parameters    |                 |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Name          | Value Type      | Restrictions | Semantics                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Analysis mode | ideal or actual |              | This specifies the default value (for all clock networks) of whether<br>the ideal insertion delay, skew, and transition times within the clock<br>network should be used, or whether the actual values should be<br>computed. Generally the default analysis mode is set to ideal prior to<br>inserting clock networks, and actual afterwards. The default analysis<br>mode can be overridden for particular clock trees by the <i>Clock</i><br><i>Delay</i> constraint. |

#### Derived Waveform

A waveform which is derived from another waveform (by a clock multiplier or divider, for example)

| Туре        | Environment condition |
|-------------|-----------------------|
| Applies To  | None                  |
| Depends On  | None                  |
| Verified By | None                  |

#### Parameters

| Name                 | Value Type                        | Restrictions | Semantics                                                                                                   |
|----------------------|-----------------------------------|--------------|-------------------------------------------------------------------------------------------------------------|
| Parent               | String                            |              | The name of the waveform from which this waveform is derived                                                |
| Inverted             | Boolean                           |              | Whether the derived waveform is inverted or not                                                             |
| Phase shift          | Float                             |              | Offset from the parent waveform                                                                             |
| Frequency multiplier | Float                             |              | Multiplier relative to parent waveform frequency. 0.5 corresponds to divide-by-two                          |
| Skew adjustment      | List of floats                    |              | Additional skew. Each value is both added to and subtracted from corresponding edges in the parent waveform |
|                      | List of min/max<br>ranges (float) |              | Each value is both added to and subtracted from corresponding edges in the parent waveform                  |

#### Waveform

A description of an abstract waveform

| Туре       | Environment condition |
|------------|-----------------------|
| Applies To | None                  |
| Depends On | None                  |

Verified By None

#### Parameters

| Name   | Value Type                        | Restrictions | Semantics                                                                                                            |
|--------|-----------------------------------|--------------|----------------------------------------------------------------------------------------------------------------------|
| Edges  | List of floats                    |              | Offsets from an implicit reference point in time                                                                     |
|        | List of min/max<br>ranges (float) |              | Offsets from an implicit reference point in time. Min/max range describes uncertainty region in which edge can occur |
| Domain | String                            |              | Name of a clock domain. All clocks in the same domain are synchronous with respect to each other.                    |