

# 7. The Quartus II TimeQuest Timing Analyzer

QII53018-9.0.0

# Introduction

The Quartus® II TimeQuest Timing Analyzer is a powerful ASIC-style timing analysis tool that validates the timing performance of all logic in your design using an industry-standard constraint, analysis, and reporting methodology. Use the Quartus II TimeQuest Timing Analyzer's GUI or command-line interface to constrain, analyze, and report results for all timing paths in your design.

Before running the Quartus II TimeQuest Timing Analyzer, you must specify initial timing constraints that describe the clock characteristics, timing exceptions, and signal transition arrival and required times. You can specify timing constraints in the Synopsys Design Constraints (**.sdc**) file format using the GUI or command-line interface. The Quartus II Fitter optimizes the placement of logic to meet your constraints.

During timing analysis, the Quartus II TimeQuest Timing Analyzer analyzes the timing paths in the design, calculates the propagation delay along each path, checks for timing constraint violations, and reports timing results as slack in the **Report** pane and in the **Console** pane. If the Quartus II TimeQuest Timing Analyzer reports any timing violations, you can customize the reporting to view precise timing information about specific paths, and then constrain those paths to correct the violations. When your design is free of timing violations, you can be confident that the logic will operate as intended in the target device.

The Quartus II TimeQuest Timing Analyzer is a complete static timing analysis tool that you can use as a sign-off tool for Altera® FPGAs and HardCopy® ASICs.

This chapter contains the following sections:

- Getting Started with the Quartus II TimeQuest Timing Analyzer" on page 7–2
- "Compilation Flow with the Quartus II TimeQuest Timing Analyzer Guidelines" on page 7–2
- "Timing Analysis Overview" on page 7–6
- "The Quartus II TimeQuest Timing Analyzer Flow Guidelines" on page 7–19
- "Collections" on page 7–21
- "SDC Constraint Files" on page 7–22
- "Clock Specification" on page 7–24
- "I/O Specifications" on page 7–39
- "Timing Exceptions" on page 7–44
- "Constraint and Exception Removal" on page 7–51
- "Timing Reports" on page 7–51
- "Timing Analysis Features" on page 7–74
- "The TimeQuest Timing Analyzer GUI" on page 7–79

"Conclusion" on page 7–89

For more information about the TimeQuest Timing Analyzer and the SOPC Builder, refer to *Volume 4: SOPC Builder* in the *Quartus II Handbook*.

# **Getting Started with the Quartus II TimeQuest Timing Analyzer**

The Quartus II TimeQuest Timing Analyzer caters to the needs of the most basic to the most advanced designs for FPGAs.

This section provides a brief overview of the Quartus II TimeQuest Timing Analyzer, including the necessary steps to properly constrain a design, perform a full place-and-route, and perform reporting on the design.

## Setting Up the Quartus II TimeQuest Timing Analyzer

The Quartus II software version 7.2 and later supports two native timing analysis tools: Quartus II TimeQuest Timing Analyzer and Quartus II Classic Timing Analyzer. When you specify the Quartus II TimeQuest Timing Analyzer as the default timing analysis tool, the Quartus II TimeQuest Timing Analyzer guides the Fitter and analyzes timing results after compilation.

To specify the Quartus II TimeQuest Timing Analyzer as the default timing analyzer, on the Assignments menu, click **Settings**. In the **Settings** dialog box, in the **Category** list, select **Timing Analysis Settings** and turn on **Use TimeQuest Timing Analyzer during compilation**.

To add the TimeQuest icon to the Quartus II toolbar, on the Tools menu, click **Customize**. In the Customize dialog box, click the **Toolbars** tab, turn on **Processing**, and click **Close**.

# Compilation Flow with the Quartus II TimeQuest Timing Analyzer Guidelines

When you enable the Quartus II TimeQuest Timing Analyzer as the default timing analyzer, everything from constraint validation to timing verification is performed by the Quartus II TimeQuest Timing Analyzer. Figure 7–1 shows the recommended design flow steps to maximize and leverage the benefits the Quartus II TimeQuest Timing Analyzer. Details about each step are provided after the figure.



#### Figure 7–1. Design Flow with the Quartus II TimeQuest Timing Analyzer

Create Quartus II Project and Specify Design Files—Creates a project before you can compile design files. In this step you specify the target FPGA, any EDA tools used in the design cycle, and all design files.

You can also modify existing design files for design optimization and add additional design files. For example, you can add HDL files or schematics to the project.

Perform Initial Compilation—Creates an initial design database before you specify timing constraints for your design. Perform Analysis and Synthesis to create a post-map database, or perform a full compilation to create a post-fit database.

Creating a post-map database for the initial compilation is faster than creating a post-fit database. A post-map database is sufficient for the initial database.

Creating a post-fit database is recommended only if you previously created and specified an **.sdc** file for the project. A post-map database is sufficient for the initial compilation.

 Specify Timing Requirements—Timing requirements guide the Fitter as it places and routes your design.

You must enter all timing constraints and exceptions in an **.sdc** file. This file must be included as part of the project. To add this file to your project, on the Project menu, click **Add/Remove Files in Project** and add the **.sdc** file in the **Files** dialog box.

Perform Compilation—Synthesizes, places, and routes your design into the target FPGA.

When compilation is complete, the TimeQuest Timing Analyzer generates summary clock setup and clock hold, recovery, and removal reports for all defined clocks in the design.  Verify Timing—Verifies timing in your design with the Quartus II TimeQuest Timing Analyzer. Refer to "The Quartus II TimeQuest Timing Analyzer Flow Guidelines" on page 7–19.

# **Running the Quartus II TimeQuest Timing Analyzer**

You can run the Quartus II TimeQuest Timing Analyzer in one of the following modes:

- Directly from the Quartus II software
- Stand-alone mode
- Command-line mode

This section describes each of the modes, and the behavior of the Quartus II TimeQuest Timing Analyzer.

## **Directly from the Quartus II Software**

To run the Quartus II TimeQuest Timing Analyzer from the Quartus II software, on the Tools menu, click **TimeQuest Timing Analyzer**. The Quartus II TimeQuest Timing Analyzer is available after you have created a database for the current project. The database can be either a post-map or post-fit database; perform Analysis and Synthesis to create a post-map database, or a full compilation to create a post-fit database.

After a database is created, you can create a timing netlist based on that database. If you create a post-map database, you cannot create a post-fit timing netlist in the Quartus II TimeQuest Timing Analyzer.

When you launch the TimeQuest Timing Analyzer directly from the Quartus II software, the current project opens by default.

## **Stand-Alone Mode**

To run the Quartus II TimeQuest Timing Analyzer in stand-alone mode, type the following command at the command prompt:

quartus\_staw 🛩

In stand-alone mode, you can perform static analysis on any project that contains either a post-map or post-fit database. To open a project, double-click **Open Project** in the **Tasks** pane.

## **Command-Line Mode**

Use command-line mode for easy integration with scripted design flows. Using the command-line mode avoids interaction with the user interface provided by the Quartus II TimeQuest Timing Analyzer, but allows the automation of each step of the static timing analysis flow. Table 7–1 provides a summary of the options available in the command-line mode.

| Command Line Option          | Description                               |
|------------------------------|-------------------------------------------|
| -h  help                     | Provides help information on quartus_sta. |
| -t <script file=""></script> |                                           |

To run the Quartus II TimeQuest Timing Analyzer in command-line mode, type the following command at the command prompt:

quartus\_sta <options> 🕶

# **Timing Analysis Overview**

This section provides an overview of the Quartus II TimeQuest Timing Analyzer concepts. Understanding these concepts allows you to take advantage of the powerful timing analysis features available in the Quartus II TimeQuest Timing Analyzer.

The Quartus II TimeQuest Timing Analyzer follows the flow shown in Figure 7–2 when it analyzes your design. Table 7–2 lists the most commonly used commands for each step.



Figure 7–2. The Quartus II TimeQuest Timing Analyzer Flow

Table 7-2 describes Quartus II TimeQuest Timing Analyzer terminology.

| Terminology | Definition                                                                                                      |
|-------------|-----------------------------------------------------------------------------------------------------------------|
| Nodes       | Most basic timing netlist unit. Use to represent ports, pins, and registers.                                    |
| Keepers     | Ports or registers. (1)                                                                                         |
| Cells       | Look-up table (LUT), registers, digital signal processing (DSP) blocks, TriMatrix memory, IOE, and so on. $(2)$ |
| Pins        | Inputs or outputs of cells.                                                                                     |
| Nets        | Connections between pins.                                                                                       |
| Ports       | Top-level module inputs or outputs; for example, device pins.                                                   |

 Table 7–2.
 Quartus II TimeQuest Timing Analyzer Terms (Part 1 of 2)

| Table 7–2. | Quartus | II TimeQuest | Timing Anal | yzer Terms | (Part 2 of 2) | ) |
|------------|---------|--------------|-------------|------------|---------------|---|
|------------|---------|--------------|-------------|------------|---------------|---|

| Terminology         | Definition                              |
|---------------------|-----------------------------------------|
| Clocks              | Abstract objects outside of the design. |
| Notes to Table 7, 9 |                                         |

Notes to Table 7-2:

- (1) Pins can indirectly refer to keepers. For example, when the value in the -from field of a constraint is a clock pin to a dedicated memory. In this case, the clock pin refers to a collection of registers.
- (2) For Stratix<sup>®</sup> devices and other early device families, the LUT and registers are contained in logic elements (LE) and act as cells for these device families.

The Quartus II TimeQuest Timing Analyzer requires a timing netlist before it can perform a timing analysis on any design. For example, for the design shown in Figure 7–3, the Quartus II TimeQuest Timing Analyzer generates a netlist equivalent to the one shown in Figure 7–4.









Figure 7–4 shows various cells, pins, nets, and ports. The following sample cell names are included:

- reg1
- reg2
- and\_inst

The following sample pins names are included:

- data1 | combout
- reg1|regout
- and\_inst|combout

The following net names are included:

- data1~combout
- reg1
- and\_inst

The following port names are included:

- data1,clk
- data\_out

Paths connect two design nodes, such as the output of a register to the input of another register. Timing paths play a significant role in timing analysis. Understanding the types of timing paths is important to timing closure and optimization. The following list shows some of the commonly analyzed paths that are described in this section:

- Edge paths—the connections from ports-to-pins, from pins-to-pins, and from pins-to-ports.
- Clock paths—the edges from device ports or internally generated clock pins to the clock pin of a register.
- **Data paths**—the edges from a port or the data output pin of a sequential element to a port or the data input pin of another sequential element.
- Asynchronous paths—the edges from a port or sequential element to the asynchronous set or clear pin of a sequential element.

Figure 7–5 shows some of these commonly analyzed path types.

#### Figure 7–5. Path Types



After the Quartus II TimeQuest Timing Analyzer identifies the path type, it can report data and clock arrival times for valid register-to-register paths. The Quartus II TimeQuest Timing Analyzer calculates data arrival time by adding the delay from the clock source to the clock pin of the source register, the micro clock-to-out ( $\mu t_{co}$ ) of the source register, and the delay from the source register's Q pin to the destination register's D pin, where the  $\mu t_{co}$  is the intrinsic clock-to-out for the internal registers in the FPGA.

The Quartus II TimeQuest Timing Analyzer calculates clock arrival time by adding the delay from the clock source to the destination register's clock pin. Figure 7–6 shows a data arrival path and a clock arrival path. The Quartus II TimeQuest Timing Analyzer calculates data required time by accounting for the clock arrival time and micro setup time ( $\mu t_{SU}$ ) of the destination register, where the  $\mu t_{SU}$  is the intrinsic setup for the internal registers in the FPGA.





In addition to identifying various paths in a design, the Quartus II TimeQuest Timing Analyzer analyzes clock characteristics to compute the worst-case requirement between any two registers in a single register-to-register path. You should constrain all clocks in your design before performing this analysis.

The launch edge is an active clock edge that sends data out of a sequential element, acting as a source for the data transfer. A latch edge is the active clock edge that captures data at the data port of a sequential element, acting as a destination for the data transfer.

Figure 7–7 shows a single-cycle system that uses consecutive clock edges to transfer and capture data, a register-to-register path, and the corresponding launch and latch edges timing diagram. In this example, the launch edge sends the data out of register reg1 at 0 ns, and register reg2 latch edge captures the data at 5 ns.





The Quartus II TimeQuest Timing Analyzer validates clock setup and hold requirements relative to the launch and latch edges.

## **Clock Analysis**

A comprehensive static timing analysis includes analysis of register-to-register, I/O, and asynchronous reset paths. The Quartus II TimeQuest Timing Analyzer uses data required times, data arrival times, and clock arrival times to verify circuit performance and detect possible timing violations. The Quartus II TimeQuest Timing Analyzer determines the timing relationships that must be met for the design to correctly function and checks arrival times against required times to verify timing.

## **Clock Setup Check**

To perform a clock setup check, the Quartus II TimeQuest Timing Analyzer determines a setup relationship by analyzing each launch and latch edge for each register-to-register path. For each latch edge at the destination register, the Quartus II TimeQuest Timing Analyzer uses the closest previous clock edge at the source register as the launch edge. In Figure 7–8, two setup relationships are defined and are labeled setup A and setup B. For the latch edge at 10 ns, the closest clock that acts as a launch edge is at 3 ns and is labeled setup A. For the latch edge at 20 ns, the closest clock that acts as a launch edge is 19 ns and is labeled setup B.





The Quartus II TimeQuest Timing Analyzer reports the result of clock setup checks as slack values. Slack is the margin by which a timing requirement is met or not met. Positive slack indicates the margin by which a requirement is met; negative slack indicates the margin by which a requirement is not met. The Quartus II TimeQuest Timing Analyzer determines clock setup slack, as shown in Equation 7–1, for internal register-to-register paths.

#### Equation 7–1.

| Clock Setup Slack = Data Required Time – Data Arrival Time                    |
|-------------------------------------------------------------------------------|
| Data Arrival Time $=$ Launch Edge + Clock Network Delay to Source Register +  |
| $\mu t_{CO}$ + Register-to-Register Delay                                     |
| Data Required = Clock Arrival Time $-\mu t_{SU}$ - Setup Uncertainty          |
| Clock Arrival Time = Latch Edge + Clock Network Delay to Destination Register |

If the data path is from an input port to a internal register, the Quartus II TimeQuest Timing Analyzer uses the equations shown in Equation 7–2 to calculate the setup slack time.

#### Equation 7–2.

| Clock Setup Slack Time = Data Required Time – Data Arrival Time                             |  |
|---------------------------------------------------------------------------------------------|--|
| Data Arrival Time = Launch Edge + Clock Network Delay +                                     |  |
| Input Maximum Delay of Pin + Pin-to-Register Delay                                          |  |
| Data Required Time = Latch Edge + Clock Network Delay to Destination Register $-\mu t_{SU}$ |  |

If the data path is an internal register to an output port, the Quartus II TimeQuest Timing Analyzer uses the equations shown in Equation 7–3 to calculate the setup slack time.

#### Equation 7–3.

| Clock Setup Slack Time = Data Required Time – Data Arrival Time                     |
|-------------------------------------------------------------------------------------|
| Data Arrival Time $=$ Launch Edge + Clock Network Delay to Source Register +        |
| $\mu t_{CO}$ + Register-to-Pin Delay                                                |
| Data Required Time = Latch Edge + Clock Network Delay – Output Maximum Delay of Pin |

### **Clock Hold Check**

To perform a clock hold check, the Quartus II TimeQuest Timing Analyzer determines a hold relationship for each possible setup relationship that exists for all source and destination register pairs. The Quartus II TimeQuest Timing Analyzer checks all adjacent clock edges from all setup relationships to determine the hold relationships. The Quartus II TimeQuest Timing Analyzer performs two hold checks for each setup relationship. The first hold check determines that the data launched by the current launch edge is not captured by the previous latch edge. The second hold check determines that the data launched by the next launch edge is not captured by the current latch edge. Figure 7–9 shows two setup relationships labeled setup A and setup B. The first hold check is labeled hold check A1 and hold check B1 for setup A and setup B, respectively. The second hold check is labeled hold check A2 and hold check B2 for setup A and setup B, respectively.

#### Figure 7–9. Hold Checks



From the possible hold relationships, the Quartus II TimeQuest Timing Analyzer selects the hold relationship that is the most restrictive. The hold relationship with the largest difference between the latch and launch edges (that is, latch – launch and not the absolute value of latch and launch) is selected because this determines the minimum allowable delay for the register-to-register path. For Figure 7–9, the hold relationship selected is hold check A2.

The Quartus II TimeQuest Timing Analyzer determines clock hold slack as shown in Equation 7–4.

#### Equation 7–4.

| Clock Hold Slack = Data Arrival Time – Data Required Time                                 |
|-------------------------------------------------------------------------------------------|
| Data Arrival Time = Launch Edge + Clock Network Delay to Source Register + $\mu t_{CO}$ + |
| Register-to-Register Delay                                                                |
| Data Required Time = Clock Arrival Time + $\mu t_{H}$ + Hold Uncertainty                  |
| Clock Arrival Time = Latch Edge + Clock Network Delay to Destination Register             |
|                                                                                           |

If the data path is from an input port to an internal register, the Quartus II TimeQuest Timing Analyzer uses the equations shown in Equation 7–5 to calculate the hold slack time.

### Equation 7-5.

| Clock Hold Slack Time $=$ Data Arrival Time – Data Required Time                              |  |
|-----------------------------------------------------------------------------------------------|--|
| Data Arrival Time = Launch Edge + Clock Network Delay +                                       |  |
| Input Minimum Delay of Pin + Pin-to-Register Delay                                            |  |
| Data Required Time $=$ Latch Edge + Clock Network Delay to Destination Register + $\mu t_{H}$ |  |

If the data path is an internal register to an output port, the Quartus II TimeQuest Timing Analyzer uses the equations shown in Equation 7–6 to calculate the setup hold time.

#### Equation 7-6.

| Clock Hold Slack Time $=$ Data Arrival Time – Data Required Time                         |
|------------------------------------------------------------------------------------------|
| Data Arrival Time = Latch Edge + Clock Network Delay to Source Register + $\mu t_{CO}$ + |
| Register-to-Pin Delay                                                                    |
| Data Required Time = Latch Edge + Clock Network Delay – Output Minimum Delay of Pin      |

### **Recovery and Removal**

Recovery time is the minimum length of time the de-assertion of an asynchronous control signal; for example, clear and preset, must be stable before the next active clock edge. The recovery slack time calculation is similar to the clock setup slack time calculation, but it applies to asynchronous control signals. If the asynchronous control signal is registered, the Quartus II TimeQuest Timing Analyzer uses Equation 7–7 to calculate the recovery slack time.

#### Equation 7–7.

| Recovery Slack Time = Data Required Time – Data Arrival Time                                |
|---------------------------------------------------------------------------------------------|
| Data Arrival Time $=$ Launch Edge + Clock Network Delay to Source Register +                |
| $\mu t_{CO}$ + Register-to-Register Delay                                                   |
| Data Required Time = Latch Edge + Clock Network Delay to Destination Register $-\mu t_{SU}$ |

If the asynchronous control is not registered, the Quartus II TimeQuest Timing Analyzer uses the equations shown in Equation 7–8 to calculate the recovery slack time.

#### Equation 7–8.

| Recovery Slack Time = Data Required Time – Data Arrival Time                                         |
|------------------------------------------------------------------------------------------------------|
| Data Arrival Time $=$ Launch Edge + Clock Network Delay + Maximum Input Delay +                      |
| Port-to-Register Delay                                                                               |
| Data Required Time $=$ Latch Edge + Clock Network Delay to Destination Register Delay – $\mu t_{SU}$ |

If the asynchronous reset signal is from a port (device I/O), you must make an Input Maximum Delay assignment to the asynchronous reset port for the Quartus II TimeQuest Timing Analyzer to perform recovery analysis on that path.

Removal time is the minimum length of time the de-assertion of an asynchronous control signal must be stable after the active clock edge. The Quartus II TimeQuest Timing Analyzer removal time slack calculation is similar to the clock hold slack calculation, but it applies asynchronous control signals. If the asynchronous control is registered, the Quartus II TimeQuest Timing Analyzer uses the equations shown in Equation 7–9 to calculate the removal slack time.

#### Equation 7–9.

| Removal Slack Time = Data Arrival Time – Data Required Time                                 |
|---------------------------------------------------------------------------------------------|
| Data Arrival Time $=$ Launch Edge + Clock Network Delay to Source Register +                |
| $\mu t_{CO}$ of Source Register + Register-to-Register Delay                                |
| Data Required Time = Latch Edge + Clock Network Delay to Destination Register + $\mu t_{H}$ |
|                                                                                             |

If the asynchronous control is not registered, the Quartus II TimeQuest Timing Analyzer uses the equations shown in Equation 7–10 to calculate the removal slack time.

## Equation 7–10.

Removal Slack Time = Data Arrival Time – Data Required Time Data Arrival Time = Launch Edge + Clock Network Delay + Input Minimum Delay of Pin + Minimum Pin-to-Register Delay Data Required Time = Latch Edge + Clock Network Delay to Destination Register + μ t<sub>H</sub>

If the asynchronous reset signal is from a device pin, you must specify the Input Minimum Delay constraint to the asynchronous reset pin for the Quartus II TimeQuest Timing Analyzer to perform a removal analysis on this path.

## **Multicycle Paths**

Multicycle paths are data paths that require more than one clock cycle to latch data at the destination register. For example, a register may be required to capture data on every second or third rising clock edge. Figure 7–10 shows an example of a multicycle path between a multiplier's input registers and output register where the destination latches data on every other clock edge.

Figure 7–10. Example Diagram of a Multicycle Path



Figure 7–11 shows a register-to-register path where the source clock, src\_clk, has a period of 10 ns and the destination clock, dst\_clk, has a period of 5 ns.

#### Figure 7–11. Register-to-Register Path



Figure 7–12 shows the respective timing diagrams for the source and destination clocks and the default setup and hold relationships. The default setup relationship is 5 ns; the default hold relationship is 0 ns.





The default setup and hold relationships can be modified with the set\_multicycle\_path command to accommodate the system requirements.

Table 7–3 shows the commands used to modify either the launch or latch edge times that the Quartus II TimeQuest Timing Analyzer Timing Analyzer uses to determine a setup relationship or hold relationship.

Table 7–3. Commands to Modify Edge Times

| Command                           | Description of Modification                |
|-----------------------------------|--------------------------------------------|
| set_multicycle_path -setup -end   | Latch edge time of the setup relationship  |
| set_multicycle_path -setup -start | Launch edge time of the setup relationship |
| set_multicycle_path -hold -end    | Latch edge time of the hold relationship   |
| set_multicycle_path -hold -start  | Launch edge time of the hold relationship  |

Figure 7–13 shows the timing diagram after a multicycle setup of two has been applied. The command moves the latch edge time to 10 ns from the default 5 ns.





## Metastability

Metastability problems can occur when a signal is transferred between circuitry in unrelated or asynchronous clock domains because the designer cannot guarantee that the signal will meet setup and hold time requirements. To minimize the failures due to metastability, circuit designers typically use a sequence of registers (synchronization register chain or synchronizer) in the destination clock domain to resynchronize the data signals to the new clock domain.

The Mean Time Before Failure (MTBF) is an estimate of the average time between instances of failure due to metastability.

The TimeQuest Timing Analyzer analyzes the robustness of the design for metastability and can calculate the MTBF for synchronization register chains in the design. The MTBF of the entire design is then estimated based on the synchronization chains it contains.

In addition to reporting synchronization register chains found in the design, the Quartus II software also protects these registers from optimizations that might negatively impact MTBF, such as register duplication and logic retiming. The Quartus II software can also optimize the MTBF of your design if the MTBF is too low.

Refer to "report\_metastability" on page 7–57 for information about how to enable metastability analysis and report metastability in the TimeQuest Timing Analyzer.

• For more information about metastability, its effects in FPGAs, and how MTBF is calculated, refer to the *Understanding Metastability in FPGAs* White Paper. For more information about metastability analysis, reporting, and optimization features in the Quartus II software, refer to the *Managing Metastability with the Quartus II Software* chapter in volume 1 of the *Quartus II Handbook*.

# **Common Clock Path Pessimism**

Common clock path pessimism (CCPP) removal accounts for the minimum and maximum delay variation associated with common clock paths during a static timing analysis. CCPP removal accounts for this variation by adding the difference between the maximum and minimum delay value of the common clock path to the appropriate slack equation.

The minimum and maximum delay variation might arise when two different delay values are used for the same clock path. For example, in a simple setup analysis, the maximum clock path delay to the source register is used to determine the data arrival time. The minimum clock path delay to the destination register is used to determine the data required time. However, if the clock path to the source register and to the destination register share a common clock path, the analysis uses both the maximum delay and the minimum delay to model the common clock path. This results in an overly pessimistic analysis since two different delay values, the maximum and minimum delays, cannot be used to model the same clock path.

Figure 7–14 shows a typical register-to-register path with the maximum and minimum delay values shown.



Figure 7–14. Common Clock Path

Segment A is the common clock path between reg1 and reg2. The minimum delay is 5.0 ns; the maximum delay is 5.5 ns. The difference between the maximum and minimum delay value equals the CCPP removal value; in this case, CCPP equals 0.5 ns. The CCPP removal value is then added to the appropriate slack equation. Therefore, if the setup slack for the register-to-register in Figure 7–14 equals 0.7 ns *without* CCPP removal, the slack would be 1.2 ns *with* CCPP removal.

CCPP is also used when determining the minimum pulse width of a register. A clock signal must meet a register's minimum pulse width requirement to be recognized by the register. A minimum high time defines the minimum pulse width for a positive-edge triggered register. A minimum low time defines the minimum pulse width for a negative-edge triggered register.

Clock pulses that violate the minimum pulse width of a register prevent data from being latched at the data pin of the register. To calculate the slack of the minimum pulse width, the required minimum pulse width time is subtracted from the actual minimum pulse width time. The actual minimum pulse width time is determined by the clock requirement specified for the clock that feeds the clock port of the register. The required minimum pulse width time is determined by the maximum rise, minimum rise, maximum fall, and minimum fall times. Figure 7–15 shows a diagram of the required minimum pulse width time for both the high pulse and low pulse.

#### Figure 7–15. Required Minimum Pulse Width



With CCPP, the minimum pulse width slack can be increased by the smallest value of either the maximum rise time minus the minimum rise time, or the maximum fall time minus the minimum fall time. For Figure 7–15, the slack value can be increased by 0.2 ns, which is the smallest value between 0.3 ns (0.8 ns – 0.5 ns) and 0.2 ns (0.9 ns – 0.7 ns).

Refer to "report\_min\_pulse\_width" on page 7–59 for more information about reporting CCPP in the TimeQuest Timing Analyzer.

You must use the **Enable common clock path pessimism removal** option to account for CCPP in the Fitter and timing analysis. This option defaults to ON for Stratix III, Cyclone III, and newer device families.

To access this option, perform the following steps:

- 1. On the Assignments menu, click **Settings**. The **Settings** dialog box appears.
- 2. In the **Category** list, next to **Timing Analysis Settings**, click the "+" icon to expand the menu. Click **TimeQuest Timing Analyzer**.

- 3. Turn on Enable common clock path pessimism removal.
- 4. Click OK.
- CCPP is supported for Stratix III, Cyclone III, and newer devices.

## **Clock-As-Data**

The majority of FPGA designs contain simple connections between any two nodes known as either a data path or a clock path. A data path is a connection between the output of a synchronous element to the input of another synchronous element. A clock is a connection to the clock pin of a synchronous element. However, as FPGA designs become more complex, such as using source-synchronous interfaces, this simplified view is no longer sufficient.

The connection between port clk\_in and port clk\_out can be treated either as a clock path or a data path. The clock path is from the port clk\_in to the register reg\_data clock pin. The data path is from port clk\_in to the port clk\_out. In the design shown in Figure 7–16, the path from port clk\_in to port clk\_out is both a clock and a data path.





With clock-as-data analysis, the TimeQuest Timing Analyzer provides a more accurate analysis of the path based on the user constraints. For the clock path analysis, any phase shift associated with the PLL is taken into consideration. For the data path, any phase shift associated with the PLL is taken into consideration instead of being ignored.

The clock-as-data analysis also applies to internally generated clock dividers similar to Figure 7–17.

7–19



A source-synchronous interface contains a clock signal that travels in parallel with data signals. The clock and data pair originates or terminates at the same device.

# The Quartus II TimeQuest Timing Analyzer Flow Guidelines

Use the steps shown in Figure 7–18 to verify timing in the TimeQuest Timing Analyzer.





The following sections describe each of the steps shown in Figure 7-18.

# **Create a Timing Netlist**

After you perform a full compilation, you must create a timing netlist based on the fully annotated database from the post-fit results.

To create the timing netlist, double-click **Create Timing Netlist** in the **Tasks** pane, or type the following command in the **Console** pane:

create\_timing\_netlist 🕶

## **Read the Synopsys Design Constraints File**

After you create a timing netlist, you must read an **.sdc** file. This step reads all constraints and exceptions defined in the **.sdc** file.

You can read the .sdc file from either the Task pane or the Console pane.

To read the .sdc file from the Tasks pane, double-click the Read SDC File command.

F

The **Read SDC File** task reads the *<current revision>.sdc* file.

To read the **.sdc** file from the Console, type the following command in the Console:

read\_sdc 🛩

For more information about reading **.sdc** files in the TimeQuest Timing Analyzer, refer to "Synopsys Design Constraints File Precedence" on page 7–24.

## **Update Timing Netlist**

You must update the timing netlist after you read an **.sdc** file. The TimeQuest Timing Analyzer applies all constraints to the netlist for verification and removes any invalid or false paths in the design from verification.

To update the timing netlist, double-click Update Timing Netlist in the **Tasks** pane, or type the following command in the Console pane:

update\_timing\_netlist ←

## **Generate Timing Reports**

You can generate timing reports for all critical paths in your design. The Tasks pane contains the commonly used reporting commands. Individual or custom reports can be generated for your design.

For more information about reporting, refer to the section "Timing Reports" on page 7–51.

•••

For a full list of available report application program interfaces (APIs), refer to the SDC & TimeQuest API Reference Manual.

As you verify timing, you may encounter failures along critical paths. If this occurs, you can refine the existing constraints or create new ones to change the effects of existing constraints. If you modify, remove, or add constraints, you should perform a full compilation. This allows the Fitter to re-optimize the design based on the new constraints and brings you back to the Perform Compilation step in the process. This iterative process allows you to resolve your timing violations in the design.



• For a sample Tcl script to automate the timing analysis flow, refer to the TimeQuest Quick Start Tutorial.

# Collections

The Quartus II TimeQuest Timing Analyzer supports collection APIs that provide easy access to ports, pins, cells, or nodes in the design. Use collection APIs with any valid constraints or Tcl commands specified in the Quartus II TimeQuest Timing Analyzer.

Table 7–4 describes the collection commands supported by the Quartus II TimeQuest Timing Analyzer.

| Command       | Description                                                                                                                                                                                                                                                                                                                           |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| all_clocks    | Returns a collection of all clocks in the design.                                                                                                                                                                                                                                                                                     |
| all_inputs    | Returns a collection of all input ports in the design.                                                                                                                                                                                                                                                                                |
| all_outputs   | Returns a collection of all output ports in the design.                                                                                                                                                                                                                                                                               |
| all_registers | Returns a collection of all registers in the design.                                                                                                                                                                                                                                                                                  |
| get_cells     | Returns a collection of cells in the design. All cell names in the collection match the specified pattern. Wildcards can be used to select multiple cells at the same time.                                                                                                                                                           |
| get_clocks    | Returns a collection of clocks in the design. When used as an argument to another command, such as the <code>-from Or -to Of set_multicycle_path</code> , each node in the clock represents all nodes clocked by the clocks in the collection. The default uses the specific node (even if it is a clock) as the target of a command. |
| get_nets      | Returns a collection of nets in the design. All net names in the collection match the specified pattern. You can use wildcards to select multiple nets at the same time.                                                                                                                                                              |
| get_pins      | Returns a collection of pins in the design. All pin names in the collection match the specified pattern. You can use wildcards to select multiple pins at the same time.                                                                                                                                                              |
| get_ports     | Returns a collection of ports (design inputs and outputs) in the design.                                                                                                                                                                                                                                                              |

Table 7-4. Collection Commands

Table 7–5 describes the SDC extension collection commands supported by the Quartus II TimeQuest Timing Analyzer.

Table 7–5. SDC Extension Collection Commands (Part 1 of 2)

| Command                                | Description                                                                                                                     |
|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| get_fanouts <filter></filter>          | Returns a collection of fan-out nodes starting from <i><filter< i="">&gt;.</filter<></i>                                        |
| get_keepers <filter></filter>          | Returns a collection of keeper nodes (non-combinational nodes) in the design.                                                   |
| <pre>get_nodes <filter></filter></pre> | Returns a collection of nodes in the design. The get_nodes collection cannot be used when specifying constraints or exceptions. |
| get_partitions <filter></filter>       | Returns a collection of partitions matching the < <i>filter</i> >.                                                              |

| Command                                            | Description                                                                                                                                                                                          |
|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| get_registers <filter></filter>                    | Returns a collection of registers in the design.                                                                                                                                                     |
| get_fanins <filter></filter>                       | Returns a collection of fan-in nodes starting from <i>&lt; filter</i> >.                                                                                                                             |
| derive_pll_clocks                                  | Automatically creates generated clocks on the outputs of the PLL. The generated clock properties reflect the PLL properties that have been specified by the MegaWizard <sup>™</sup> Plug-In Manager. |
| <pre>get_assignment_groups <filter></filter></pre> | Returns either a collection of keepers, ports, or registers that have been saved to the Quartus Settings File ( <b>.qsf</b> ) with the <b>Assignment (Time) Groups</b> option.                       |
| <pre>remove_clock <clock list=""></clock></pre>    | Removes the list of clocks specified by < <i>clock list</i> >.                                                                                                                                       |
| <pre>set_scc_mode <size></size></pre>              | Allows you to set the maximum Strongly Connected Components (SCC) loop size<br>or force the Quartus II TimeQuest Timing Analyzer to always estimate delays<br>through SCCs.                          |
| set time format                                    | Sets time format, including time unit and decimal places.                                                                                                                                            |

Table 7-5. SDC Extension Collection Commands (Part 2 of 2)

For more information about collections, refer to the .sdc file and the SDC and TimeQuest API Reference Manual.

## **Application Examples**

Example 7–1 shows various uses of the create\_clock and create\_generated\_clock commands and specific design structures.

Example 7–1. create\_clock and set\_multicycle\_path Commands and Specific Design Structures

```
# Create a simple 10 ns with clock with a 60 % duty cycle
create_clock -period 10 -waveform {0 6} -name clk [get_ports clk]
# The following multicycle applies to all paths ending at registers
# clocked by clk
set_multicycle_path -to [get_clocks clk] 2
```

# **SDC Constraint Files**

The Quartus II TimeQuest Timing Analyzer stores all timing constraints in an **.sdc** file. You can create an **.sdc** file with different constraints for place-and-route and for timing analysis.

The **.sdc** file should contain only SDC and Tcl commands. Commands to manipulate the timing netlist or control the compilation flow should not be included in the **.sdc** file.

The Quartus II software does not automatically update **.sdc** files. You must explicitly write new or updated constraints in the TimeQuest Timing Analyzer GUI. Use the write\_sdc command, or, in the Quartus II TimeQuest Timing Analyzer, on the Constraints menu, click **Write SDC File** to write your constraints to an **.sdc** file.

The constraints in the **.sdc** file are order-sensitive. A constraint must first be declared before any references are made to that constraint. For example, if a generated clock references a base clock with a name clk, the base clock constraint must be declared before the generated clock constraint.

# Fitter and Timing Analysis with SDC Files

You can specify the same or different **.sdc** files for the Quartus II Fitter for place-and-route, and the Quartus II TimeQuest Timing Analyzer for static timing analysis. Using different **.sdc** files allows you to have one set of constraints for place-and-route and another set of constraints for final timing sign-off in the Quartus II TimeQuest Timing Analyzer.

## Specifying SDC Files for Place-and-Route

To specify an **.sdc** file for the Fitter, you must add the **.sdc** file to your Quartus II project. To add the file to your project, use the following command in the Tcl console:

set\_global\_assignment -name SDC\_FILE <SDC file name> +

Or, in the Quartus II software GUI, on the Project menu, click **Add/Remove Files in Project**.

The Fitter optimizes your design based on the requirements in the **.sdc** files in your project.

The results shown in the timing analysis report located in the Compilation Report are based on the **.sdc** files added to the project.

You must specify the Quartus II TimeQuest Timing Analyzer as the default timing analyzer to make the Fitter read the **.sdc** file.

## **Specifying SDC Files for Static Timing Analysis**

After you create a timing netlist in the Quartus II TimeQuest Timing Analyzer, you must specify timing constraints and exceptions before you can perform a timing analysis. The timing requirements do not have to be identical to those provided to the Fitter. You can specify your timing requirements manually or you can read a previously created **.sdc** file.

To manually enter your timing requirements, you can use constraint entry dialog boxes or SDC commands. If you have an **.sdc** file that contains your timing requirements, use this file to apply your timing requirements. To specify the **.sdc** file for timing analysis in the Quartus II TimeQuest Timing Analyzer, use the following command:

read\_sdc [<SDC file name>] ←

If you use the TimeQuest GUI to apply the **.sdc** file for timing analysis, in the Quartus II TimeQuest Timing Analyzer, on the Constraints menu, click **Read SDC File**.

The read\_sdc command has the -hdl option, allowing read\_sdc to read SDC commands embedded in HDL that uses that ALTERA\_ATTRIBUTE attribute.

The read\_sdc command without any options reads both your **.sdc** files and any HDL-embedded commands. By default, the **Read SDC File** command in the Tasks pane reads the **.sdc** files specified in the Quartus II Settings File (**.qsf**), which are the same **.sdc** files used by the Fitter.

# **Synopsys Design Constraints File Precedence**

The Quartus II Fitter and the Quartus II TimeQuest Timing Analyzer reads the **.sdc** files from the files list in the **.qsf** file in the order they are listed, from top to bottom.

The Quartus II software searches for an .sdc file, as shown in Figure 7–19.





### Note to Figure 7-19:

(1) This occurs only in the Quartus II TimeQuest Timing Analyzer and not during compilation in the Quartus II software. The Quartus II TimeQuest Timing Analyzer has the ability to automate the conversion of the QSF timing assignments to SDC if no .sdc file exists when the Quartus II TimeQuest Timing Analyzer is opened.

F

If you type the read\_sdc command at the command line without any arguments, the precedence order shown in Figure 7–19 is followed.

# **Clock Specification**

The specification of all clocks and any associated clock characteristics in your design is essential for accurate static timing analysis results. The Quartus II TimeQuest Timing Analyzer supports many SDC commands that accommodate various clocking schemes and any clock characteristics.

This section describes the **.sdc** file API available to create and specify clock characteristics.

## Clocks

Use the create\_clock command to create a clock at any register, port, or pin. You can create each clock with unique characteristics. Example 7–2 shows the create\_clock command and options.



```
create_clock
-period <period value>
[-name <clock name>]
[-waveform <edge list>]
[-add]
<targets>
```

Table 7–6 describes the options for the create\_clock command.

Table 7-6. create\_clock Command Options

| Option                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -period <period value=""></period> | Specifies the clock period. You can also specify the clock period in units of frequency, such as -period <num>MHz. (1)</num>                                                                                                                                                                                                                                                                                                              |
| -name <clock name=""></clock>      | Name of the specific clock; for example, sysclock. If you do not specify the clock name, the clock name is the same as the node to which it is assigned.                                                                                                                                                                                                                                                                                  |
| -waveform <edge list=""></edge>    | Specifies the clock's rising and falling edges. The edge list alternates between rising edge and falling edge. For example, a 10 ns period where the first rising edge occurs at 0 ns and the first falling edge occurs at 5 ns would be written as $-waveform \{0 \ 5\}$ . The difference must be within one period unit, and the rise edge must come before the fall edge. The default edge list is $\{0 \ /2\}$ , or a 50% duty cycle. |
| -add                               | Allows you to specify more than one clock to the same port or pin.                                                                                                                                                                                                                                                                                                                                                                        |
| <targets></targets>                | Specifies the port(s) or pin(s) to which the assignment applies. If source objects are not specified, the clock is a virtual clock. Refer to "Virtual Clocks" on page 7–28 for more information.                                                                                                                                                                                                                                          |

## Note to Table 7-6:

(1) The default time unit in the Quartus II TimeQuest Timing Analyzer is nanoseconds (ns).

Example 7–3 shows how to create a 10 ns clock with a 50% duty cycle, where the first rising edge occurs at 0 ns applied to port clk.

Example 7–3. 100MHz Clock Creation

create\_clock -period 10 -waveform { 0 5 } clk

Example 7–4 shows how to create a 10 ns clock with a 50% duty cycle that is phase shifted by 90 degrees applied to port clk\_sys.

**Example 7–4.** 100MHz Shifted by 90 Degrees Clock Creation

create\_clock -period 10 -waveform { 2.5 7.5 } clk\_sys

Clocks defined with the create\_clock command have a default source latency value of zero. The Quartus II TimeQuest Timing Analyzer automatically computes the clock's network latency for non-virtual clocks.

# **Generated Clocks**

The Quartus II TimeQuest Timing Analyzer considers clock dividers, ripple clocks, or circuits that modify or change the characteristics of the incoming or master clock as generated clocks. You should define the output of these circuits as generated clocks. This definition allows the Quartus II TimeQuest Timing Analyzer to analyze these clocks and account for any network latency associated with them.

Use the create\_generated\_clock command to create generated clocks. Example 7–5 shows the create\_generated\_clock command and the available options.

```
Example 7–5. create_generated_clock Command
```

```
create_generated_clock
[-name <clock name>]
-source <master pin>
[-edges <edge list>]
[-edge_shift <shift list>]
[-divide_by <factor>]
[-multiply_by <factor>]
[-duty_cycle <percent>]
[-add]
[-invert]
[-master_clock <clock>]
[-phase <phase>]
[-offset <offset>]
<targets>
```

Table 7–7 describes the options for the create\_generated\_clock command.

 Table 7–7.
 create\_generated\_clock Command Options (Part 1 of 2)

| Option                                                                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -name < <i>clock name</i> >                                            | Name of the generated clock; for example, $clk\_x2$ . If you do not specify the clock name, the clock name is the same as the first node to which it is assigned.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| -source <master pin=""></master>                                       | The < <i>master pin</i> > specifies the node in the design from which the clock settings derive.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| -edges < <i>edge list&gt;</i>  <br>-edge_shift < <i>shift list&gt;</i> | The $-edges$ option specifies the new rising and falling edges with respect to the master clock's rising and falling edges. The master clock's rising and falling edges are numbered 1 < <i>n</i> > starting with the first rising edge; for example, edge 1. The first falling edge after that is edge number 2, the next rising edge number 3, and so on. The < <i>edge list&gt;</i> must be in ascending order. The same edge may be used for two entries to indicate a clock pulse independent of the original waveform's duty cycle.<br>-edge_shift specifies the amount of shift for each edge in the < <i>edge list&gt;</i> . The -invert option can be used to invert the clock after the -edges and -edge and -edge and -edge and -edge and -edge -edge and -edge -ed |
| -divide_by <factor>  <br/>-multiply_by <factor></factor></factor>      | The $-divide_by$ and $-multiply_by$ factors are based on the first rising edge of the clock, and extend or contract the waveform by the specified factors. For example, a $-divide_by$ 2 is equivalent to $-edges$ {1 3 5}. For multiplied clocks, the duty cycle can also be specified. The Quartus II TimeQuest Timing Analyzer supports specifying multiply and divide factors at the same time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| -duty_cycle <percent></percent>                                        | Specifies the duty cycle of the generated clock. The duty cycle is applied last.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| -add                                                                   | Allows you to specify more than one clock to the same pin.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Option                         | Description                                                                                                   |
|--------------------------------|---------------------------------------------------------------------------------------------------------------|
| -invert                        | Inversion is applied at the output of the clock after all other modifications are applied, except duty cycle. |
| -master_clock < <i>clock</i> > | $-{\tt master\_clock}$ is used to specify the clock if multiple clocks exist at the master pin.               |
| -phase < <i>phase</i> >        | Specifies the phase of the generated clock.                                                                   |
| -offset <offset></offset>      | Specifies the offset of the generated clock.                                                                  |
| <targets></targets>            | Specifies the port(s) or pin(s) to which the assignment applies.                                              |

#### Table 7–7. create\_generated\_clock Command Options (Part 2 of 2)

#### Note to Table 7-7:

(1) The Quartus II TimeQuest Timing Analyzer supports a maximum of three edges in the edge list.

Source latencies are based on clock network delays from the master clock (not necessarily the master pin). You can use the set\_clock\_latency -source command to override source latency.

Figure 7–20 shows how to create an inverted generated clock based on a 10 ns clock.

Figure 7–20. Generating an Inverted Clock



Figure 7–21 shows how to modify the generated clock using the -edges and -edge\_shift options.

#### Figure 7–21. Edges and Edge Shifting a Generated Clock



Figure 7–22 shows the effect of the -multiply\_by option on the generated clock.





# **Virtual Clocks**

A virtual clock is a clock that does not have a real source in the design or that does not interact directly with the design. For example, if a clock feeds only an external device's clock port and not a clock port in the design, and the external device then feeds (or is fed by) a port in the design, it is considered a virtual clock.

Use the create\_clock command to create virtual clocks, with no value specified for the source option.

You can use virtual clocks for set\_input\_delay and set\_output\_delay constraints.

Figure 7–23 shows an example where a virtual clock is required for the Quartus II TimeQuest Timing Analyzer to properly analyze the relationship between the external register and those in the design. Because the oscillator labeled virt\_clk does not interact with the Altera device, but acts as the clock source for the external register, the clock virt\_clk must be declared. Example 7–6 shows the command to create a 10 ns virtual clock named virt\_clk with a 50% duty cycle where the first rising edge occurs at 0 ns. The virtual clock is then used as the clock source for an output delay constraint.





After you create the virtual clock, you can perform register-to-register analysis between the register in the Altera device and the register in the external device.

### Example 7–6. Virtual Clock Example 1

```
#create base clock for the design
create_clock -period 5 [get_ports system_clk]
#create the virtual clock for the external register
create_clock -period 10 -name virt_clk -waveform { 0 5 }
#set the output delay referencing the virtual clock
set_output_delay -clock virt_clk -max 1.5 [get_ports dataout]
```

Example 7–7 shows the command to create a 10 ns virtual clock with a 50% duty cycle that is phase shifted by 90°.

Example 7–7. Virtual Clock Example 2

create\_clock -name virt\_clk -period 10 -waveform { 2.5 7.5 }

# **Multi-Frequency Clocks**

Certain designs have more than one clock source feeding a single clock port in the design. The additional clock may act as a low-power clock, with a lower frequency than the primary clock. To analyze this type of design, the create\_clock command supports the -add option that allows you to add more than one clock to a clock node.

Example 7–8 shows the command to create a 10 ns clock applied to clock port clk, and then add an additional 15 ns clock to the same clock port. The Quartus II TimeQuest Timing Analyzer uses both clocks when it performs timing analysis.

### Example 7–8. Multi-Frequency Example

```
create_clock -period 10 -name clock_primary -waveform { 0 5 } [get_ports
clk]
create_clock -period 15 -name clock_secondary -waveform { 0 7.5 }
[get_ports clk] -add
```

## **Automatic Clock Detection**

To create clocks for all clock nodes in your design automatically, use the derive\_clocks command. This command creates clocks on ports or registers to ensure every register in the design has a clock.

Example 7–9 shows the derive\_clocks command and options.

```
Example 7–9. derive_clocks Command
```

```
derive_clocks
[-period <period value>]
[-waveform <edge list>]
```

Table 7–8 describes the options for the derive\_clocks command.

Table 7-8. derive\_clocks Command Options

| Option                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -period <period value=""></period> | Creates the clock period. You can also specify the frequency as -period <num>MHz. (1)</num>                                                                                                                                                                                                                                                                                                                                                            |
| -waveform <edge list=""></edge>    | Creates the clock's rising and falling edges. The edge list alternates between the rising edge and falling edge. For example, for a 10 ns period where the first rising edge occurs at 0 ns and the first falling edge occurs at 5 ns, the edge list is waveform {0 5}. The difference must be within one period unit, and the rising edge must come before the falling edge. The default edge list is $\{0 \text{ period/2}\}$ , or a 50% duty cycle. |

## Note to Table 7–8:

(1) This option uses the default time unit nanoseconds (ns).

The derive\_clocks command does not create clocks for the output of the PLLs.

The derive\_clocks command is equivalent to using create\_clock for each register or port feeding the clock pin of a register.

Using the derive\_clocks command for final timing sign-off is not recommended. You should create clocks for all clock sources using the create\_clock and create\_generated\_clock commands.

# **Derive PLL Clocks**

PLLs are used for clock management and synthesis in Altera devices. You can customize the clocks generated from the outputs of the PLL based on design requirements. Because a clock should be created for all clock nodes, all outputs of the PLL should have an associated clock. You can manually create a clock for each output of the PLL with the create\_generated\_clock command, or you can use the derive\_pll\_clocks command, which automatically searches the timing netlist and creates generated clocks for all PLL outputs according to the settings specified for each PLL output.

Use the derive\_pll\_clocks command to automatically create a clock for each output of the PLL. Example 7–10 shows the derive\_pll\_clocks command and options.

Example 7–10. derive\_pll\_clocks Command

```
derive_pll_clocks
[-create_base_clocks]
[-use_tan_name]
```

Table 7–9 describes the options for the derive\_pll\_clocks command.

 Table 7–9.
 derive\_pll\_clocks Command Options

| Option              | Description                                                                                                                                             |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| -use_tan_name       | By default, the clock name is the output clock name. This option uses the net name similar to the names used by the Quartus II Classic Timing Analyzer. |
| -create_base_clocks | Creates the base clocks on input clock ports of the design that are feeding the PLL.                                                                    |

The derive\_pll\_clocks command calls the create\_generated\_clock command to create generated clocks on the outputs of the PLL. The source for the create\_generated\_clock command is the input clock pin of the PLL. Before or after the derive\_pll\_clocks command has been issued, you must manually create a base clock for the input clock port of the PLL. If a clock is not defined for the input clock node of the PLL, no clocks are reported for the PLL outputs. Instead, the Quartus II TimeQuest Timing Analyzer issues a warning message similar to Example 7–11 when the timing netlist is updated.

### Example 7–11. Warning Message

```
Warning: The master clock for this clock assignment could not be derived.
Clock: <name of PLL output clock pin name> was not created.
```

You can use the -create\_base\_clocks option to create the input clocks for the PLL inputs automatically.

You can include the derive\_pll\_clocks command in your .sdc file, which allows the derive\_pll\_clocks command to automatically detect any changes to the PLL. With the derive\_pll\_clocks command in your .sdc file, each time the file is read, the appropriate create\_generated\_clocks command for the PLL output clock pin is generated. If you use the write\_sdc-expand command after the derive\_pll\_clock command, the new .sdc file contains the individual create\_generated\_clock commands for the PLL output clock pins and not the derive\_pll\_clocks command. Any changes to the properties of the PLL are not automatically reflected in the new .sdc file. You must manually update the create\_generated\_clock commands in the new .sdc file written by the derive\_pll\_clocks command to reflect the changes to the PLL. The derive\_pll\_clocks constraint will also constrain any LVDS transmitters or LVDS receivers in the design by adding the appropriate multicycle constraints to account for any deserialization factors.

For example, Figure 7–24 shows a simple PLL design with a register-to-register path.

```
Figure 7-24. Simple PLL Design
```



Use the derive\_pll\_clocks command to automatically constrain the PLL. When this command is issued for the design shown in Figure 7–24, the messages shown in Example 7–12 are generated.

**Example 7–12.** derive\_pll\_clocks Generated Messages

```
Info:
Info: Deriving PLL Clocks:
Info: create_generated_clock -source
pll_inst|altpll_component|pll|inclk[0] -divide_by 2 -name
pll_inst|altpll_component|pll|clk[0]
pll_inst|altpll_component|pll|clk[0]
Info:
```

The node name pll\_inst|altpll\_component|pll|inclk[0] used for the source option refers to the input clock pin of the PLL. In addition, the name of the output clock of the PLL is the name of the PLL output clock node, pll\_inst|altpll\_component|pll|clk[0].

If the PLL is in clock switchover mode, multiple clocks are created for the output clock of the PLL; one for the primary input clock (for example, inclk[0]), and one for the secondary input clock (for example, inclk[1]). In this case, you should cut the primary and secondary output clocks using the set\_clock\_groups command with the -exclusive option.

Before you can generate any reports for this design, you must create a base clock for the PLL input clock port. Use a the following command or one similar:

create\_clock -period 5 [get\_ports pll\_inclk]

You do not have to generate the base clock on the input clock pin of the PLL: pll\_inst|altpll\_component|pll|inclk[0]. The clock created on the PLL input clock port propagates to all fan-outs of the clock port, including the PLL input clock pin.

# **Default Clock Constraints**

To provide a complete clock analysis, the Quartus II TimeQuest Timing Analyzer, by default, automatically creates clocks for all detected clock nodes in your design that have not be constrained, if there are no base clock constraints in the design. The Quartus II TimeQuest Timing Analyzer creates a base clock with a 1 GHz requirement to unconstrained clock nodes, using the following command:

derive\_clocks -period 1 🕶

Individual clock constraints (for example, create\_clock and create\_generated\_clock) should be made for all clocks in the design. This results in a thorough and realistic analysis of the design's timing requirements. Avoid using derive\_clocks for final timing sign-off.

The default clock constraint is only applied when the Quartus II TimeQuest Timing Analyzer detects that all synchronous elements have no clocks associated with them. For example, if a design contains two clocks and only one clock has constraints, the default clock constraint is not applied. However, if both clocks have not been constrained, the default clock constraint is applied.

## **Clock Groups**

Many clocks can exist in a design; however, not all of the clocks interact with one another and certain clock interactions are not possible.

Use the set\_clock\_groups command to specify clocks that are exclusive or asynchronous. Example 7–13 shows the set\_clock\_groups command and options.

Example 7–13. set\_clock\_groups Command

```
set_clock_groups
[-asynchronous | -exclusive]
-group <clock name>
[-group <clock name>]
[-group <clock name>] ...
```

Table 7–10 describes the options for the set\_clock\_groups command.

 Table 7–10.
 set\_clock\_groups
 Command
 Options

| Option                         | Description                                                                                                                                                |
|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -asynchronous                  | Asynchronous clocks—when the two clocks have no phase relationship and are active at the same time.                                                        |
| -exclusive                     | Exclusive clocks—when only one of the two clocks is active at any given time. An example of an exclusive clock group is when two clocks feed a 2-to-1 MUX. |
| -group <clock name=""></clock> | Specifies valid destination clock names that are mutually exclusive. < <i>clock name</i> > is used to specify the clock names.                             |

The exclusive option is used to declare when two clocks are mutually exclusive to each other and cannot coexist in the design at the same time. This can happen when multiple clocks are created on the same node or for multiplexed clocks. For example, a port can be clocked by either a 25-MHz or a 50-MHz clock. To constrain this port, two clocks should be created on the port with the create\_clock command, then use set\_clock\_groups -exclusive to declare that they cannot coexist in the design at the same time.

This eliminates any clock transfers that may be derived between the 25-MHz clock and the 50-MHz clock. Example 7–14 shows the constraints for this.

### Example 7–14. Exclusive Option

```
create_clock -period 40 -name clk_A [get_ports {port_A}]
create_clock -add -period 20 -name clk_B [get_ports {port_A}]
set_clock_groups -exclusive -group {clk_A} -group {clk_B}
```

A group is defined with the -group option. The TimeQuest Timing Analyzer cuts the timing paths between clocks each of the separate -groups groups.

The asynchronous option is used to group related and unrelated clocks. With the asynchronous option, clocks that are contained in groups are considered asynchronous to each other. Any clocks within each group are considered synchronous to each other.

For example, suppose you have three clocks: clk\_A, clk\_B, and clk\_C. The clocks clk\_A and clk\_B are related to each other, but clock clk\_C operates completely asynchronous with clk\_A or clk\_B. Example 7–15 makes clk\_A and clk\_B related in the same group and unrelated with the second group which contains clk\_C.

Example 7–15. Asynchronous Option Example 1

set\_clock\_groups -asynchronous -group {clk\_A clk\_B} -group {clk\_C}

Example 7–16 shows an alternative method of specifying the same constraint as Example 7–15.

**Example 7–16.** Asynchronous Option Example 2

```
set_clock_groups -asynchronous -group {clk_C}
```

This makes clk\_C unrelated with every other clock in the design because clk\_C is the only group in the constraint.

The TimeQuest Timing Analyzer assumes all clocks are related by default, unless constrained otherwise.

Example 7–17 shows a set\_clock\_groups command and the equivalent set\_false\_path commands.

Example 7–17. set\_clock\_groups

# Clocks A and C are never active when clocks B and D are active set\_clock\_groups -exclusive -group {A C} -group {B D} # Equivalent specification using false paths set\_false\_path -from [get\_clocks A] -to [get\_clocks B] set\_false\_path -from [get\_clocks A] -to [get\_clocks D] set\_false\_path -from [get\_clocks C] -to [get\_clocks B] set\_false\_path -from [get\_clocks C] -to [get\_clocks D] set\_false\_path -from [get\_clocks B] -to [get\_clocks A] set\_false\_path -from [get\_clocks B] -to [get\_clocks A] set\_false\_path -from [get\_clocks B] -to [get\_clocks C] set\_false\_path -from [get\_clocks D] -to [get\_clocks A] set\_false\_path -from [get\_clocks D] -to [get\_clocks A]

## **Clock Effect Characteristics**

The create\_clock and create\_generated\_clock commands create ideal clocks that do not account for any board effects. This section describes how to account for clock effect characteristics with clock latency and clock uncertainty.

## **Clock Latency**

There are two forms of clock latency: source and network. Source latency is the propagation delay from the origin of the clock to the clock definition point (for example, a clock port). Network latency is the propagation delay from a clock definition point to a register's clock pin. The total latency (or clock propagation delay) at a register's clock pin is the sum of the source and network latencies in the clock path.

IP

The set\_clock\_latency command supports only source latency. The -source option must be specified when using the command.

Use the set\_clock\_latency command to specify source latency to any clock ports in the design. Example 7–18 shows the set\_clock\_latency command and options.

**Example 7–18.** set\_clock\_latency Command

```
set_clock_latency
-source
[-clock <clock_list>]
[-rise | -fall]
[-late | -early]
<delay>
<targets>
```

Table 7–11 describes the options for the set\_clock\_latency command.

| Table 7–11. set_clock_latency | Command Options (Pa | art 1 of 2) |
|-------------------------------|---------------------|-------------|
|-------------------------------|---------------------|-------------|

| Option                         | Description                                                                      |
|--------------------------------|----------------------------------------------------------------------------------|
| -source                        | Specifies a source latency.                                                      |
| -clock <clock list=""></clock> | Specifies the clock to use if the target has more than one clock assigned to it. |
| -rise   -fall                  | Specifies the rising or falling delays.                                          |
| -late   -early                 | Specifies the earliest or the latest arrival times to the clock.                 |

| Option              | Description                                                                         |  |
|---------------------|-------------------------------------------------------------------------------------|--|
| <delay></delay>     | Specifies the delay value.                                                          |  |
| <targets></targets> | Specifies the clocks or clock sources if a clock is clocked by more than one clock. |  |

Table 7–11. set\_clock\_latency Command Options (Part 2 of 2)

The Quartus II TimeQuest Timing Analyzer automatically computes network latencies; therefore, the set\_clock\_latency command specifies only source latencies.

## **Clock Uncertainty**

The set\_clock\_uncertainty command specifies clock uncertainty or skew for clocks or clock-to-clock transfers. Specify the uncertainty separately for setup and hold. Specify separate rising and falling clock transitions. The Quartus II TimeQuest Timing Analyzer subtracts setup uncertainty from the data required time for each applicable path and adds the hold uncertainty to the data required time for each applicable path.

Use the set\_clock\_uncertainty command to specify any clock uncertainty to the clock port. Example 7–19 shows the set\_clock\_uncertainty command and options.

Example 7–19. set\_clock\_uncertainty Command and Options

```
set_clock_uncertainty
[-rise_from <rise from clock> | -fall_from <fall from clock> |
    -from <from clock>]
[-rise_to <rise to clock> | -fall_to <fall to clock> | -to <to clock>]
[-setup | -hold]
<value>
-add
```

Table 7–12 describes the options for the set\_clock\_uncertainty command.

 Table 7–12.
 set\_clock\_uncertainty Command Options

| Option                                    | Description                                                                                                                               |
|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| -from <from clock=""></from>              | Specifies the from clock.                                                                                                                 |
| -rise_from <rise clock="" from=""></rise> | Specifies the rise-from clock.                                                                                                            |
| -fall_from <fall clock="" from=""></fall> | Specifies the fall-from clock.                                                                                                            |
| -to <to clock=""></to>                    | Specifies the to clock.                                                                                                                   |
| -rise_to <rise clock="" to=""></rise>     | Specifies the rise-to clock.                                                                                                              |
| -fall_to <fall clock="" to=""></fall>     | Specifies the fall-to clock.                                                                                                              |
| -setup   -hold                            | Specifies setup or hold.                                                                                                                  |
| <value></value>                           | Uncertainty value.                                                                                                                        |
| -add                                      | Specifies that the uncertainty < <i>value</i> > should be added to the uncertainty value derived by the derive_clock_uncertainty command. |
# **Derive Clock Uncertainty**

Use the derive\_clock\_uncertainty command to automatically apply inter-clock, intra-clock, and I/O interface uncertainties. Both setup and hold uncertainties are calculated for each clock-to-clock transfer. Example 7–20 shows the derive\_clock\_uncertainty command and options.

#### Example 7–20. derive\_clock\_uncertainty Command

```
derive_clock_uncertainty
[-overwrite]
[-add]
```

Table 7–13 describes the options for the derive\_clock\_uncertainty command.

Table 7–13. derive\_clock\_uncertainty Command Options

| Option     | Description                                                                         |
|------------|-------------------------------------------------------------------------------------|
| -overwrite | Overwrites previously performed clock uncertainty assignments.                      |
| -add       | Adds derived uncertainty results to any user-defined clock uncertainty assignments. |

The Quartus II TimeQuest Timing Analyzer automatically applies clock uncertainties to clock-to-clock transfers in the design.

Any clock uncertainty constraints that have been applied to source and destination clock pairs with the set\_clock\_uncertainty command have a higher precedence than the clock uncertainties derived from the derive\_clock\_uncertainty command for the same source and destination clock pairs. For example, if set\_clock\_uncertainty is applied between clka and clkb, the derive\_clock\_uncertainty values for the clock transfer is ignored by default. The set\_clock\_uncertainty constraint has priority over the derive\_clock\_uncertainty constraint.

The clock uncertainty value that would have been used; however, is still reported for informational purposes. You can use the -overwrite command to overwrite previous clock uncertainty assignments, or remove them manually with the remove\_clock\_uncertainty command. You can also use the -add option to add clock uncertainty determined by the derive\_clock\_uncertainty command to any previously defined clock uncertainty value.

The following list shows the types of clock-to-clock transfers in which clock certainties can arise. They are modeled by the derive\_clock\_uncertainty command automatically.

- Inter-clock
- Intra-clock
- I/O Interface

I Altera recommends using the derive\_clock\_uncertainty command.

#### **Intra-Clock Transfers**

Intra-clock transfers occur when the register-to-register transfer happens in the core of the FPGA and source and destination clocks come from the same PLL output pin or clock port. An example of an intra-clock transfer is shown in Figure 7–25.





#### **Inter-Clock Transfers**

Inter-clock transfers occur when a register-to-register transfer happens in the core of the FPGA and source and destination clocks come from a different PLL output pin or clock port. An example of an inter-clock transfer is shown in Figure 7–26.

#### Figure 7-26. Inter-Clock Transfer



## I/O Interface Clock Transfers

I/O interface clock transfers occur when data transfers from an I/O port to the core of the FPGA (input) or from the core of the FPGA to the I/O port (output). An example of an I/O interface clock transfer is shown in Figure 7–27.





For I/O interface uncertainty, you must create a virtual clock and constrain the input and output ports with the set\_input\_delay and set\_output\_delay commands that reference the virtual clock. The virtual clock is required to prevent the derive\_clock\_uncertainty command from applying clock uncertainties for either intra- or inter-clock transfers on an I/O interface clock transfer when the set\_input\_delay or set\_output\_delay commands reference a clock port or PLL output. If a virtual clock is not referenced in the set\_input\_delay or set\_output\_delay commands, the derive\_clock\_uncertainty command calculates intra- or inter-clock uncertainty value for the I/O interface. Create the virtual clock with the same properties as the original clock that is driving the I/O port. For example, Figure 7–28 shows a typical input I/O interface with the clock specifications.





Example 7–21 shows the SDC commands to constrain the I/O interface shown in Figure 7–28.

**Example 7–21.** SDC Commands to Constrain the I/O Interface

```
# Create the base clock for the clock port
create_clock -period 10 -name clk_in [get_ports clk_in]
# Create a virtual clock with the same properties of the base clock
# driving the source register
create_clock -period 10 -name virt_clk_in
# Create the input delay referencing the virtual clock and not the base
# clock
# DO NOT use set_input_delay -clock clk_in <delay_value>
# [get_ports data_in]
set_input_delay -clock virt_clk_in <delay value> [get_ports data_in]
```

# I/O Specifications

The Quartus II TimeQuest Timing Analyzer supports Synopsys Design Constraints that constrain the ports in your design. These constraints allow the Quartus II TimeQuest Timing Analyzer to perform a system static timing analysis that includes not only the FPGA internal timing, but also any external device timing and board timing parameters.

## **Input and Output Delay**

Use input and output delay constraints to specify any external device or board timing parameters. When you apply these constraints, the Quartus II TimeQuest Timing Analyzer performs static timing analysis on the entire system.

#### **Set Input Delay**

The set\_input\_delay constraint specifies the data arrival time at a port (a device I/O) with respect to a given clock. Figure 7–29 shows an input delay path.

#### Figure 7-29. Set Input Delay



Use the set\_input\_delay command to specify input delay constraints to ports in the design. Example 7-22 shows the set\_input\_delay command and options.

**Example 7–22.** set\_input\_delay Command

```
set_input_delay
-clock <clock name>
[-clock_fall]
[-rise | -fall]
[-max | -min]
[-add_delay]
[-reference_pin <target>]
[-source_latency_included]
<delay value>
<targets>
```

Table 7–14 describes the options for the set\_input\_delay command.

 Table 7–14.
 set\_input\_delay Command Options

| Option                           | Description                                                                                                                                                                   |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -clock < <i>clock name</i> >     | Specifies the source clock.                                                                                                                                                   |
| -clock_fall                      | Specifies the arrival time with respect to the falling edge of the clock.                                                                                                     |
| -rise   -fall                    | Specifies either the rise or fall delay at the port.                                                                                                                          |
| -max   -min                      | Specifies the minimum or maximum data arrival time.                                                                                                                           |
| -add_delay                       | Adds another delay, but does not replace the existing delays assigned to the port.                                                                                            |
| -reference_pin < <i>target</i> > | Specifies a pin or port in the design from which to determine source and network latencies. This is useful to specify input delays relative to an output port fed by a clock. |
| -source_latency_ included        | Specifies that the input delay value includes the source latency delay value; therefore, any source clock latency assigned to the clock is ignored.                           |
| <delay value=""></delay>         | Specifies the delay value.                                                                                                                                                    |
| <targets></targets>              | Specifies the destination ports or pins.                                                                                                                                      |

A warning message appears if you specify only a -max or -min value for the input delay value. The input minimum delay default value is equal to the input maximum delay; the input maximum delay default value is equal to the input minimum delay, if only one is specified. Similarly, a warning message appears if you specify only a -rise or -fall value for the delay value, and the delay defaults in the same manner as the input minimum and input maximum delays.

The maximum value is used for setup checks; the minimum value is used for hold checks.

By default, a set of input delays (min/max, rise/fall) is allowed for only one -clock, -clock\_fall, -reference\_pin combination. Specifying an input delay on the same port for a different clock, -clock\_fall or -reference\_pin removes any previously set input delays, unless you specify the -add\_delay option. When you specify the -add\_delay option, the worst-case values are used.

The -rise and -fall options are mutually exclusive, as are the -min and -max options.

#### **Set Output Delay**

The set\_output\_delay command specifies the data required time at a port (the device pin) with respect to a given clock.

Use the set\_output\_delay command to specify output delay constraints to ports in the design. Figure 7–30 shows an output delay path.

Figure 7–30. Output Delay



Example 7–23 shows the set\_output\_delay command and options.

#### Example 7-23. set\_output\_delay Command

```
set_output_delay
-clock <clock name>
[-clock_fall]
[-rise | -fall]
[-max | -min]
[-add_delay]
[-reference_pin <target>]
<delay value>
<targets>
```

Table 7–15 describes the options for the set\_output\_delay command.

 Table 7–15.
 set\_output\_delay Command Options (Part 1 of 2)

| Option                       | Description                                                                        |
|------------------------------|------------------------------------------------------------------------------------|
| -clock < <i>clock nam</i> e> | Specifies the source clock.                                                        |
| -clock_fall                  | Specifies the required time with respect to the falling edge of the clock.         |
| -rise   -fall                | Specifies either the rise or fall delay at the port.                               |
| -max   -min                  | Specifies the minimum or maximum data arrival time.                                |
| -add_delay                   | Adds another delay, but does not replace the existing delays assigned to the port. |

| Option                           | Description                                                                                                                                                                    |
|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -reference_pin <target></target> | Specifies a pin or port in the design from which to determine source and network latencies. Use this option to specify input delays relative to an output port fed by a clock. |
| -source_latency_included         | Specifies that the input delay value includes the source latency delay value; therefore, any source clock latency assigned to the clock will subsequently be ignored.          |
| <delay value=""></delay>         | Specifies the delay value.                                                                                                                                                     |
| <targets></targets>              | Specifies the destination ports or pins.                                                                                                                                       |

Table 7–15. set\_output\_delay Command Options (Part 2 of 2)

A warning message appears if you specify only a -max or -min value for the output delay value. The output minimum delay default value is the output maximum delay; the output maximum delay default value is the output minimum delay, if only one is specified.

The maximum value is used for setup checks; the minimum value is used for hold checks.

By default, a set of output delays (min/max, rise/fall) is allowed for only one clock, -clock\_fall, port combination. Specifying an output delay on the same port for a different clock or -clock\_fall removes any previously set output delays, unless you specify the -add\_delay option. When you specify the -add\_delay option, the worst-case values are used.

The -rise and -fall options are mutually exclusive, as are the -min and -max options.

# **Delay and Skew Specifications**

The TimeQuest Timing Analyzer supports the ability to specify and report maximum, minimum, and skew delays between a source and destination points.

## set\_net\_delay

Use the set\_net\_delay command in conjunction with the report\_net\_delay command to report the net delays and perform minimum or maximum analysis across nets. Example 7–24 shows the set\_net\_delay command and options.

The set\_net\_delay and report\_net\_delay commands can be used when verifying timing-critical delays for high-speed interfaces. For example, the command can be used to report the delay across a high-speed data bus for each bit.

#### Example 7–24. set\_net\_delay Command

```
set_net_delay
   -from <names>
   [-max]
   [-to <names>]
   [-min]
   <delay>
```

Table 7–16 describes the options for the set\_net\_delay command.

| Option                | Description                                                                                                                                                                             |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -from <names></names> | Valid source pins or ports (string patterns are matched using Tcl string matching).                                                                                                     |
| -max                  | Specifies maximum delay.                                                                                                                                                                |
| -min                  | Specifies minimum delay.                                                                                                                                                                |
| -to <names></names>   | Valid destination pins or ports (string patterns are matched using Tcl string matching). If $-to$ is left unspecified, the missing value or values are substituted by an "*" character. |
| <delay></delay>       | Required delay.                                                                                                                                                                         |

| Table 7–16. | set | net | delay | Command | Options |
|-------------|-----|-----|-------|---------|---------|
|-------------|-----|-----|-------|---------|---------|

When the -min option is specified, the slack is calculated with the minimum edge delay. When the -max option is specified, the slack is calculated with the maximum edge delay. When the -skew option is specified, the slack is calculated across all the valid edges that satisfy the -from and -to filters.

#### set\_max\_skew

Use the set\_max\_skew command to specify the maximum path-based skew requirements for registers and ports in the design. Example 7–25 shows the set\_max\_delay command and options.

**Example 7–25.** set\_max\_skew

```
set_max_skew
[-exclude <Tcl list>]
[-from <names>]
[-include <Tcl list>]
[-to <names>]
<skew>
```

Table 7–17 describes the options for the set\_max\_skew command.

| Table 7–17. | set_max_ | _skew | Command | Options |
|-------------|----------|-------|---------|---------|
|-------------|----------|-------|---------|---------|

| Option                 | Description                                                                                                                                                                                    |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -exclude <list></list> | A list of parameters to exclude during skew analysis. This list can include 1 or more of the following: utsu, uth, utco, from_clock, to_clock, clock_uncertainty, input_delay, output_delay.   |
| -from <names></names>  | Valid sources (string patterns are matched using Tcl string matching)                                                                                                                          |
| -include <list></list> | Tcl list of parameters to include during skew analysis. This list can include 0 or more of the following: utsu, uth, utco, from_clock, to_clock, clock_uncertainty, input_delay, output_delay. |
| -to <names></names>    | Valid destinations (string patterns are matched using Tcl string matching)                                                                                                                     |
| <skew></skew>          | Required maximum skew                                                                                                                                                                          |

P

By default, the set\_max\_skew command excludes set\_input\_delay, set\_output\_delay, utsu and uth.

When this constraint is used, the results of max skew analysis are reported with the command report\_max\_skew.

For more information about the report\_max\_skew command, refer to "report\_max\_skew" on page 7–69.

# **Timing Exceptions**

Timing exceptions modify the default analysis performed by the Quartus II TimeQuest Timing Analyzer. This section describes the following available timing exceptions:

- "False Path" on page 7–44
- "Minimum Delay" on page 7–45
- "Maximum Delay" on page 7–46
- "Multicycle Path" on page 7–47

## Precedence

If a conflict of node names occurs between timing exceptions, the following order of precedence applies:

- 1. False path
- 2. Minimum delays and maximum delays
- 3. Multicycle path

The false path timing exception has the highest precedence. Within each category, assignments to individual nodes have precedence over assignments to clocks. Finally, the remaining precedence for additional conflicts is order-dependent, such that the last assignments overwrite (or partially overwrite) earlier assignments.

# **False Path**

False paths are paths that can be ignored during timing analysis.

Use the set\_false\_path command to specify false paths in the design. Example 7–26 shows the set\_false\_path command and options.

**Example 7–26.** set\_false\_path Command

```
set_false_path
[-fall_from <clocks> | -rise_from <clocks> | -from <names>]
[-fall_to <clocks> | -rise_to <clocks> | -to <names>]
[-hold]
[-setup]
[-through <names>]
<delay>
```

Table 7–18 describes the options for the set\_false\_path command.

| Table 7-18. | set | false | path | Command | Options |
|-------------|-----|-------|------|---------|---------|
|-------------|-----|-------|------|---------|---------|

| Option                       | Description                                                                                                                                     |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| -fall_from <clocks></clocks> | The $<$ names $>$ is a collection or list of objects in the design. Specifies false path begins at the fall from $<$ clocks $>$ .               |
| -fall_to < <i>clocks</i> >   | The <names> is a collection or list of objects in the design. Specifies false path ends at the fall to &lt;<i>clocks</i>&gt;.</names>           |
| -from <names></names>        | The < <i>names</i> > is a collection or list of objects in the design. Specifies false path begins at the < <i>names</i> >.                     |
| -hold                        | Specifies the false path is valid during the hold analysis only.                                                                                |
| -rise_from <clocks></clocks> | The $<$ <i>names</i> $>$ is a collection or list of objects in the design. Specifies false path begins at the rise from $<$ <i>clocks</i> $>$ . |
| -rise_to < <i>clocks</i> >   | The $<$ names> is a collection or list of objects in the design. Specifies false path ends at the rise to $<$ clocks>.                          |
| -setup                       | Specifies the false path is valid during the setup analysis only.                                                                               |
| -through <names></names>     | The < <i>names</i> > is a collection or list of objects in the design. Specifies false path passes through < <i>names</i> >.                    |
| -to <names></names>          | The < <i>names</i> > is a collection or list of objects in the design. Specifies false path ends at < <i>names</i> >.                           |
| <delay></delay>              | Specifies the delay value.                                                                                                                      |

When the objects are timing nodes, the false path only applies to the path between the two nodes. When an object is a clock, the false path applies to all paths where the source node (-from) or destination node (-to) is clocked by the clock.

# **Minimum Delay**

Use the set\_min\_delay command to specify an absolute minimum delay for a given path. Example 7–27 shows the set\_min\_delay command and options.

**Example 7–27.** set\_min\_delay Command

```
set_min_delay
[-fall_from <clocks> | -rise_from <clocks> | -from <names>]
[-fall_to <clocks> | -rise_to <clocks> | -to <names>]
[-through <names>]
<delay>
```

Table 7–19 describes the options for the set\_min\_delay command.

| Table 7–19. | set_min | _delay Command Options | (Part 1 of 2) |
|-------------|---------|------------------------|---------------|
|-------------|---------|------------------------|---------------|

| Option                       | Description                                                                                                                                         |
|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| -fall_from <clocks></clocks> | The < <i>names</i> > is a collection or list of objects in the design. Specifies the minimum delay begins at the falling edge of < <i>clocks</i> >. |
| -fall_to < <i>clocks</i> >   | The <i>&lt; names</i> > is a collection or list of objects in the design. Specifies the minimum delay ends at the falling of <i>&lt; clocks</i> >.  |
| -from <names></names>        | The < <i>names</i> > is a collection or list of objects in the design. The < <i>names</i> > acts as the start point of the path.                    |

| Option                       | Description                                                                                                                                       |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| -rise_from <clocks></clocks> | The <i>&lt; names</i> > is a collection or list of objects in the design. Specifies the minimum delay at the rising edge of <i>&lt; clocks</i> >. |
| rise_to < <i>clocks</i> >    | The $<$ names $>$ is a collection or list of objects in the design. Specifies the minimum delay at the rising edge of $<$ clocks $>$ .            |
| -through <names></names>     | The < <i>names</i> > is a collection or list of objects in the design. The < <i>names</i> > acts as the through point of the path.                |
| -to <names></names>          | The < <i>names</i> > is a collection or list of objects in the design. The < <i>names</i> > acts as the end point of the path.                    |
| <delay></delay>              | Specifies the delay value.                                                                                                                        |

|  | Table 7-19. | set min | delay Command Options | (Part 2 of | 2) |
|--|-------------|---------|-----------------------|------------|----|
|--|-------------|---------|-----------------------|------------|----|

If the source or destination node is clocked, the clock paths are taken into account, allowing more or less delay on the data path. If the source or destination node has an input or output delay, that delay is also included in the minimum delay check.

When the objects are timing nodes, the minimum delay applies only to the path between the two nodes. When an object is a clock, the minimum delay applies to all paths where the source node (-from) or destination node (-to) is clocked by the clock.

You can apply the set\_min\_delay command exception to an output port that does not use a set\_output\_delay constraint. In this case, the setup summary and hold summary report the slack for these paths. Because there is no clock associated with the output port, no clock is reported for these paths and the Clock column is empty. In this case, you cannot report timing for these paths.

P

To report timing using clock filters for output paths with the set\_min\_delay command, you can use the set\_output\_delay command for the output port with a value of 0. You can use an existing clock from the design or a virtual clock as the clock reference in the set\_output\_delay command.

## **Maximum Delay**

Use the set\_max\_delay command to specify an absolute maximum delay for a given path. Example 7–28 shows the set\_max\_delay command and options.

**Example 7–28.** set\_max\_delay Command

```
set_max_delay
[-fall_from <clocks> | -rise_from <clocks> | -from <names>]
[-fall_to <clocks> | -rise_to <clocks> | -to <names>]
[-through <names>]
<delay>
```

Table 7–20 describes the options for the set\_max\_delay command.

Table 7–20. set\_max\_delay Command Options

| Option                       | Description                                                                                                                                                              |
|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -fall_from <clocks></clocks> | The <i>&lt; names</i> > is a collection or list of objects in the design. Specifies the maximum delay begins at the falling edge of <i><clocks< i="">&gt;.</clocks<></i> |
| -fall_to < <i>clocks</i> >   | The <i>&lt; names</i> > is a collection or list of objects in the design. Specifies the maximum delay ends at the falling of <i>&lt; clocks</i> >.                       |
| -from <names></names>        | The < <i>names</i> > is a collection or list of objects in the design. The < <i>names</i> > acts as the start point of the path.                                         |
| -rise_from <clocks></clocks> | The $<$ names $>$ is a collection or list of objects in the design. Specifies the maximum delay at the rising edge of $<$ clocks $>$ .                                   |
| rise_to < <i>clocks</i> >    | The $<$ names $>$ is a collection or list of objects in the design. Specifies the maximum delay at the rising edge of $<$ clocks $>$ .                                   |
| -through <names></names>     | The < <i>names</i> > is a collection or list of objects in the design. The < <i>names</i> > acts as the through point of the path.                                       |
| -to <names></names>          | The < <i>names</i> > is a collection or list of objects in the design. The < <i>names</i> > acts as the end point of the path.                                           |
| <delay></delay>              | Specifies the delay value.                                                                                                                                               |

If the source or destination node is clocked, the clock paths are taken into account, allowing more or less delay on the data path. If the source or destination node has an input or output delay, that delay is also included in the maximum delay check.

When the objects are timing nodes, the maximum delay only applies to the path between the two nodes. When an object is a clock, the maximum delay applies to all paths where the source node (-from) or destination node (-to) is clocked by the clock.

You can apply the set\_max\_delay command exception to an output port that does not use a set\_output\_delay constraint. In this case, the setup summary and hold summary report the slack for these paths. Because there is no clock associated with the output port, no clock is reported for these paths and the Clock column is empty. In this case, you cannot report timing for these paths.

To report timing using clock filters for output paths with the set\_max\_delay command, you can use the set\_output\_delay command for the output port with a value of 0. You can use an existing clock from the design or a virtual clock as the clock reference in the set\_output\_delay command.

## **Multicycle Path**

By default, the Quartus II TimeQuest Timing Analyzer uses a single-cycle analysis. When analyzing a path, the setup launch and latch edge times are determined by finding the closest two active edges in the respective waveforms. For a hold analysis, the timing analyzer analyzes the path against two timing conditions for every possible setup relationship, not just the worst-case setup relationship. Therefore, the hold launch and latch times may be completely unrelated to the setup launch and latch edges. A multicycle constraint relaxes setup or hold relationships by the specified number of clock cycles based on the source (-start) or destination (-end) clock. An end multicycle constraint of 2 extends the worst-case setup latch edge by one destination clock period.

Hold multicycle constraints are based on the default hold position (the default value is 0). An end hold multicycle constraint of 1 effectively subtracts one destination clock period from the default hold latch edge.

Use the set\_multicycle\_path command to specify the multicycle constraints in the design. Example 7–29 shows the set\_multicycle\_path command and options.

Example 7–29. set\_multicycle\_path Command

```
set_multicycle_path
[-end]
[-fall_from <clocks> | -rise_from <clocks> | -from <names>]
[-fall_to <clocks> | -rise_to <clocks> | -to <names>]
[-hold]
[-setup]
[-start]
[-through <names>]
<path multiplier>
```

Table 7-21 describes the options for the set\_multicycle\_path command.

Table 7-21. set\_multicycle\_path Command Options

| Option                       | Description                                                                                                                                                 |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| fall_from < <i>clocks</i> >  | The <i>&lt; names&gt;</i> is a collection or list of objects in the design. Specifies the multicycle begins at the falling edge of <i>&lt; clocks&gt;</i> . |
| fall_to < <i>clocks</i> >    | The <i>&lt; names&gt;</i> is a collection or list of objects in the design. Specifies the multicycle ends at the falling of <i>&lt; clocks&gt;</i> .        |
| -from < <i>names</i> >       | The < <i>names</i> > is a collection or list of objects in the design. The < <i>names</i> > acts as the start point of the path.                            |
| -hold   -setup               | Specifies the type of multicycle to be applied.                                                                                                             |
| -rise_from < <i>clocks</i> > | The < <i>names</i> > is a collection or list of objects in the design. Specifies the multicycle at the rising edge of < <i>clocks</i> >.                    |
| -rise_to < <i>clocks</i> >   | The $<$ names $>$ is a collection or list of objects in the design. Specifies the multicycle ends at the rising edge of $<$ clocks $>$ .                    |
| -start   -end                | Specifies whether the start or end clock acts as the source or destination for the multicycle.                                                              |
| -through <names></names>     | The < <i>names</i> > is a collection or list of objects in the design. Specifies multicycle passes through < <i>names</i> >.                                |
| -to <names></names>          | The < <i>names</i> > is a collection or list of objects in the design. The < <i>names</i> > acts as the end point of the path.                              |
| <path multiplier=""></path>  | Specifies the multicycle multiplier value.                                                                                                                  |

When the objects are timing nodes, the multicycle constraint only applies to the path between the two nodes. When an object is a clock, the multicycle constraint applies to all paths where the source node (-from) or destination node (-to) is clocked by the clock.

## **Annotated Delay**

Use the set\_annotated\_delay command to annotate the cell delay between two or more pins/nodes on a cell, or the interconnect delay between two or more pins on the same net, in the current design. The annotated delay can be specified for specific transition edges: rise-rise, fall-rise, rise-fall, and fall-fall, and can also set different minimum and maximum values.



If no transition is specified, the given delay is assigned to all four values. Options -max and -min allow users to specify maximum or minimum delay.

Example 7-30 shows the set\_annotated command and options.

Example 7–30. set\_annotated\_delay Command

```
set_annotated_delay
  [-cell|-net]
  [-from <names>]
  [-max|-min]
  [-operating_conditions <operating_conditions>]
  [-rr|-fr|-rf|-ff]
  [-to <names>]
  <delay>
```

Table 7–22 describes the options for the set\_annotated\_delay command.

Table 7–22. set\_annotated\_delay Command Options

| Options                                                             | Description                                                                                                                                             |
|---------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| -cell                                                               | Specifies that cell delay must be set.                                                                                                                  |
| -ff                                                                 | Specifies that FF delay must be set.                                                                                                                    |
| -fr                                                                 | Specifies that FR delay must be set.                                                                                                                    |
| -from <names></names>                                               | Valid source pins or ports (string patterns are matched using Tcl string matching). If $-from$ value is left unspecified, the "*" character is used.    |
| -max                                                                | Specifies that only the maximum delay should be set.                                                                                                    |
| -min                                                                | Specifies that only the minimum delay should be set.                                                                                                    |
| -net                                                                | Specifies that net delay must be set.                                                                                                                   |
| -operating_conditions <operating_conditions></operating_conditions> | Specifies the operating conditions Tcl object. Refer to Table 7–51 on page 7–75 for the operating conditions Tcl object.                                |
| -rf                                                                 | Specifies that RF delay must be set.                                                                                                                    |
| -rr                                                                 | Specifies that RR delay must be set.                                                                                                                    |
| -to <names></names>                                                 | Valid destination pins or ports (string patterns are matched using Tcl string matching). If $-to$ value is left unspecified, the "*" character is used. |
| <delay></delay>                                                     | The delay value in default time units.                                                                                                                  |

With the -operation\_conditions option, different operating conditions can be specified in a single **.sdc** file, removing the requirement of having multiple **.sdc** files that specify different operating conditions.

The delay annotation is deferred until the next time update\_timing\_netlist is called. To remove annotated delays, use the remove\_annotated\_delay command.

# **Application Examples**

This section describes specific examples for the set\_multicycle\_path command.

Figure 7–31 shows a register-to-register path where the source clock, src\_clk, has a period of 10 ns and the destination clock, dst\_clk, has a period of 5 ns.

Figure 7–31. Register-to-Register Path



Figure 7–32 shows the respective timing diagrams for the source and destination clocks and the default setup and hold relationships. The default setup relationship is 5 ns; the default hold relationship is 0 ns.

Figure 7–32. Default Setup and Hold Timing Diagram



The default setup and hold relationships can be modified with the set\_multicycle\_path command to accommodate system requirements.

Table 7–23 shows the commands used to modify either the launch or latch edge times that the TimeQuest Timing Analyzer uses to determine a setup relationship or hold relationship.

| Table 7–23. | Commands to | Modify Edge Times |
|-------------|-------------|-------------------|
|-------------|-------------|-------------------|

| Command                           | Description of Modification                |
|-----------------------------------|--------------------------------------------|
| set_multicycle_path -setup -end   | Latch edge time of the setup relationship  |
| set_multicycle_path -setup -start | Launch edge time of the setup relationship |
| set_multicycle_path -hold -end    | Latch edge time of the hold relationship   |
| set_multicycle_path -hold -start  | Launch edge time of the hold relationship  |

Figure 7–33 shows the command used to modify the setup latch edge and the resulting timing diagram. The command moves the latch edge time to 10 ns from the default 5 ns.

#### Figure 7–33. Modified Setup Diagram



# **Constraint and Exception Removal**

When using the Quartus II TimeQuest Timing Analyzer interactively, it is usually necessary to remove a constraint or exception. In cases where constraints and exceptions either become outdated or have been erroneously entered, the Quartus II TimeQuest Timing Analyzer provides a convenient way to remove them.

Table 7–24 lists commands that allow you to remove constraints and exceptions from a design.

**Table 7–24.** Constraint and Exception Removal

| Command                                                                                 | Description                                                                                                                        |
|-----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| <pre>remove_clock [-all] [<clock list="">]</clock></pre>                                | Removes any clocks specified by $< clock list >$ that have been previously created. The $-all$ option removes all declared clocks. |
| remove_clock_groups -all                                                                | Removes all clock groups previously created. Specific clock groups cannot be removed.                                              |
| <pre>remove_clock_latency -source <targets></targets></pre>                             | Removes the clock latency constraint from the clock specified by < <i>targets</i> >.                                               |
| <pre>remove_clock_uncertainty -from <from clock=""> -to <to clock=""></to></from></pre> | Removes the clock uncertainty constraint from <i><from clock=""></from></i> to <i><to clock=""></to></i> .                         |
| remove_input_delay <targets></targets>                                                  | Removes the input delay constraint from < targets>.                                                                                |
| remove_output_delay <targets></targets>                                                 | Removes the output delay constraint from < targets>.                                                                               |
| remove_annotated_delay -all                                                             | Removes any annotated delay specified with the set_annotated_delay command.                                                        |
| reset_design                                                                            | Removes all constraints and exceptions in the design.                                                                              |

# **Timing Reports**

The Quartus II TimeQuest Timing Analyzer provides real-time static timing analysis result reports. Reports are generated only when requested. You can customize which report to display specific timing information, excluding those fields not required.

This section describes various report generation commands supported by the Quartus II TimeQuest Timing Analyzer.

# report\_timing

Use the report\_timing command to generate a setup, hold, recovery, or removal report. Example 7–31 shows the report\_timing command and options.

**Example 7–31.** report\_timing Command

```
report_timing
[-append]
[-detail <summary/path_only/path_and_clock/full_path>]
[-fall_to_clock <names> | -rise_to_clock <names>]
[-to <names> |-to_clock <names>]
[-false_path]
[-file <name>]
[-from <names>]
[-from_clock <names>|-rise_from_clock <names>|-fall_from_clock <names>]
[-less_than_slack <slack limit>]
[-npaths <number>]
[-nworst <number>]
[-pairs_only]
[-panel_name < name > ]
[-setup|-hold|-recovery|-removal]
[-show_routing]
[-stdout]
[-through <names>]
```

Table 7–25 describes the options for the report\_timing command.

 Table 7–25.
 report\_timing Command Options (Part 1 of 2)

| Option                                                                                                                  | Description                                                                                                                                                                      |
|-------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -append                                                                                                                 | If output is sent to a file, this option appends the result to that file.<br>Otherwise, the file is overwritten.                                                                 |
| -detail <summary <="" path_only="" td=""><td>Specifies whether or not the clock path detail is reported:</td></summary> | Specifies whether or not the clock path detail is reported:                                                                                                                      |
| path_and_clock/full_path>                                                                                               | Path Only: Clock network delay is lumped together                                                                                                                                |
|                                                                                                                         | Summary: Lists each individual path                                                                                                                                              |
|                                                                                                                         | Path and Clock: Clock network delay is shown in detail                                                                                                                           |
|                                                                                                                         | Full Path: More clock network details, in particular for generated clocks                                                                                                        |
| -fall_from_clock <names></names>                                                                                        | Specifies the falling edge of the < <i>names</i> > from the source register to be analyzed. The options from_clock, fall_from_clock, and rise_from_clock are mutually exclusive. |
| -fall_to_clock <names></names>                                                                                          | Specifies the falling edge of the < <i>names</i> > to the destination register to be analyzed; the options to_clock, fall_to_clock, and rise_to_clock are mutually exclusive.    |
| -false_path                                                                                                             | Reports only paths that are cut by a false path assignment.                                                                                                                      |
| -file <names></names>                                                                                                   | Sends the results to an ASCII or HTML file. The extension specified in the file name determines the file type either <b>*.rpt</b> , <b>*.txt</b> , or <b>*.html</b> .            |
| -hold                                                                                                                   | Specifies a clock hold analysis.                                                                                                                                                 |
| -less_than_slack < <i>slack limit</i> >                                                                                 | Limits the paths to be reported to the < <i>slack limit</i> > value.                                                                                                             |
| -npaths <number></number>                                                                                               | Specifies the number of paths to report.                                                                                                                                         |
| -nworst <number></number>                                                                                               | Restricts the number of paths per endpoint.                                                                                                                                      |
| -panel_name <names></names>                                                                                             | Specifies the name of the panel in the <b>Reports</b> pane.                                                                                                                      |

| Option                            | Description                                                                                                                                                                     |
|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -panel_name < <i>names</i> >      | Sends the results to the panel and specifies the name of the new panel.                                                                                                         |
| -pairs_only                       | When set, paths with the same start and end points are considered equivalent; only the worst-case path for each unique combination is displayed.                                |
| -recovery                         | Specifies a recovery analysis.                                                                                                                                                  |
| -removal                          | Specifies a removal analysis.                                                                                                                                                   |
| -rise_from_clock < <i>names</i> > | Specifies the rising edge of the < <i>names</i> > from the source register to be analyzed; the options from_clock, fall_from_clock, and rise_from_clock are mutually exclusive. |
| -rise_to_clock <names></names>    | Specifies the rising edge of the < <i>names</i> > to the destination register to be analyzed; the options to_clock, fall_to_clock, and rise_to_clock are mutually exclusive.    |
| -setup                            | Specifies a clock setup analysis.                                                                                                                                               |
| -show_routing                     | Displays detailed routing in the path.                                                                                                                                          |
| -stdout                           | Indicates the report will be sent to stdout.                                                                                                                                    |
| -through <names></names>          | Specifies the through node for analysis.                                                                                                                                        |
| -to <names></names>               | Specifies the to node for analysis.                                                                                                                                             |
| -to_clock <names></names>         | Specifies the destination clock for analysis.                                                                                                                                   |

|  | Table 7–25. | report | timing | Command | Options | (Part 2 of 2 | ) |
|--|-------------|--------|--------|---------|---------|--------------|---|
|--|-------------|--------|--------|---------|---------|--------------|---|

Example 7–32 shows a sample report that results from typing the following command:

report\_timing -from\_clock clk\_async -to\_clock clk\_async -setup -npaths 1 🕶

#### Example 7-32. Sample report\_timing Report (Part 1 of 2)

```
Info:
Info: To Node : dst_reg
Info: From Node : src_reg
Info: Latch Clock : clk_async
Info: Launch Clock : clk_async
Info:
Info: Data Arrival Path:
Info:
```

**Example 7–32.** Sample report\_timing Report (Part 2 of 2)

The report\_timing command generates a report of the specified analysis type either setup, hold, recovery, or removal. Each of the column descriptions are described in the Table 7–26.

All columns appear only when a report panel is created. If the report\_timing output is directed to a file or the console, only the Total, Incr, RF, Type, and Node columns appear.

| Column Name | Description                                                                                                   |
|-------------|---------------------------------------------------------------------------------------------------------------|
| Total       | Shows the accumulated time delay.                                                                             |
| Incr        | Shows the increment in delay.                                                                                 |
| RF          | Shows the input and output transition of the element; this can be one of the following: R, F, RR, RF, FR, FF. |
| Туре        | Shows the node type; refer to Table $7-27$ of a description of the various node types.                        |
| Fanout      | Shows the number of fan-outs of the element.                                                                  |
| Location    | Shows the location of the element in the FPGA.                                                                |
| Element     | Shows the name of the element.                                                                                |

Table 7–26. Timing Report Data

Table 7–27 provides a description of the possible node type in the report\_timing reports.

Table 7–27. Type Description (Part 1 of 2)

| Type Name | Description                                                                                                                                                        |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CELL      | Indicates the element is either a register or a combinational element in the FPGA; t.he CELL can be a register in the ALM, memory blocks, DSP blocks, or I/O block |
| COMP      | Indicates the PLL clock network compensation delay.                                                                                                                |

| Type Name | Description                                             |
|-----------|---------------------------------------------------------|
| IC        | Indicates the element is an interconnect delay.         |
| utco      | Indicates the element's micro clock-to-out time.        |
| utsu      | Indicates the element's micro setup time.               |
| uth       | Indicates the element's micro hold time.                |
| iext      | Indicates the element's external input delay time.      |
| oext      | Indicates the element's external output delay time.     |
| LOOP      | Indicates a lumped delay bypassing combinational loops. |
| RE        | Indicates a specified routing delay.                    |

Table 7–27. Type Description (Part 2 of 2)

#### report\_exceptions

Use the report\_exceptions command to generate a report that details the slack of all paths that have the timing exceptions set\_false\_path, set\_multicycle, set\_min\_delay, or set\_max\_delay applied to them.

The report\_exceptions command can be used to determine if all exceptions have been applied to the applicable paths in the design.

Example 7-33 shows the report\_exceptions command and options.

**Example 7–33.** report\_exceptions Command

```
report_exceptions
[-append]
[-detail <summary|path_summary|path_only|path_and_clock|full_path>]
[-fall_from_clock <names>]
[-fall_to_clock <names>]
[-file <name>]
[-from <names>]
[-from_clock <names>]
[-hold]
[-less_than_slack <slack limit>]
[-npaths <number>]
[-nworst <number>]
[-pairs_only]
[-panel_name <name>]
[-recovery]
[-removal]
[-rise_from_clock <names>]
[-rise_to_clock <names>]
[-setup]
[-stdout]
[-through <names>]
[-to <names>]
[-to_clock <names>]
```

Table 7–28 describes the options for the report\_exceptions command.

Table 7-28. report\_exceptions Command Options

| Option                                                                                                                  | Description                                                                                                                                                                                   |
|-------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -append                                                                                                                 | If output is sent to a file, this option appends the result to that file.<br>Otherwise, the file is overwritten.                                                                              |
| -detail <summary <="" path_only="" td=""><td>Specifies whether or not the clock path detail is reported:</td></summary> | Specifies whether or not the clock path detail is reported:                                                                                                                                   |
| path_and_clock/full_path>                                                                                               | Path Only: Clock network delay is lumped together                                                                                                                                             |
|                                                                                                                         | Summary: Lists each individual path                                                                                                                                                           |
|                                                                                                                         | Path and Clock: Clock network delay is shown in detail                                                                                                                                        |
|                                                                                                                         | Full Path: More clock network details, in particular for generated clocks                                                                                                                     |
| -fall_from_clock <names></names>                                                                                        | Specifies the falling edge of the < <i>names</i> > from the source register to be analyzed. The options from_clock, fall_from_clock, and rise_from_clock are mutually exclusive.              |
| -fall_to_clock <names></names>                                                                                          | Specifies the falling edge of the < <i>names</i> > to the destination register to be analyzed; the options to_clock, fall_to_clock, and rise_to_clock are mutually exclusive.                 |
| -false_path                                                                                                             | Reports only paths that are cut by a false path assignment.                                                                                                                                   |
| -file <names></names>                                                                                                   | Sends the results to an ASCII or HTML file. The extension specified in the file name determines the file type either <b>*.rpt</b> , <b>*.txt</b> , or <b>*.html</b> .                         |
| -hold                                                                                                                   | Specifies a clock hold analysis.                                                                                                                                                              |
| -less_than_slack < <i>slack limit</i> >                                                                                 | Limits the paths to be reported to the < <i>slack limit</i> > value.                                                                                                                          |
| -npaths <number></number>                                                                                               | Specifies the number of paths to report.                                                                                                                                                      |
| -nworst <number></number>                                                                                               | Restricts the number of paths per endpoint.                                                                                                                                                   |
| -panel_name < <i>names</i> >                                                                                            | Specifies the name of the panel in the <b>Reports</b> pane.                                                                                                                                   |
| -panel_name < <i>names</i> >                                                                                            | Sends the results to the panel and specifies the name of the new panel.                                                                                                                       |
| -pairs_only                                                                                                             | When set, paths with the same start and end points are considered equivalent; only the worst-case path for each unique combination is displayed.                                              |
| -recovery                                                                                                               | Specifies a recovery analysis.                                                                                                                                                                |
| -removal                                                                                                                | Specifies a removal analysis.                                                                                                                                                                 |
| -rise_from_clock <names></names>                                                                                        | Specifies the rising edge of the <i><names></names></i> from the source register to be analyzed; the options from_clock, fall_from_clock, and rise_from_clock are mutually exclusive.         |
| -rise_to_clock <names></names>                                                                                          | Specifies the rising edge of the <i><names< i="">&gt; to the destination register to be analyzed; the options to_clock, fall_to_clock, and rise_to_clock are mutually exclusive.</names<></i> |
| -setup                                                                                                                  | Specifies a clock setup analysis.                                                                                                                                                             |
| -show_routing                                                                                                           | Displays detailed routing in the path.                                                                                                                                                        |
| -stdout                                                                                                                 | Indicates the report will be sent to stdout.                                                                                                                                                  |
| -through <names></names>                                                                                                | Specifies the through node for analysis.                                                                                                                                                      |
| -to <names></names>                                                                                                     | Specifies the to node for analysis.                                                                                                                                                           |
| -to_clock <names></names>                                                                                               | Specifies the destination clock for analysis.                                                                                                                                                 |

#### report\_metastability

•...

Use the report\_metastability command to generate a report that lists the synchronization register chains for asynchronous transfers in your design, and details the MTBF for synchronization register chains.

To enable metastability analysis, you must set the **Synchronizer Identification** option to identify the synchronization register chains in the design. You can use automatic identification to generate a list of possible synchronizers in the metastability report, but MTBF is not reported for automatically-identified synchronizers.

The TimeQuest Timing Analyzer can analyze metastability MTBF only if a synchronization chain meets its timing requirements. Therefore, it is important for your design to be correctly constrained to get an accurate MTBF report. In addition, automatic synchronizer identification uses timing constraints to automatically detect the signal transfers between circuitry in unrelated or asynchronous clock domains, so clock domains must be related correctly with the timing constraints.

For details about metastability analysis and reporting, refer to the *Managing Metastability with the Quartus II Software* chapter in volume 1 of the *Quartus II Handbook*. This chapter describes how to use the **Synchronizer Identification** option, explains how TimeQuest timing constraints affect synchronizer chain identification and the reported MTBF, and provides details about the information reported with the report\_metastability command.

#### **Example 7–34.** report\_metastability command

```
report_metastability
[-append]
[-file <name>]
[-panel_name <name>]
[-stdout]
```

Table 7-29 describes the options for the report\_metastability command.

#### Table 7–29. report\_metastability Command Options

| Option                      | Description                                                                                                                                                                                                     |
|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -append                     | If output is sent to a file, this option appends the result to that file.<br>Otherwise, the file is overwritten.                                                                                                |
| -file <name></name>         | Sends the results to an ASCII or HTML file. The extension specified in the file name determines the file type—either <b>*.txt</b> or <b>*.html</b> .                                                            |
| -panel_name < <i>name</i> > | Sends the results to the panel and specifies the name of the new panel.                                                                                                                                         |
| -stdout                     | Indicates the report will be sent to the standard output, via messages.<br>This option is required only if you have selected another output<br>format, such as a file, and would also like to receive messages. |

#### report\_clock\_transfers

Use the report\_clock\_transfers command to generate a report that details all clock-to-clock transfers in the design. A clock-to-clock transfer is reported if a path exists between two registers that are clocked by two different clocks. Information such as the number of destinations and sources is also reported.

Use the report\_clock\_transfers command to generate a setup, hold, recovery, or removal report.

Example 7–35 shows the report\_clock\_transfers command and options.

Example 7–35. report\_clock\_transfers Command

report\_clock\_transfers
[-append]
[-file <name>]
[-hold]
[-setup]
[-stdout]
[-recovery]
[-removal]
[-panel\_name <name>]

Table 7–30 describes the options for the report\_clock\_transfers command.

Table 7–30. report\_clock\_transfers Command Options

| Option                    | Description                                                                                                                                          |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| -append                   | If output is sent to a file, this option appends the result to that file. Otherwise, the file is overwritten.                                        |
| -file <name></name>       | Sends the results to an ASCII or HTML file. The extension specified in the file name determines the file type either <b>*.txt</b> or <b>*.html</b> . |
| -hold                     | Creates a clock transfer summary for hold analysis.                                                                                                  |
| -setup                    | Creates a clock transfer summary for setup analysis.                                                                                                 |
| -stdout                   | Indicates the report will be sent to stdout.                                                                                                         |
| -recovery                 | Creates a clock transfer summary for recovery analysis.                                                                                              |
| -removal                  | Creates a clock transfer summary for removal analysis.                                                                                               |
| -panel_name <name></name> | Sends the results to the panel and specifies the name of the new panel.                                                                              |

#### report\_clocks

Use the report\_clocks command to generate a report that details all clocks in the design. The report contains information such as type, period, waveform (rise and fall), and targets for all clocks in the design.

Example 7–36 shows the report\_clocks command and options.

**Example 7–36.** report\_clocks Command

```
report_clocks
[-append]
[-desc]
[-file <name>]
[-stdout]
[-panel_name <name>]
```

Table 7–31 describes the options for the report\_clocks command.

| Option                    | Description                                                                                                                           |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| -append                   | If output is sent to a file, this option appends the result to that file. Otherwise, the file is overwritten.                         |
| -file <name></name>       | Sends the results to an ASCII or HTML file. The extension specified in the file name determines the file type—either *.txt or *.html. |
| -desc                     | Specifies the clock names to sort in descending order. The default is ascending order.                                                |
| -stdout                   | Indicates the report will be sent to stdout.                                                                                          |
| -panel_name <name></name> | Sends the results to the panel and specifies the name of the new panel.                                                               |

Table 7-31. report\_clocks Command Options

## report\_min\_pulse\_width

The report\_min\_pulse\_width command checks that a clock high or low pulse is sustained long enough to be recognized as an actual change in the clock signal. A failed minimum pulse width check indicates that the register may not recognize the clock transition. Use the report\_min\_pulse\_width command to generate a report that details the minimum pulse width for all clocks in the design. The report contains information for high and low pulses for all clocks in the design.

The report\_min\_pulse\_width command also reports minimum period checks for RAM and DSP, as well as I/O edge rate limits for input and output clock ports. For output ports, the port must either have a clock (or generated clock) assigned to it or used as the -reference\_pin for input/output delays.

The report\_min\_pulse\_width command checks the I/O edge rate limits, but does not always perform the check for output clock ports. For the report\_min\_pulse\_width command to check the I/O edge rate limits for output clock ports, the output clock port must fall into one of the following categories:

Have a clock or generated clock constraint assigned to it

or

Use a -reference\_pin for an input or output delay constraint

Each register in the design is reported twice per clock that clocks the register: once for the high pulse and once for the low pulse. Example 7–37 shows the report\_min\_pulse\_width command and options.

Example 7–37. report\_min\_pulse\_width Command

```
report_min_pulse_width
[-append]
[-file <name>]
[-nworst <number>]
[-stdout]
[<targets>]
[-panel_name <name>]
```

Table 7-32 describes the options for the report\_min\_pulse\_width command.

 Table 7–32.
 report\_min\_pulse\_width Command Options

| Option                    | Description                                                                                                                                             |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| -append                   | If output is sent to a file, this option appends the result to that file. Otherwise, the file is overwritten.                                           |
| -file <name></name>       | Sends the results to an ASCII or HTML file. The extension specified in the file name determines the file type—either *. <b>txt</b> or *. <b>html</b> .  |
| -nworst <number></number> | Specifies the number of pulse width checks to report. The default is 1.                                                                                 |
| -stdout                   | Redirects the output to stdout via messages; only required if another output format, such as a file, has been selected and is also to receive messages. |
| <targets></targets>       | Specifies registers.                                                                                                                                    |
| -panel_name <name></name> | Sends the results to the panel and specifies the name of the new panel.                                                                                 |

## report\_net\_timing

Use the report\_net\_timing command to generate a report that details the delay and fan-out information about a net in the design. A net corresponds to a cell's output pin.

Example 7–38 shows the report\_net\_timing command and options.

**Example 7–38.** report\_net\_timing Command

```
report_net_timing
[-append]
[-file <name>]
[-nworst_delay <number>]
[-nworst_fanout <number>]
[-stdout]
[-panel_name <name>]
```

Table 7–33 describes the options for the report\_net\_timing command.

Table 7-33. report\_net\_timing Command Options

| Option                           | Description                                                                                                                                          |
|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| -append                          | If output is sent to a file, this option appends the result to that file. Otherwise, the file is overwritten.                                        |
| -file <name></name>              | Sends the results to an ASCII or HTML file. The extension specified in the file name determines the file type—either <b>*.txt</b> or <b>*.html</b> . |
| -nworst_delay <number></number>  | Specifies that < number> worst net delays be reported.                                                                                               |
| -nworst_fanout <number></number> | Specifies that < <i>number&gt;</i> worst net fan-outs be reported.                                                                                   |
| -stdout                          | Indicates the report will be sent to stdout.                                                                                                         |
| -panel_name <name></name>        | Sends the results to the panel and specifies the name of the new panel.                                                                              |

### report\_sdc

Use the report\_sdc command to generate a report of all the Synopsys design constraints in the project.

Example 7–39 shows the report\_sdc command and options.

| Example 7–39. | report_sd | c Command |
|---------------|-----------|-----------|
|---------------|-----------|-----------|

report\_sdc
[-ignored]
[-append]
[-file]
[-stdout]
[-panel\_name <name>]

Table 7–34 describes the options for the report\_sdc command.

 Table 7–34.
 report\_sdc Command Options

| Option                    | Description                                                                                                                                          |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| -ignored                  | Reports assignments that were ignored.                                                                                                               |
| -append                   | If output is sent to a file, this option appends the result to that file. Otherwise, the file is overwritten.                                        |
| -file                     | Sends the results to an ASCII or HTML file. The extension specified in the file name determines the file type—either <b>*.txt</b> or <b>*.html</b> . |
| -stdout                   | Indicates that the report will be sent to stdout.                                                                                                    |
| -panel_name <name></name> | Sends the results to the panel and specifies the name of the new panel.                                                                              |

#### report\_ucp

Use the report\_ucp command to generate a report of all unconstrained paths in the design.

Example 7–40 shows the report\_ucp command and options.

**Example 7–40.** report\_ucp Command

```
report_ucp
[-append]
[-file <name>]
[-hold]
[-setup]
[-stdout]
[-summary]
[-panel_name <name>]
```

Table 7–35 describes the options for the report\_ucp command.

 Table 7–35.
 Option Descriptions for report\_ucp (Part 1 of 2)

| Option              | Description                                                                                                                                          |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| -append             | If output is sent to a file, this option appends the result to that file. Otherwise, the file is overwritten.                                        |
| -file <name></name> | Sends the results to an ASCII or HTML file. The extension specified in the file name determines the file type—either <b>*.txt</b> or <b>*.html</b> . |

| Option                    | Description                                                             |
|---------------------------|-------------------------------------------------------------------------|
| -hold                     | Reports all unconstrained hold paths.                                   |
| -setup                    | Reports all unconstrained setup paths.                                  |
| -stdout                   | Indicates the report be sent to stdout.                                 |
| -summary                  | Generates only the summary panel.                                       |
| -panel_name <name></name> | Sends the results to the panel and specifies the name of the new panel. |

#### Table 7–35. Option Descriptions for report\_ucp (Part 2 of 2)

Table 7–36 summarizes all reporting commands available in the Quartus II TimeQuest Timing Analyzer.

Table 7-36. Reports from the Tasks Pane and Tcl Commands

| Task Pane Report              | Tcl Command                     | Description                                                                        |  |
|-------------------------------|---------------------------------|------------------------------------------------------------------------------------|--|
| Report Setup<br>Summary       | create_timing_summary -setup    | Generates a clock setup summary for all defined clocks.                            |  |
| Report Hold<br>Summary        | create_timing_summary -hold     | Generates a clock hold summary for all defined clocks.                             |  |
| Report Recovery<br>Summary    | create_timing_summary -recovery | Generates a clock recovery summary for all defined clocks.                         |  |
| Report Removal<br>Summary     | create_timing_summary -removal  | Generates a clock removal summary for all defined clocks.                          |  |
| Report Clocks                 | report_clocks                   | Generates a clock summary for all defined clocks.                                  |  |
| Report Clock<br>Transfers     | report_clock_transfers          | Generates a clock transfer summary for all clock-to-clock transfers in the design. |  |
| Report SDC                    | report_sdc                      | Generates a summary of all <b>.sdc</b> file commands read.                         |  |
| Report Unconstrained<br>Paths | report_ucp                      | Generates a summary of all unconstrained paths in the design.                      |  |
| Report Timing                 | report_timing                   | Generates a detailed summary for specific paths in the design.                     |  |
| Report Net Timing             | report_net_timing               | Generates a detailed summary for specific nets in the design.                      |  |
| Report Minimum<br>Pulse Width | report_min_pulse_width          | Generates a detailed summary for specific registers in the design.                 |  |
| Create Slack<br>Histogram     | create_slack_histogram          | Generates a detailed histogram for a specific clock in the design.                 |  |

## report\_bottleneck

Use the report\_bottleneck command to report a rating per node based on the number of failing paths through each node for the worst 1,000 setup paths. Example 7–41 shows the report\_bottleneck command and options.

#### **Example 7–41.** report\_bottleneck Command

```
report_bottleneck
[-cmetric <cmetric_name>]
[-details]
[-metric <default/tns/num_paths/num_fpaths/num_fanins/num_fanouts>]
[-panel <panel_name>]
[-stdout]
[<paths>]
```

By default, the report\_bottleneck command reports a rating for the worst 1,000 setup paths.

In addition to the default metric, there are a few additional "standard" metrics to choose from, such as:

- -metric num\_fanouts
- -metric tns

You can also create a custom metric to evaluate the nodes based on the combination of the number of fanouts, fanins, failing paths, total paths, and other keepers. The paths to be analyzed can be specified by passing the result of any get\_timing\_paths call as the last argument to report\_bottleneck.

Table 7–37 describes the options for the report\_bottleneck command.

 Table 7–37.
 report\_bottleneck Command

| Option                                                                                                | Description                                                                               |
|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| -cmetric <cmetric_name></cmetric_name>                                                                | Custom metric function to evaluate individual nodes.                                      |
| -details                                                                                              | Show the detailed information (number of failing edges, number of fan-ins, and so forth). |
| <pre>-metric <default num_fanins="" num_fanouts="" num_fpaths="" num_paths="" tns=""></default></pre> | Indicate the metric to use to rate individual nodes.                                      |
| -panel <panel_name></panel_name>                                                                      | Sends the results to the panel and specifies the name of the new panel.                   |
| -stdout                                                                                               | Indicates the report will be sent to stdout.                                              |
| <paths></paths>                                                                                       | Paths to be analyzed.                                                                     |

Example 7–42 shows how to create a custom metric with the report\_bottleneck command.

Example 7-42. report\_bottleneck Custom Metric

```
#set the number of paths to be reported
set paths [ get_timing_paths -npaths 1000 -setup ]
#create the custom metric
proc report_bottleneck_custom_metric {arg} {
    # Description: use the number of fanins as the custom metric.
    upvar $arg metric
    set rating $metric(num_fanins)
    return $rating
}
#reporting the results of the custom metric
report_bottleneck -cmetric report_bottleneck_custom_metric -panel
"Timing Analysis Bottleneck Report - Custom" $paths
```

### report\_datasheet

Use the report\_datasheet command to generate a datasheet report which summarizes the timing characteristics of the entire design. It reports setup (tsu), hold (th), clock-to-output (tco), minimum clock-to-output (mintco), propagation delay (tpd), and minimum propagation delay (mintpd) times. Example 7–43 shows the report\_datasheet command and options.

Example 7–43. report\_datasheet Command

```
report_datasheet
[-append]
[-file <name>]
[-stdout]
[panel_name <name>]
```

Table 7-38 describes the options for the report\_datasheet command.

 Table 7–38.
 report\_datasheet Command Options

| Option                      | Description                                                                                                                           |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| -append                     | If output is sent to a file, this option appends the result to that file. Otherwise, the file is overwritten.                         |
| -file <name></name>         | Sends the results to an ASCII or HTML file. The extension specified in the file name determines the file type—either *.txt or *.html. |
| -stdout                     | Indicates the report will be sent to stdout.                                                                                          |
| -panel_name < <i>nam</i> e> | Sends the results to the panel and specifies the name of the new panel.                                                               |

The delays are reported with respect to a base clock or port for which they are relevant. If there is a case where there are multiple paths for a clock, the maximum delay of the longest path is taken for the  $t_{SU}$ ,  $t_{H}$ ,  $t_{CO}$ , and  $t_{PD}$ , and the minimum delay of the shortest path is taken for mint<sub>CO</sub> and mint<sub>PD</sub>.

#### report\_rskm

Use the report\_rskm command to generate a report that details the receiver skew margin for LVDS receivers.

Example 7-44 shows the report\_rskm command and options.

#### **Example 7–44.** report\_rskm Command

report\_rskm
[-append]
[-file <name>]
[-panel\_name <name>]
[-stdout]

Table 7–39 describes the options for the report\_rskm command.

Table 7–39. report\_rskm Command Options

| Type Name                   | Description                                                                                                                           |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| -append                     | If output is sent to a file, this option appends the result to that file. Otherwise, the file is overwritten.                         |
| -file <name></name>         | Sends the results to an ASCII or HTML file. The extension specified in the file name determines the file type—either *.txt or *.html. |
| -panel_name < <i>name</i> > | Sends the results to the panel and specifies the name of the new panel.                                                               |
| -stdout                     | Indicates the report will be sent to stdout.                                                                                          |

The receiver input skew margin (RSKM) is the time margin available before the LVDS receiver megafunction fails to operate. RSKM is defined as the total time margin that remains after subtracting the sampling window (SW) size and the receiver channel-to-channel skew (RCCS) from the time unit interval (TUI), as expressed in the formula shown in Equation 7–11:

#### Equation 7–11.

| Berm - ( | (TUI - SW - RCCS) |  |
|----------|-------------------|--|
|          | 2                 |  |

The time unit interval is the LVDS clock period  $(1/f_{MAX})$ . The sampling window is the period of time that the input data must be stable to ensure that the data is successfully sampled by the LVDS receiver megafunction. The sampling window size varies by device speed grade; RCCS reflects channel-to-channel skew seen by the LVDS receiver. This RCCS includes transmitter channel-to-channel skew (TCCS) of the upstream transmitter and maximum channel-to-channel skew between the transmitter and receiver. RCCS is equal to the difference between the maximum input delay and minimum input delay. If no input delay is set, RCCS defaults to zero.

#### report\_tccs

Use the report\_tccs command to generate a report that details the channel-to-channel skew margin for LVDS transmitters.

Example 7–45 shows the report\_tccs command and options.



```
report_tccs
[-append]
[-file <name>]
[-panel_name <name>]
[-quiet]
[-stdout]
```

Table 7-40 describes the options for the report\_tccs command.

Table 7-40. report\_tccs Command Options

| Type Name                   | Description                                                                                |
|-----------------------------|--------------------------------------------------------------------------------------------|
| -append                     | Specifies that the current report be appended to the file specified by the $-file$ option. |
| -file <name></name>         | Indicates that the current report is written to the file < <i>name</i> >.                  |
| -panel_name < <i>nam</i> e> | Sends the results to the panel and specifies the name of the new panel.                    |
| -quiet                      | Specifies that nothing is printed if there are no LVDS receivers in the design.            |
| -stdout                     | Indicates the report will be sent to stdout.                                               |

The TCCS is the timing difference between the fastest and slowest output transitions, including  $t_{co}$  variations and clock skew.

### report\_partitions

Use the report\_partitions command to generate a timing report listing the worst-case setup checks for each partition in the design.

Example 7–46 shows the report\_partitions command and options.

**Example 7–46.** report\_partitions Command

```
report_partitions
[-nworst <number>]
[-panel_name <name>]
[-stdout]
```

Table 7–41 describes the options for the report\_partitions command.

**Table 7–41.** report\_partitions Command Options

| Type Name   | Description                                                             |  |
|-------------|-------------------------------------------------------------------------|--|
| -nworst     | Specifies the maximum number of paths to report for each endpoint.      |  |
| -panel_name | Sends the results to the panel and specifies the name of the new panel. |  |
| -stdout     | Indicates the report will be sent to stdout.                            |  |

## report\_path

Use the report\_path command to generate a report that details the longest delay paths between any two arbitrary keeper nodes.

Example 7–47 shows the report\_path command and options.

```
Example 7–47. report_path Command
```

```
report_path
[-append]
[-file <name>]
[-from <names>]
[-min_path]
[-npaths <number>]
[-nworst <number>]
[-panel_name <name>]
[-stdout]
[-summary]
[-through <names>]
[-to <names>]
```

Table 7-42 describes the options for the report\_path command.

**Table 7–42.** report\_path Command Options

| Type Name                   | Description                                                                                                                              |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| -append                     | Specifies that the current report be appended to the file specified by the $-file$ option.                                               |
| -file <name></name>         | Indicates that the current report is written to the file < name>.                                                                        |
| -from <names></names>       | The < <i>names</i> > is a collection or list of objects in the design. The < <i>names</i> > acts as the start point of the path.         |
| -min_path                   | Displays the minimum delay paths.                                                                                                        |
| -npaths <number></number>   | Specifies the number of paths to report.                                                                                                 |
| -nworst <number></number>   | Specifies the maximum number of paths to report for each endpoint.                                                                       |
| -panel_name < <i>name</i> > | Sends the results to the panel and specifies the name of the new panel.                                                                  |
| -stdout                     | Indicates the report will be sent to stdout.                                                                                             |
| -summary                    | Creates a single table with a summary of each path found.                                                                                |
| -through <names></names>    | The < <i>names</i> > is a collection or list of objects in the design. Specifies false path passes through < <i>names</i> >.             |
| -to <names></names>         | The <i>&lt; names&gt;</i> is a collection or list of objects in the design. The <i>&lt; names&gt;</i> acts as the end point of the path. |

The delay path reported cannot pass through a keeper node; for example, a register or port. Instead, the delay path must be from the output pin of a keeper node to the input pin of a keeper node.

Figure 7–34 shows a simple design with a register-to-register path.

Figure 7–34. Simple Register-to-Register Path



Example 7-48 shows the report generated from the following command:

```
report_path -from [get_pins {reg1|regout}] -to [get_pins \
{reg2|datain}] -npaths 1 -panel_name "Report Path" -stdout
```

**Example 7–48.** report\_path from Keeper Output Pin to Keeper Input Pin

Example 7-49 shows the report generated from the following command:

```
report_path -from [get_ports data_in_a] -to [get_pins {reg2|regout}] \
-npaths 1
```

**Example 7–49.** report\_path from Keeper-to-Keeper Output Pin

```
Info: Report Path: No paths were found 0 0.000
```

No paths were reported in Example 7–49 because the destination passes through an input pin of a keeper node.

#### report\_net\_delay

Use the report\_net\_delay to generate a slack report for paths constrained with the set\_net\_delay command. The report\_net\_delay command reports the results of all set\_net\_delay commands in a single report. The report contains each set\_net\_delay command with the worst case slack result followed by the results of each edge matching the criteria set by that set\_net\_delay command. These results are ordered based on the slack value. Example 7–50 shows the report\_net\_delay command and options.

```
Example 7–50. report_net_delay Command
```

```
report_net_delay
  [-append]
  [-file <name>]
  [-nworst <number>]
  [-panel_name <name>]
  [-stdout]
```

Table 7-43 describes the options for the report\_net\_delay command.

| Options                   | Description                                                                                                                                                                |
|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -append                   | If output is sent to a file, this option appends the result to that file. Otherwise, the file is overwritten.                                                              |
| -file <name></name>       | Sends the results to an ASCII or HTML file. The extension specified in the file name determines the file type—either *. <b>txt</b> or *. <b>html</b> .                     |
| -nworst <number></number> | Specifies the maximum number of paths to report for each analysis. If unspecified, there is no limit.                                                                      |
| -panel_name <name></name> | Sends the results to the panel and specifies the name of the new panel.                                                                                                    |
| -stdout                   | Send output to stdout, via messages. You only have to use this option if you have selected another output format, such as a file, and would also like to receive messages. |

Table 7-43. report\_net\_delay Command Options

#### report\_max\_skew

Use the report\_max\_skew to generate a slack report for paths constrained with the set\_max\_skew command. The report\_max\_skew command reports the results of all set\_max\_skew commands in a single report. The report contains each set\_max\_skew command with the worst case slack result followed by the results of each edge matching the criteria set by that set\_max\_skew command. These results are ordered based on the slack value. Example 7–51 shows the report\_max\_skew command and options.

**Example 7–51.** report\_max\_skew Command

```
report_max_skew
[-detail <summary/path_only/path_and_clock/full_path>]
[-file <name>]
[-less_than_slack <slack limit>]
[-npaths <number>]
[-panel_name <name>]
[-show_routing]
[-stdout]
```

Table 7-44 describes the options for the report\_max\_skew command.

| Table 7–44. | report_ | _max_ | _skew | Command | Options |
|-------------|---------|-------|-------|---------|---------|
|-------------|---------|-------|-------|---------|---------|

| Option                                                                    | Description                                                                                                                                    |
|---------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| [-detail <summary full_path="" path_and_clock="" path_only="">]</summary> | Specifies whether or not the clock<br>path detail is reported:                                                                                 |
|                                                                           | Path Only: Clock network delay is<br>lumped together                                                                                           |
|                                                                           | Summary: Lists each individual path                                                                                                            |
|                                                                           | Path and Clock: Clock network delay is shown in detail                                                                                         |
|                                                                           | Full Path: More clock network details, in particular for generated clocks                                                                      |
| [-file <name>]</name>                                                     | Sends the results to an ASCII or HTML<br>file. The extension specified in the file<br>name determines the file type—either<br>*.txt or *.html. |
| [-less_than_slack < <i>slack limit</i> >]                                 | Limits the paths reported to the<br>< <i>slack limit&gt;</i> value.                                                                            |
| [-npaths <number>]</number>                                               | Specifies the number of paths to report.                                                                                                       |
| [-panel_name <name>]</name>                                               | Sends the results to the panel and specifies the name of the new panel.                                                                        |
| [-show_routing]                                                           | Displays detailed routing in the path.                                                                                                         |
| [-stdout]                                                                 | Indicates the report will be sent to stdout.                                                                                                   |

P

No results are displayed if the -from/-from\_clock and -to/-to\_clock are applied to less than two paths.

# check\_timing

Use the check\_timing command to generate a report on any potential problem with the design or applied constraints. Not all check\_timing results are serious issues. The results should be examined to see if the results are desired. Example 7–52 shows the check\_timing command and options.

#### Example 7–52. check\_timing Command

```
check_timing
[-append]
[-file <name>]
[-include <check_list>]
[-stdout]
[-panel_name <name>]
```

Table 7–45 describes the options for the check\_timing command.

| Option                      | Description                                                                                                                     |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| -append                     | Specifies that the current report be appended to the file specified by the _file option.                                        |
| -file <name></name>         | Indicates that the current report is written to the file < name>.                                                               |
| -include                    | Indicates that a check is to be performed with the <i><check_list></check_list></i> . Refer to Table 7–46 for a list of checks. |
| -stdout                     | Indicates the report will be sent to stdout.                                                                                    |
| -panel_name < <i>name</i> > | Sends the results to the panel and specifies the name of the new panel.                                                         |

Table 7–46 describes the possible checks.

| Table 7-46. | Possible Check | ks (Part 1 of 2) |
|-------------|----------------|------------------|
|-------------|----------------|------------------|

| Option               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| no_clock             | Checks that registers have at least one clock at their clock pin and ensures that ports determined to be clocks have a clock assigned to them.                                                                                                                                                                                                                                                                                                   |  |  |
| multiple_clock       | Checks that registers have at most one clock at their clock pin. When multiple clocks reach a register's clock pin, both clocks are used for analysis.                                                                                                                                                                                                                                                                                           |  |  |
| generated_clock      | Checks that generated clocks are valid. Generated clocks must have a source that is clocked by a valid clock. They must also not depend on each other in a loop (clkl cannot have clk2 as a source if clk2 already uses clkl as a source).                                                                                                                                                                                                       |  |  |
| no_input_delay       | Checks that every input port that is not determined to be a clock has an input delay set<br>on it.                                                                                                                                                                                                                                                                                                                                               |  |  |
| no_output_delay      | Checks that every output port has an output delay set on it.                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| partial_input_delay  | Checks that input delays are complete. Makes sure that input delays have a rise-min, fall-min, rise-max, and fall-max portion set.                                                                                                                                                                                                                                                                                                               |  |  |
| partial_output_delay | Checks that output delays are complete. Makes sure that output delays have a rise-min, fall-min, rise-max, and fall-max portion set.                                                                                                                                                                                                                                                                                                             |  |  |
| reference_pin        | Checks if reference pins specified in set_input_delay and<br>set_output_delay using the reference_pin option are valid. A reference_pin is<br>valid if the clock option specified in the same<br>set_input_delay/set_output_delay command matches the clock that is in<br>the direct fan-in of the reference_pin. Being in the direct fan-in of the<br>reference_pin means that there must be no keepers between the clock and<br>reference_pin. |  |  |
| latency_override     | Ensures that the clock latency constraint applied on a port or pin overrides the more generic clock latency set on a clock. Clock latency set to a clock applies to all keepers clocked by the clock. Clock latency set to a pin or a port applies to registers in the fan-out of the port or pin.                                                                                                                                               |  |  |
| loops                | Checks that there are no strongly connected components in the design. These loops prevent a design from being properly analyzed. Indicates that loops exist but were marked so that they would not be traversed.                                                                                                                                                                                                                                 |  |  |
| latches              | Checks whether there are latches in the design. The Quartus II TimeQuest Timing Analyzer warns the user that the latches exist and cannot be properly analyzed.                                                                                                                                                                                                                                                                                  |  |  |
| pos_neg_clock_domain | Checks whether any register is clocked by both the rising and falling edges of the same clock. if this scenario is necessary, such as in a clock multiplexer, create two separate clocks that have similar settings and are assigned to the same node.                                                                                                                                                                                           |  |  |

| Option                                | Description                                                                                                                                                                                                         |  |  |
|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| pll_cross_check                       | Checks the clocks that are assigned to a PLL against the PLL setting defined in the user's design files. Inconsistent setting or an unmatched number of clocks associated with the PLL are reported to the user.    |  |  |
| no_uncertainty                        | Checks that each clock-to-clock transfer has a clock uncertainty assignment set between the two clocks.                                                                                                             |  |  |
| virtual_clock                         | Checks that each virtual clock is referenced.                                                                                                                                                                       |  |  |
| partial_multicycle                    | Checks that each setup multicycle assignment has a corresponding hold multicycle assignment, and each hold multicycle assignment has a corresponding setup multicyle assignment.                                    |  |  |
| multicycle_consistency                | Checks that all of the multicycle cases in which a setup multicycle does not equal one greater than the hold multicycle. Hold multicycle assignments are usually one cycle fewer than setup multicycle assignments. |  |  |
| partial_min_max_delay                 | Verifies that each minimum delay assignment has a corresponding maximum delay assignment, and that each maximum delay assignment has a corresponding minimum delay assignment.                                      |  |  |
| clock_assignments_<br>on_output_ports | Checks that reports all of the clock assignments that have been applied to output ports.                                                                                                                            |  |  |
| generated_io_delay                    | Checks that all of the I/O delays with no reference pin, generated -clock, or no -source_atencey_included.                                                                                                          |  |  |

| Table 7-46. | Possible Checks | (Part 2 of 2) |
|-------------|-----------------|---------------|
|-------------|-----------------|---------------|

Example 7–53 shows how the check\_timing command can be used.

| Example 7-53. | The check | timing | Command |
|---------------|-----------|--------|---------|
|---------------|-----------|--------|---------|

```
# Constrain design
create_clock -name clk -period 4.000 -waveform { 0.000 2.000 } \
[get_ports clk]
set_input_delay -clock clk2 1.5 [get_ports in*]
set_output_delay -clock clk 1.6 [get_ports out*]
set_false_path -from [get_keepers in] -through [get_nets r1] -to \
[get_keepers out]
# Check if there were any problems for combinational loops, latches, or
# misssing or incomplete input delays
check_timing -include {loops latches no_input_delay
partial_input_delay}
```

## report\_clock\_fmax\_summary

Use the report\_clock\_fmax\_summary to report potential  $f_{MAX}$  for every clock in the design, regardless of the user-specified clock periods.  $f_{MAX}$  is only computed for paths where the source and destination registers or ports are driven by the same clock. Paths of different clocks, including generated clocks, are ignored. For paths between a clock and its inversion,  $f_{MAX}$  is computed as if the rising and falling edges are scaled along with  $f_{MAX}$ , such that the duty cycle (in terms of a percentage) is maintained.
Example 7-54 shows the report\_clock\_fmax\_summary command and options.

Example 7–54. report\_clock\_fmax\_summary Command

```
report_clock_fmax_summary
[-append]
[-file <name>]
[-panel_name <name>]
[-stdout]
```

Table 7-47 describes the options for the report\_clock\_fmax\_summary command.

 Table 7–47.
 report\_clock\_fmax\_summary Command Options

| Option                    | Description                                                                                |
|---------------------------|--------------------------------------------------------------------------------------------|
| -append                   | Specifies that the current report be appended to the file specified by the $-file$ option. |
| -file <name></name>       | Indicates that the current report is written to the file < name>.                          |
| -stdout                   | Indicates the report will be sent to stdout.                                               |
| -panel_name <name></name> | Sends the results to the panel and specifies the name of the new panel.                    |

The  $f_{MAX}$  Summary report contains four columns:  $f_{MAX}$ , Restricted  $f_{MAX}$ , Clock Name, and Note. The description of each column is given in Table 7–48.

Table 7–48. f<sub>MAX</sub> Summary Report Column

| Column Name                 | Description                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| f <sub>MAX</sub>            | Shows the fastest possible frequency at which the internal register-to-register can run. This is not the fastest the clock port can be driven.                                                                                                                                                                                                      |
| Restricted f <sub>MAX</sub> | Shows fastest possible frequency at which the clock port can run. This number may be lower than the $f_{MAX}$ column for various reasons, including hold timing requirements, I/O edge rate limits for clocks (which also depends on I/O standards), minimum pulse width checks for registers, and minimum period checks for RAM and DSP registers. |
| Clock Name                  | Shows the clock name.                                                                                                                                                                                                                                                                                                                               |
| Note                        | Shows any notes related to the clock.                                                                                                                                                                                                                                                                                                               |

### create\_timing\_summary

Reports the worst-case clock setup and clock hold slacks and endpoint total negative slack (TNS) per clock domain. Total negative slack is the sum of all slacks less than zero for each destination register or port in the clock domain.

Example 7-55 shows the create\_timing\_summary command and options.

**Example 7–55.** create\_timing\_summary Command

```
create_timing_summary
[-append]
[-file <name>]
[-hold]
[-panel_name <name>]
[-recovery]
[-removal]
[-setup]
[-stdout]
```

Table 7-49 describes the options for the create\_timing\_summary command.

| Option                    | Description                                                                                |  |
|---------------------------|--------------------------------------------------------------------------------------------|--|
| -append                   | Specifies that the current report be appended to the file specified by the $-file$ option. |  |
| -file <name></name>       | Indicates that the current report is written to the file < name>.                          |  |
| -hold                     | Generates a clock hold check summary report.                                               |  |
| -panel_name <name></name> | Sends the results to the panel and specifies the name of the new panel.                    |  |
| -recovery                 | Generates a recovery check summary report.                                                 |  |
| -removal                  | Generates a removal check summary report.                                                  |  |
| -setup                    | Generates a clock setup check summary report.                                              |  |
| -stdout                   | Indicates the report will be sent to stdout.                                               |  |

Table 7-49. create\_timing\_summary Command Options

# **Timing Analysis Features**

The TimeQuest Timing Analyzer supports many features that enhances and provides a through analysis of your designs. This section covers the many features available in the TimeQuest Timing Analyzer.

### **Multi-Corner Analysis**

Multi-corner analysis allows a design to be verified under a variety of operating conditions (voltage, process, and temperature) while performing a static timing analysis on the design.

Use the set\_operating\_conditions command to change the operating conditions or speed grade of the device used for static timing analysis.

Example 7-56 shows the set\_operating\_conditions command and options.

```
Example 7–56. set_operating_conditions Command
```

```
set_operating_conditions
[-model <fast/slow>]
[-speed <speed grade>]
[-temperature <value in °C>]
[-voltage <value in mV>]
[<operating condition Tcl object>]
```

Table 7-50 describes the options for the set\_operating\_conditions command.

| Table 7–50. set | _operating_ | _conditions | Command | Options |
|-----------------|-------------|-------------|---------|---------|
|-----------------|-------------|-------------|---------|---------|

| Option                                                           | Description                                                                           |
|------------------------------------------------------------------|---------------------------------------------------------------------------------------|
| -model <fast slow=""></fast>                                     | Specifies the timing model.                                                           |
| -speed < <i>speed grade</i> >                                    | Specifies the device speed grade.                                                     |
| -temperature <value in="" °c=""></value>                         | Specifies the operating temperature.                                                  |
| -voltage <value in="" mv=""></value>                             | Specifies the operating voltage.                                                      |
| <pre><operating condition="" object="" tcl=""></operating></pre> | Specifies the operating condition Tcl object that specifies the operating conditions. |

If an operating condition Tcl object *is* used, the model, speed, temperature, and voltage options are not required. If an operating condition Tcl object *is not* used, the model must be specified, and the -speed, -temperature, and -voltage options are optional, using the appropriate defaults for the device where applicable.

Table 7–51 shows a few of the available operating conditions that can be set for each device family.

|               | Available Conditions |       |                 |           |                                    |
|---------------|----------------------|-------|-----------------|-----------|------------------------------------|
| Device Family | Speed<br>Grade       | Model | Voltage<br>(mV) | Temp (°C) | Operating Condition Tcl Objects    |
| Stratix III   | 4                    | Slow  | 1100            | 85        | 4_slow_1100mv_85c 4_slow_1100mv_0c |
|               |                      | Slow  | 1100            | 0         | MIN_fast_1100mv_0c                 |
|               |                      | Fast  | 1100            | 0         |                                    |
| Cyclone® III  | 7                    | Slow  | 1200            | 85        | 7_slow_1200mv_85c 7_slow_1200mv_0c |
|               |                      | Slow  | 1200            | 0         | MIN_fast_1200mv_0c                 |
|               |                      | Fast  | 1200            | 0         |                                    |
| Stratix II    | 4                    | Slow  | _               | —         | 4_slow                             |
|               |                      | Fast  |                 |           | MIN_fast                           |
| Cyclone II    | 6                    | Slow  |                 | _         | 6_slow                             |
|               |                      | Fast  |                 |           | MIN_fast                           |

 Table 7–51.
 Device Family Operating Conditions

Use the get\_available\_operating\_conditions-all command to obtain a list of available operating conditions for the target device.

Table 7–52 shows the operating conditions of each model for device families that support only two operating conditions, that is, fast and slow.

| Table 7-52. | Operating | Conditions | for Fas | st and | Slow Models |
|-------------|-----------|------------|---------|--------|-------------|
|-------------|-----------|------------|---------|--------|-------------|

| Model | Speed Grade                           | Voltage                     | Temperature                       |
|-------|---------------------------------------|-----------------------------|-----------------------------------|
| Slow  | Slowest speed grade in device density | $V_{cc}$ minimum supply (1) | Maximum $T_J$ (1)                 |
| Fast  | Fastest speed grade in device density | $V_{cc}$ maximum supply (1) | Minimum T <sub>J</sub> <i>(1)</i> |

Note toTable 7-52:

(1) Refer to the DC & Switching Characteristics chapter of the applicable device Handbook for V $_{\rm cc}$  and T $_{\rm J}$ 

A static timing analysis should be performed under all available operating conditions. This ensures that no violations will occur under various conditions during the device operation.

Example 7–57 shows how to set the operating conditions for a Stratix III design to the slow model, 1100 mV, and 85° C.

Example 7–57. Setting Operating Conditions with Individual Values

set\_operating\_conditions -model slow -temperature 85 -voltage 1100

Alternatively, you can set the operating conditions in Example 7–57 with the Tcl object as shown in Example 7–58.

#### **Example 7–58.** Setting Operating Conditions with a Tcl Object

```
set_operating_conditions 4\_slow\_1100mv\_85c
```

### Advanced I/O Timing and Board Trace Model Assignments

The Quartus II TimeQuest Timing Analyzer is able to use Advanced I/O Timing and Board Trace Model assignments to model I/O buffer delays in your design.

To turn the Advanced I/O feature on or off, in the **Settings** dialog box, under the **TimeQuest Timing Analyzer** option, choose **on** or **off**.

If you turn the **Advanced I/O Timing** on or off or change Board Trace Model assignments and do not recompile before you analyze timing, you must use the -force\_dat command when you create the timing netlist. Type the following command in the Tcl console of the Quartus II TimeQuest Timing Analyzer:

#### create\_timing\_netlist -force\_dat 🛩

If you turn the **Advanced I/O Timing** or change Board Trace Model assignments on or off and recompile before you analyze timing, you do not have to use the <code>-force\_dat</code> command when you create the timing netlist. You can create the timing netlist with the <code>create\_timing\_netlist</code> command, or with the <code>Create Timing Netlist</code> task in the **Tasks** pane.

•••

For more information about the Advanced I/O Timing feature, refer to the I/O *Management* chapter in volume 2 of the *Quartus II Handbook*.

### Wildcard Assignments and Collections

To simplify the task of applying constraints to many nodes in a design, the Quartus II TimeQuest Timing Analyzer accepts the "\*" and "?" wildcard characters. Use these wildcard characters to reduce the number of individual constraints you must specify in your design.

The "\*" wildcard character matches any string. For example, given an assignment made to a node specified as reg\*, the Quartus II TimeQuest Timing Analyzer searches for and applies the assignment to all design nodes that match the prefix reg with none, one, or several characters following, such as reg1, reg[2], regbank, and reg12bank.

The "?" wildcard character matches any single character. For example, given an assignment made to a node specified as reg?, the Quartus II TimeQuest Timing Analyzer searches and applies the assignment to all design nodes that match the prefix reg and any single character following; for example, reg1, rega, and reg4.

Both the collection commands get\_cells and get\_pins have three options that allow you to refine searches that include the wildcard character. To refine your search results, select the default behavior, the -hierarchical option, or the -compatibility option.

The pipe character is used to separate one hierarchy level from the next in the Quartus II TimeQuest Timing Analyzer. For example, *<absolute full cell name>* | *<pin suffix>* represents a hierarchical pin name with the "|" separating the hierarchy from the pin name.

When you use the collection commands get\_cells and get\_pins without an option, the default search behavior is performed on a per-hierarchical level of the pin name; that is, the search is performed level by level. A full hierarchical name may contain multiple hierarchical levels where a " | " is used to separate the hierarchical levels, and each wildcard character represents only one hierarchical level. For example,"\*" represents the first hierarchical level and "\* | \*" represents the first and second hierarchical levels.

When you use the collection commands get\_cells and get\_pins with the -hierarchical option, a recursive match is performed on the relative hierarchical path name of the form *<short cell name>* | *<pin name>*. The search is performed on the node name; for example, the last hierarchy of the name and not the hierarchy path. Unlike the default behavior, this option does not limit the search to each hierarchy level represented by the pipe character.

The pipe character cannot be used in the search with the get\_cells -hierarchical option. However, the pipe character can be used with the get\_pins collection search.

When you use the collection commands get\_cells and get\_pins with the -compatibility option, the search performed is similar to that of the Quartus II Classic Timing Analyzer. This option searches the entire hierarchical path and pipe characters are not treated as special characters.

Assuming the following cells exist in a design:

foo foo|bar and the following pin names:

foo|dataa foo|datab foo|bar|datac foo|bar|datad

Table 7–53 shows the results of using these search strings.

| Search String                      | Search Result        |
|------------------------------------|----------------------|
| get_pins * dataa                   | foo dataa            |
| get_pins * datac                   | <empty></empty>      |
| get_pins * * datac                 | foo bar datac        |
| get_pins foo* *                    | foo dataa, foo datab |
| get_pins -hierarchical * * datac   | <empty> (1)</empty>  |
| get_pins -hierarchical foo *       | foo dataa, foo datab |
| get_pins -hierarchical * datac     | foo bar datac        |
| get_pins -hierarchical foo * datac | <empty> (1)</empty>  |

 Table 7–53.
 Sample Search Strings and Search Results (Part 1 of 2)

| Search String                     | Search Result |
|-----------------------------------|---------------|
| get_pins -compatibility * datac   | foo bar datac |
| get_pins -compatibility * * datac | foo bar datac |

| Table 7–53. | Sample Search Strings and Search Results | (Part 2 of 2) |
|-------------|------------------------------------------|---------------|
|             | cample coulon othinge and coulon module  |               |

Note to Table 7–53:

(1) Due to the additional \* | \* | in the search string, the search result is <empty>.

### **Resetting a Design**

Use the reset\_design command to remove all timing constraints and exceptions from the design under analysis. The command removes all clocks, generated clocks, derived clocks, input delays, output delays, clock latency, clock uncertainty, clock groups, false paths, multicycle paths, min delays, and max delays.

This command provides a convenient way to return to the initial state of analysis without the need to delete and re-create a new timing netlist.

### **Cross-Probing**

The cross-probing feature allows you to locate paths and elements from the TimeQuest Timing Analyzer to various tools available in the Quartus II software (and vice versa).

From the TimeQuest GUI, you can right-click any path in the **View** pane and select either **Locate Path** or **Locate**.

The source is the element in the **From Node** column and the destination is the element in the **To Node** column.

The **Locate Path** option allows you to located the data arrival path, default, of the currently selected row. To locate the data required time path select a row in the data required path panel.

The **Locate Required Path** command is available only when there is a path to show; unless the user reports the clock path as well, there is probably only a single node in the required path. In this case, the command is not available.

The **Locate** option allows you to locate the highlighted element.

The **Locate Path** and **Locate** commands can cross-probe to either the Chip Planner, Technology Map Viewer, or Resource Property Editor. Additionally, the **Locate Path** option can cross-probe to Critical Path Settings.

From the **Critical Path Settings** dialog box in the Chip Planner, you can cross-probe to the TimeQuest Timing Analyzer to report critical paths in the design.

#### locate

Use the locate command in the **Console** pane to cross-probe to the Chip Editor, Critical Path Settings, Resource Property Editor, and the Technology Map Viewer.

Example 7–59 shows the locate command and options.

#### Example 7–59. locate Command

```
locate
[-chip]
[-color <black/blue/brown/green/grey/light_grey/orange/purple/red/white>]
[-cps]
[-label <label>]
[-rpe]
[-tmv]
<items>
```

#### Table 7–54 describes the options for the locate command.

#### Table 7-54. locate Options

| Option                                                                                                     | Description                                                                                                                                                                               |
|------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -chip                                                                                                      | Locates the object in the Chip Planner.                                                                                                                                                   |
| -color<br><black <br="" blue="" brown="" green="">grey/light_grey/orange/<br/>purple/red/white&gt;</black> | Identifies the objects you are locating.                                                                                                                                                  |
| -cps                                                                                                       | Locates the object in the Critical Path Settings dialog of the Chip Planner.                                                                                                              |
| -label < <i>label</i> >                                                                                    | Specifies a label used to identify the objects you are locating.                                                                                                                          |
| -rpe                                                                                                       | Locates in the Resource Property Editor.                                                                                                                                                  |
| -tmv                                                                                                       | Locates the object in the Technology Map Viewer.                                                                                                                                          |
| <items></items>                                                                                            | Items to locate. Any collection or object (such as paths, points, nodes, nets, keepers, registers, etc.) may be located by passing a reference to the corresponding collection or object. |

Example 7–60 shows how to cross-probe ten paths from TimeQuest Timing Analyzer to the Chip Editor and locate all data ports in the Technology Map Viewer.

Example 7–60. Cross-probing from TimeQuest

```
# Locate all of the nodes in the longest ten paths
# into the Chip Editor
locate [get_path -npaths 10] -chip
# locate all ports that begin with data to the Tech Map Viewer
locate [get_ports data*] -tmv
```

# **The TimeQuest Timing Analyzer GUI**

The Quartus II TimeQuest Timing Analyzer provides an intuitive and easy-to-use GUI that allows you to efficiently constrain and analyze your designs. The GUI consists of the following panes:

- "The Quartus II Software Interface and Options" described on page 7–80
- "View Pane" described on page 7–81
- "Tasks Pane" described on page 7–83

- "Console Pane" described on page 7–85
  - "Report Pane" described on page 7–85
- "Constraints" described on page 7–85
- "Name Finder" described on page 7–87
- "Target Pane" described on page 7–88
- "SDC Editor" described on page 7–89

Each pane provides features that enhance productivity (Figure 7–35).

Figure 7–35. The TimeQuest GUI

| Edit View Netlist Constraints Reports S    | icript T | 'ools '       | Window H    | telp           |             |           |                  |                           |                                             |
|--------------------------------------------|----------|---------------|-------------|----------------|-------------|-----------|------------------|---------------------------|---------------------------------------------|
| Report ×                                   | Report   | Timin         | g           |                |             |           |                  |                           | ⊙- <u></u>                                  |
| TimeQuest Timing Analyzer Summary          | Comm     | nand In       | o Summi     | ary of Path    | ns          |           |                  |                           |                                             |
|                                            | S        | ilack         | From Node   | •              | To Node     | Launch Cl | ock Latch Clock  |                           |                                             |
|                                            | 1 2      | .836          | state_m:in: | st1 filter.tap | o4 follow   | clk       | clkx2            |                           |                                             |
|                                            | 2 2      | 846           | inst5[5]    |                | yn_out[5]   | clkx2     | clkx2            |                           |                                             |
|                                            | 3 2      | .858          | inst5[7]    |                | yn_out[7]   | clkx2     | clkx2            |                           |                                             |
|                                            | 4 2      | .870          | inst5[2]    |                | yn_out[2]   | clkx2     | clkx2            |                           |                                             |
|                                            | 1912     | .894          | insto[1]    |                | yn_out(1)   | CIKXZ     | CIKXZ            |                           |                                             |
|                                            | Path #   | 1: Seh        | ın slack i  | \$ 2.836       | _           | _         |                  |                           | Path #1: Setun slack is 2.836               |
| Benort SDC                                 | Dath (   | C             | ] Ctatisti  | oo Data        | Path Lucau  | oform     |                  |                           | Path Summany Statistics Data Path Waveform  |
| Report Unconstrained Paths                 | rain :   | summa         | iy Statist  | C2 Dara        | i dui   wav | erorm     |                  |                           | Fath Summary Statistics Data Fath Waverbinn |
|                                            | Data     | ranny.<br>Fal | Ipor        | DE             | Tupe        | Ennort    | Location         | Element                   |                                             |
|                                            | 1 00     | 100           | 0.000       | Inr            | Type        | ranuul    | Lucation         | Liement                   | 7.827 ns                                    |
| Custom Benorts                             | 2 2.7    | 754           | 2.754       | В              |             |           |                  | clock network delay       |                                             |
|                                            | 3 2.8    | 363           | 0.109       |                | uTco        | 1         | LCFF_X37_Y20_N25 | state_m:inst1 filter.tap4 | Launch Clock Launch                         |
|                                            | 4 2.8    | 363           | 0.000       | RR             | CELL        | 6         | LCFF_X37_Y20_N25 | inst1 filter.tap4 regout  | 10.0.02                                     |
| Report Path                                | 5 3.9    | 327           | 1.064       | RR             | IC          | 1         | IOC_X38_Y27_N2   | follow/datain             | Setup Relationship                          |
| Create Slack Histogram                     | 6 6.1    | 164           | 2.237       | RR             | LELL        | J         | PIN_F6           | wollot                    |                                             |
| E Macros                                   |          |               | 10.01       |                |             |           |                  |                           | Latch Clock                                 |
|                                            | Data     | Requ          | red Path    | loc            | T           | Course of | Leveling         | Flores                    |                                             |
| Report I op Failing Paths                  | 1 10     |               | 10,000      | nr             | туре        | ranout    | Location         | Liement                   | Data Arrival                                |
| Report All Core Timings                    | 2 10     | 000           | 0.000       | В              |             |           |                  | clock network delay       | 2,754 ns                                    |
|                                            | 3 9.0    | 000           | -1.000      | R              | oExt        | 0         | PIN_F6           | follow                    | Clock Delay                                 |
| Write SDC File                             |          |               |             |                |             |           |                  |                           | 3.41 ns                                     |
| Set Operating Conditions                   |          |               |             |                |             |           |                  |                           | Data Delay                                  |
|                                            |          |               |             |                |             |           |                  |                           | Slack 2.836 ns                              |
|                                            |          |               |             |                |             |           |                  |                           | CINCK I                                     |
|                                            |          |               |             |                |             |           |                  |                           | Data Required                               |
|                                            |          |               |             |                |             |           |                  |                           | Output Delay -1.0 ns                        |
|                                            |          |               |             |                |             |           |                  |                           | Time (ns) 0.9 4.9 8.9                       |
| 2 💽 🧿 Info: Running Quartus II             | TimeQ    | uest          | Timing .    | Analyze        | r           |           |                  |                           |                                             |
| Info: ************************************ | *****    | *****         | ******      | ******         | *****       | *******   | *****            |                           | ~                                           |
| Console / History /                        |          |               |             |                |             |           |                  |                           |                                             |

### **The Quartus II Software Interface and Options**

The Quartus II software allows you to configure various options for the Quartus II TimeQuest Timing Analyzer report generation that are generated in the Compilation Report for the design.

The TimeQuest Timing Analyzer settings, in the **Settings** dialog box, allow you to configure the options shown in Table 7–55.

Table 7-55. The Quartus II TimeQuest Timing Analyzer Settings (Part 1 of 2)

| Options                                               | Description                                                                             |
|-------------------------------------------------------|-----------------------------------------------------------------------------------------|
| .sdc files to include in the project                  | Adds and removes .sdc files associated with the project.                                |
| Enable Advanced I/O Timing                            | Generates advanced I/O timing results from board trace models specified for each pin.   |
| Enable multicorner timing analysis during compilation | Generates multiple reports for all available operating conditions of the target device. |

| Options                                                   | Description                                                                  |
|-----------------------------------------------------------|------------------------------------------------------------------------------|
| Report worst-case paths during compilation                | Generates worst-case path reports per clock domain.                          |
| Tcl Script File for customizing report during compilation | Specifies any custom scripts to be sourced for any custom report generation. |

#### Table 7-55. The Quartus II TimeQuest Timing Analyzer Settings (Part 2 of 2)

The options shown in Table 7–55 control only the reports generated in the Compilation Report, and do not control the reports generated in the Quartus II TimeQuest Timing Analyzer.

### **View Pane**

The **View** pane is the main viewing area for the timing analysis results. Use the **View** pane to view summary reports, custom reports, or histograms. Figure 7–36 shows the **View** pane after you select the **Summary (Setup)** report from the Report pane.

Figure 7-36. Summary (Setup) Report

| Su | immary (Setup)                             |       |               | ⊙ 🕂 |
|----|--------------------------------------------|-------|---------------|-----|
|    | Clock                                      | Slack | End Point TNS |     |
| 1  | inclk0                                     | 0.303 | 0.000         |     |
| 2  | altpll0:inst altpll:altpll_component[_clk0 | 0.384 | 0.000         |     |
|    |                                            |       |               |     |
|    |                                            |       |               |     |
|    |                                            |       |               |     |
|    |                                            |       |               |     |

#### **View Pane: Splitting**

For analyzing the timing results properly, comparing multiple reports is extremely important. To facilitate multiple report viewing, the **View** pane supports window splitting. Window splitting divides the **View** pane into multiple windows, allowing you to view different reports side-by-side.

You can split the **View** pane into multiple windows using the split icon located in the upper right corner of the **View** pane. Drag the icon in different directions to generate additional window views in the **View** pane. For example, if you drag the split icon to the left, the **View** pane creates a new window to the right of the current window (Figure 7–37).

| Sı | immary (Setup)                             |       | <b>⊙</b> +    | 5 | ummary (Setup)                             |       | 0-            |
|----|--------------------------------------------|-------|---------------|---|--------------------------------------------|-------|---------------|
|    | Clock                                      | Slack | End Point TNS | Г | Clock                                      | Slack | End Point TNS |
| 1  | inclk0                                     | 0.303 | 0.000         | 1 | inclk0                                     | 0.303 | 0.000         |
| 2  | altpll0:inst altpll:altpll_component[_clk0 | 0.384 | 0.000         | 2 | altpll0:inst altpll:altpll_component[_clk0 | 0.384 | 0.000         |
| 51 | ımmary (Setup)                             |       |               |   |                                            |       | 0-            |
|    | Clock                                      | Slack | End Point TNS |   |                                            |       |               |
| 1  | inclk0                                     | 0.303 | 0.000         |   |                                            |       |               |
| 2  | altpll0:inst altpll:altpll_component[_clk0 | 0.384 | 0.000         |   |                                            |       |               |
|    |                                            |       |               |   |                                            |       |               |

Figure 7–37. Splitting the View Pane to the Left (Before and After Split Left)

If you drag the split icon diagonally, the **View** pane creates three new windows in the **View** pane (Figure 7–38).

| Sı | ımmary (Setup)                             |       | <b>⊙</b> -1   | 2 | Sum   | mary (Setup)                             |       | 0+            |
|----|--------------------------------------------|-------|---------------|---|-------|------------------------------------------|-------|---------------|
|    | Clock                                      | Slack | End Point TNS |   | C     | lock                                     | Slack | End Point TNS |
| 1  | inclk0                                     | 0.303 | 0.000         |   | 1 in  | clk0                                     | 0.303 | 0.000         |
| 2  | altpll0:inst altpll:altpll_component[_clk0 | 0.384 | 0.000         |   | 2 all | tpll0:inst altpll:altpll_component[_clk0 | 0.384 | 0.000         |
|    |                                            |       |               |   |       |                                          |       |               |
| Su | ımmary (Setup)                             |       | 0-            | 2 | Sum   | imary (Setup)                            |       | 0-j           |
|    | Clock                                      | Slack | End Point TNS |   | CI    | lock                                     | Slack | End Point TNS |
| 1  | inclk0                                     | 0.303 | 0.000         |   | 1 in  | clk0                                     | 0.303 | 0.000         |
| 2  | altpll0:inst altpll:altpll_component[_clk0 | 0.384 | 0.000         |   | 2 all | tpll0:inst altpll:altpll_component[_clk0 | 0.384 | 0.000         |
| 51 | ımmary (Setup)                             |       |               |   |       |                                          |       | <u>0</u> +    |
|    | Clock                                      | Slack | End Point TNS |   |       |                                          |       |               |
| 1  | inclk0                                     | 0.303 | 0.000         |   |       |                                          |       |               |
| 2  | altpll0:inst(altpll:altpll_component(_clk0 | 0.384 | 0.000         |   |       |                                          |       |               |
|    |                                            |       |               |   |       |                                          |       |               |

Figure 7–38. Splitting the View Pane Diagonally (Before and After Diagonal Split)

Drag the split icon downward to create a new window directly below the current window.

#### **View Pane: Removing Split Windows**

You can remove windows that you create in the View pane using the split icon by dragging the border of the window over the window you wish to remove (Figure 7–39).

Figure 7-39. Removing a Split Window (Before and After Split is Removed)

| Sı | ımmary (Setup)                             |       |               | <b>⊙</b> + |
|----|--------------------------------------------|-------|---------------|------------|
|    | Clock                                      | Slack | End Point TNS |            |
| 1  | inclk0                                     | 0.303 | 0.000         |            |
| 2  | altpll0:inst altpll:altpll_component[_clk0 | 0.384 | 0.000         |            |
|    |                                            |       |               |            |

| Sı | immary (Setup)                             |       | 6             | 2 | Fr                | nax Summar                                                                                      | У                                                                                                                                                                                                                  | 0+                    |
|----|--------------------------------------------|-------|---------------|---|-------------------|-------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|
|    | Clock                                      | Slack | End Point TNS |   | Γ                 | Fmax (MHz)                                                                                      | Clock Name                                                                                                                                                                                                         |                       |
| 1  | inclk0                                     | 0.303 | 0.000         |   | 1                 | 1623.38                                                                                         | altpll0:inst altpll:altpll_component _clk0                                                                                                                                                                         |                       |
| 2  | altpll0:inst(altpll:altpll_component(_clk0 | 0.384 | 0.000         |   | 2                 | 1434.72                                                                                         | inclk0                                                                                                                                                                                                             |                       |
|    |                                            |       |               |   | T<br>rr<br>c<br>c | his panel repor<br>egardless of the<br>computed for pa<br>r ports are drive<br>locks, including | ts FMAX for every clock in the design,<br>a user-specified clock periods. FMAX is o<br>where the source and destination re<br>en by the same clock. Paths of different<br>g generated clocks, are ignored. For pat | only<br>gisters<br>hs |

### **Tasks Pane**

Use the **Tasks** pane to access common commands such as netlist setup and report generation.

The following common commands are located in the **Tasks** pane: Open Project, Set Operating Conditions, and Reset Design. The other commands, including timing netlist setup and report generation, are contained in the following folders:

- Netlist Setup
- Reports

Each command in the **Tasks** pane has an equivalent Tcl command that is displayed in the **Console** pane when the command runs.

#### **Opening a Project and Writing a Synopsys Design Constraints File**

To open a project in the Quartus II TimeQuest Timing Analyzer, double-click the **Open Project** task. If you launch the Quartus II TimeQuest Timing Analyzer from the Quartus II software GUI, the project opens automatically.

You can add or remove constraints from the timing netlist after the Quartus II TimeQuest Timing Analyzer reads the initial **.sdc** file. After the file is read, the initial **.sdc** file becomes outdated compared to the constraints in the Quartus II TimeQuest Timing Analyzer. Use the **Write SDC File** command to generate an **.sdc** file that is up-to-date and reflects the current state of constraints in the Quartus II TimeQuest Timing Analyzer.

#### **Netlist Setup Folder**

The Netlist Setup folder contains tasks that are used to set up the timing netlist for timing analysis. The three tasks located in this folder are Create Timing Netlist, Read SDC File, and Update Timing Netlist.

Use the Create Timing Netlist task to create a netlist that the Quartus II TimeQuest Timing Analyzer uses to perform static timing analysis. This netlist is used only for timing analysis by the Quartus II TimeQuest Timing Analyzer.

You must always create a timing netlist before you perform an analysis with the Quartus II TimeQuest Timing Analyzer.

Use the Read SDC File command to apply constraints to the timing netlist. By default, the Read SDC File command reads the *<current revision***>.sdc** file.

Use the read\_sdc command to read an **.sdc** file that is not associated with the current revision of the design.

Use the Update Timing Netlist command to update the timing netlist after you enter constraints or read an **.sdc** file. You should use this command if any constraints are added or removed from the design.

### **Reports Folder**

The Reports folder contains commands to generate timing summary reports of the static timing analysis results. The twelve commands located in this folder are summarized in Table 7–56.

Table 7-56. Reports Folder Commands

| Report Task                | Description                                                                   |
|----------------------------|-------------------------------------------------------------------------------|
| Report Fmax Summary        | Generates a f <sub>MAX</sub> summary report for all clocks in the design.     |
| Report Setup Summary       | Generates a clock setup summary report for all clocks in the design.          |
| Report Hold Summary        | Generates a clock hold summary report for all clocks in the design.           |
| Report Recovery Summary    | Generates a recovery summary report for all clocks in the design.             |
| Report Removal Summary     | Generates a removal summary report for all clocks in the design.              |
| Report Clocks              | Generates a summary report of all created clocks in the design.               |
| Report Clock Transfers     | Generates a summary report of all clock transfers detected in the design.     |
| Report Minimum Pulse Width | Generates a summary report of all minimum pulse widths in the design.         |
| Report SDC                 | Generates a summary report of the constraints read from the <b>.sdc</b> file. |
| Report Unconstrained Paths | Generates a summary report of all unconstrained paths in the design.          |
| Report Ignored Constraints | Generates a summary report of all ignored SDC constraints for the design.     |
| Report Datasheet           | Generates a datasheet report for the design.                                  |

### **Macros Folder**

The Macros folder contains commands that perform custom tasks available in the Quartus II TimeQuest Timing Analyzer utility package. These commands are: Report All Summaries, Report Top Failing Paths, and Create All Clock Histograms.

Table 7–57 describes the commands available in the Macros folder.

| Macro Task                  | Description                                                                                                                                                                         |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Report All Summaries        | This command runs the Report Setup Summary, Report Hold Summary, Report Recovery Summary, Report Removal Summary, and Minimum Pulse Width commands to generate all summary reports. |
| Report Top Failing Paths    | This command generates a report containing a list of top failing paths.                                                                                                             |
| Create All Clock Histograms | This command runs the Create Slack Histogram command to generate a clock histogram for all clocks in the design.                                                                    |
| Report All I/O Timings      | This command generates a report of all timing paths that start or end at a device port.                                                                                             |
| Report All Core Timings     | This command generates a report of all timing paths that start and end at the device register.                                                                                      |

Table 7–57. Macros Folder Commands

### **Console Pane**

The **Console** pane is both a message center for the Quartus II TimeQuest Timing Analyzer and an interactive Tcl console. The **Console** pane has two tabs: the **Console** tab and the **History** tab. The **Console** tab shows all messages, such as info and warning messages. Also, the Console tab allows you to enter and run Synopsys design constraints and Tcl commands. The Console tab shows the Tcl equivalent of all commands that you run in the **Tasks** pane. The History tab records all the Synopsys design constraints and Tcl commands that are run.

To run the commands located in the History tab after the timing netlist has been updated, right-click the command and click **Rerun**.

You can copy Tcl commands from the Console and History tabs to easily generate Tcl scripts to perform timing analysis.

### **Report Pane**

Use the **Report** pane to access all reports generated from the **Tasks** pane, and by any custom report commands. When you select a report in the **Report** pane, the report is shown in the active window in the **View** pane.



If a report is out-of-date with respect to the current constraints, a "?" icon is shown next to the report.

### **Constraints**

Use the Constraints menu to access commonly used constraints, exceptions, and commands. You can access this menu from the toolbar, click **Edit** and then click **Constraint menu**.

The following commands are available on the Constraints menu:

- Create Clock
- Create Generated Clock
- Set Clock Latency
- Set Clock Uncertainty
- Set Clock Groups
- Remove Clock

For example, use the **Create Clock** dialog box to create clocks in your design. Figure 7–40 shows the **Create Clock** dialog box.

| Figure 7–40. | Create | Clock | Dialog | Box |
|--------------|--------|-------|--------|-----|
|--------------|--------|-------|--------|-----|

| lock name:      | clock_sys                   |             |              |          |              |     |      |  |
|-----------------|-----------------------------|-------------|--------------|----------|--------------|-----|------|--|
| eriod:          | 10.000                      | ns          |              |          |              | ٦   |      |  |
| -Waveform edges |                             |             |              |          |              |     |      |  |
| Rising:         | 2.5 ns                      | s           |              |          |              |     |      |  |
| Falling:        | 7.5 ns                      | s –         | 2.           | 5        |              | 7.5 | 10.0 |  |
|                 |                             |             |              |          |              |     |      |  |
| l argets:       | Ск                          |             |              |          |              |     |      |  |
| SDC command:    | create_clock -period 10.000 | ) -name clo | ock_sys -wav | veform { | 2.5 7.5} cli | <   |      |  |
|                 |                             |             |              |          |              |     |      |  |

The following commands specify timing exceptions and are available on the Constraints menu:

- Set False Path
- Set Multicycle Path
- Set Maximum Delay
- **Set Minimum Delay**

All the dialog boxes used to specify timing constraints or exceptions from commands have an SDC command field. This field contains the SDC command that is run when you click OK.

All commands and constraints created in the Quartus II TimeQuest Timing Analyzer user interface are echoed in the **Console** pane.

The constraints specified with Constraints menu commands are not saved to the current **.sdc** file automatically. You must run the **Write SDC File** command to save your constraints.

The following commands are available on the Constraints menu in the Quartus II TimeQuest Timing Analyzer:

- Generate SDC File from QSF
- Read SDC File
- Write SDC File

The **Generate SDC File from QSF** command runs a Tcl script that converts the Quartus II Classic Timing Analyzer constraints in a QSF file to an **.sdc** file for the Quartus II TimeQuest Timing Analyzer. The file *<current revision>.sdc* is created by this command.

For information about the Generate SDC File from QSF command, refer to the *Switching to the Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

The Generate SDC File from QSF command attempts to convert all timing constraints and exceptions in the QSF file to their equivalent **.sdc** file constraints. However, not all QSF file constraints are convertible to **.sdc** file constraints. Review the **.sdc** file after it is created to ensure that all constraints have been successfully converted.

The Read SDC File command reads the <*current revision*>.sdc file.

When you select the **Write SDC File** command, an up-to-date **.sdc** file that reflects the current state of constraints in the Quartus II TimeQuest Timing Analyzer is generated.

### **Name Finder**

Use the **Name Finder** dialog box to select the target for any constraints or exceptions in the Quartus II TimeQuest Timing Analyzer GUI. The **Name Finder** dialog box allows you to specify collections, filters, and filter options. The Collections field in the **Name Finder** dialog box allows you to specify the type of name to select. To select the type, in the **Collection** list, select the desired collection API from the following list:

- get\_cells
- get\_clocks
- get\_keepers
- get\_nets
- get\_nodes
- get\_pins
- get\_ports
- get\_registers

For more information about the various collection APIs, refer to "Collections" on page 7–21.

The Filter field allows you to filter names based on your own criteria, including wildcard characters. You can further refine your results using the following filter options:

- Case-insensitive
- Hierarchical
- Compatibility mode

For more information about the filter options, refer to "Wildcard Assignments and Collections" on page 7–76.

The Name Finder dialog box also provides an SDC command field that displays the currently selected name search command. You can copy the value from this field and use it for other constraint target fields. The **Name Finder** dialog box is shown in Figure 7–41.

| Collection:                                                                                                                                                                                                                                       | get_cells                                                                                | ▼ <u>F</u> ilter: | ×                  |                                                              |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|-------------------|--------------------|--------------------------------------------------------------|--|
| Options<br>Fierarchice<br>Compatibilit<br>Matches<br>List<br>8 matches fou<br>acq_clk<br>acq_clk<br>acq_clk<br>acq_clk<br>acq_clk<br>acq_clk<br>acq_clk<br>acq_clk<br>acq_clk<br>acq_rtigger_i<br>altera_interm<br>altera_reserv<br>altera_reserv | sitive<br>y mode<br>ind<br>0]<br>n(0)<br>4) (tag<br>ed_tck<br>ed_tdi<br>ed_tdi<br>ed_tms |                   | >>><               | 2 selected names<br>acq_trigger_in[0]<br>altera_reserved_tdo |  |
| SDC commonde                                                                                                                                                                                                                                      | faet cells no ca                                                                         | se (acol trioge   | r in 101 altera re | eserved tdo}]                                                |  |

Figure 7–41. Name Finder Dialog Box

### **Target Pane**

When using the TimeQuest GUI, you can split the **View** pane into multiple windows. The splitting feature allows you to display multiple reports in the **View** pane. After splitting the **View** pane, the last active window is updated with any new reports. You can change this behavior by changing the state of each split window. To change the window state, click the target circle in the upper right corner (Figure 7–42). Table 7–58 describes the state of each window.



Figure 7–42. Target Pane

| State                       | Description                                                                                     |
|-----------------------------|-------------------------------------------------------------------------------------------------|
| Partially Filled Red Circle | Indicates that the active window displays any new reports.                                      |
| Fully Filled Red Circle     | Indicates that the window, independent of it being the active window, displays any new reports. |
| Empty Circle                | Indicates that the window does not display any new reports.                                     |

 Table 7–58.
 View Pane Window State

Clicking on the circle in the upper right corner of an active window changes the state of the window.

### **SDC Editor**

The TimeQuest Timing Analyzer GUI also provides an SDC editor. The SDC editor provides an easy and convenient way to write, edit, and view **.sdc** files. The SDC editor is context sensitive. After an SDC constraint or exception has been entered, a tooltip appears that shows the options and format for the constraint or exception.

The SDC editor also provides helpful tools, including SDC templates and SDC templates for common design structures. To find these templates, when the SDC editor is active, look on the **Edit** menu.

On the menu bar, the Constraints menu opens the **Constraints** dialog box. After you have finished entering all required parameters, the **.sdc** file is inserted at the current cursor position.

# Conclusion

The Quartus II TimeQuest Timing Analyzer addresses the requirements of complex designs, resulting in increased productivity and efficiency through its intuitive user interface, support of industry-standard constraints format, and scripting capabilities. The Quartus II TimeQuest Timing Analyzer is a next-generation timing analysis tool that supports the industry-standard SDC format and allows designers to create, manage, and analyze complex timing constraints and to perform advanced timing verification.

# **Referenced Documents**

This chapter references the following documents:

- AN 481: Applying Multicycle Exceptions in the TimeQuest Timing Analyzer
- *I/O Management* chapter in volume 2 of the *Quartus II Handbook*
- Managing Metastability with the Quartus II Software chapter of volume 1 in the Quartus II Handbook
- Quartus II TimeQuest Timing Analyzer Cookbook
- SDC and TimeQuest API Reference Manual
- Switching to the Quartus II TimeQuest Timing Analyzer chapter in volume 3 of the Quartus II Handbook
- TimeQuest Quick Start Tutorial

- Understanding Metastability in FPGAs White Paper
- Volume 4: SOPC Builder in the Quartus II Handbook

# **Document Revision History**

Table 7–59 shows the revision history for this chapter.

Table 7-59. Document Revision History (Part 1 of 2)

| Date and<br>Version  | Changes Made                                                             | Summary of Changes            |
|----------------------|--------------------------------------------------------------------------|-------------------------------|
| March 2009<br>v9.0.0 | Updated Table 7–1                                                        | Updated for the Quartus II    |
|                      | <ul> <li>Updated "Metastability" on page 7–15</li> </ul>                 | software version 9.0 release. |
|                      | <ul> <li>Updated "Delay and Skew Specifications" on page 7–42</li> </ul> |                               |
|                      | Added "set_max_skew" on page 7–43                                        |                               |
|                      | Added "report_exceptions" on page 7–55                                   |                               |
|                      | <ul> <li>Updated "report_metastability" on page 7–57</li> </ul>          |                               |
|                      | <ul> <li>Added "report_partitions" on page 7–66</li> </ul>               |                               |
|                      | Added "report_max_skew" on page 7–69                                     |                               |
|                      | <ul> <li>Updated "Multi-Corner Analysis" on page 7–74</li> </ul>         |                               |
|                      | Added Table 7–52                                                         |                               |
|                      | <ul> <li>Removed report_path section</li> </ul>                          |                               |
|                      | <ul> <li>Minor editorial updates</li> </ul>                              |                               |

#### Table 7–59. Document Revision History (Part 2 of 2)

| Date and<br>Version | Changes Made                                                                                                                                                    | Summary of Changes                                                        |  |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|--|
| November 2008       | Updated for the Quartus II software version 8.1, including:                                                                                                     | Medium update for the                                                     |  |
| v8.1.0              | <ul> <li>Added the following sections:</li> </ul>                                                                                                               | Quartus II software version<br>8.1 release.                               |  |
|                     | <ul> <li>"set_net_delay" on page 7–42</li> </ul>                                                                                                                |                                                                           |  |
|                     | <ul> <li>"Annotated Delay" on page 7–49</li> </ul>                                                                                                              |                                                                           |  |
|                     | <ul> <li>"report_net_delay" on page 7–66</li> </ul>                                                                                                             |                                                                           |  |
|                     | <ul> <li>Updated the descriptions of the -append and -file <name><br/>options in tables throughout the chapter</name></li> </ul>                                |                                                                           |  |
|                     | <ul> <li>Updated entire chapter using 8½" × 11" chapter template</li> </ul>                                                                                     |                                                                           |  |
|                     | <ul> <li>Minor editorial updates</li> </ul>                                                                                                                     |                                                                           |  |
| May 2008<br>v8.0.0  | Updated for the Quartus II software version 8.0, including:                                                                                                     | Significant update for the<br>Quartus II software version<br>8.0 release. |  |
|                     | <ul> <li>Changed the heading "Specify Design Timing Requirements" to "The<br/>Quartus II TimeQuest Timing Analyzer Flow Guidelines" on page 7–26</li> </ul>     |                                                                           |  |
|                     | <ul> <li>In "SDC Constraint Files" on page 7–29, added information about<br/>order-sensitivity</li> </ul>                                                       |                                                                           |  |
|                     | <ul> <li>Added a new section on "Metastability" on page 7–19</li> </ul>                                                                                         |                                                                           |  |
|                     | <ul> <li>Added a new section on "Common Clock Path Pessimism" on page<br/>7–22</li> </ul>                                                                       |                                                                           |  |
|                     | <ul> <li>Removed information about Asynchronous clocks from "Clock<br/>Groups" on page 7–43</li> </ul>                                                          |                                                                           |  |
|                     | <ul> <li>Updated information in Example 7–28</li> </ul>                                                                                                         |                                                                           |  |
|                     | <ul> <li>Added three entries to Table 7–22</li> </ul>                                                                                                           |                                                                           |  |
|                     | <ul> <li>Added information to Table 7–24</li> </ul>                                                                                                             |                                                                           |  |
|                     | <ul> <li>Added information about the RSKM to "report_rskm" on page 7-80,<br/>including a formulaic equation (Equation 12)</li> </ul>                            |                                                                           |  |
|                     | <ul> <li>Added the section "Clock Groups" on page 7–43</li> </ul>                                                                                               |                                                                           |  |
|                     | <ul> <li>Added Table 7–44 to "report_clock_fmax_summary" on page 7–86</li> </ul>                                                                                |                                                                           |  |
|                     | <ul> <li>Added qualifier to introduction of Table 7–46</li> </ul>                                                                                               |                                                                           |  |
|                     | <ul> <li>Added Speed Grade information to Table 7–46</li> </ul>                                                                                                 |                                                                           |  |
|                     | <ul> <li>Removed [-dtw] and added [-add] to information about the<br/>derive_clock_uncertainty command ("Derive Clock Uncertainty" on<br/>page 7–47)</li> </ul> |                                                                           |  |
|                     | <ul> <li>Added the section "report_metastability" on page 7–68</li> </ul>                                                                                       |                                                                           |  |
|                     | <ul> <li>Added a new information about RSKM to "report_rskm" on page<br/>7–80</li> </ul>                                                                        |                                                                           |  |
|                     | <ul> <li>Added the section "Cross-Probing" on page 7–93</li> </ul>                                                                                              |                                                                           |  |
|                     | <ul> <li>Minor editorial updates</li> </ul>                                                                                                                     |                                                                           |  |
|                     | <ul> <li>Added hyperlinks to referenced documents throughout chapter</li> </ul>                                                                                 |                                                                           |  |

**For previous versions of the** *Quartus II Handbook*, refer to the Quartus II Handbook Archive.