



---

## **Quartus II Version 8.0 Handbook**

---

### **Volume 3: Verification**



101 Innovation Drive  
San Jose, CA 95134  
[www.altera.com](http://www.altera.com)

Copyright © 2008 Altera Corporation. All rights reserved. Altera, The Programmable Solutions Company, the stylized Altera logo, specific device designations, and all other words and logos that are identified as trademarks and/or service marks are, unless noted otherwise, the trademarks and service marks of Altera Corporation in the U.S. and other countries. All other product or service names are the property of their respective holders. Altera products are protected under numerous U.S. and foreign patents and pending applications, maskwork rights, and copyrights. Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera Corporation. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.



|                                     |               |
|-------------------------------------|---------------|
| <b>Chapter Revision Dates .....</b> | <b>xxxiii</b> |
|-------------------------------------|---------------|

|                                  |             |
|----------------------------------|-------------|
| <b>About this Handbook .....</b> | <b>XXXV</b> |
|----------------------------------|-------------|

|                                                |       |
|------------------------------------------------|-------|
| How to Contact Altera .....                    | XXXV  |
| Third-Party Software Product Information ..... | XXXV  |
| Typographic Conventions .....                  | XXXVI |

## Section I. Simulation

### Chapter 1. Quartus II Simulator

|                                                            |      |
|------------------------------------------------------------|------|
| Introduction .....                                         | 1-1  |
| Simulation Flow .....                                      | 1-2  |
| Functional Simulation .....                                | 1-4  |
| Timing Simulation .....                                    | 1-5  |
| Timing Simulation Using Fast Timing Model Simulation ..... | 1-5  |
| Waveform Editor .....                                      | 1-6  |
| Creating VWFs .....                                        | 1-6  |
| Count Value .....                                          | 1-12 |
| Clock .....                                                | 1-12 |
| Arbitrary Value .....                                      | 1-13 |
| Random Value .....                                         | 1-14 |
| Generating a Testbench .....                               | 1-14 |
| Grid Size .....                                            | 1-15 |
| Time Bars .....                                            | 1-15 |
| Stretch or Compress a Waveform Interval .....              | 1-16 |
| End Time .....                                             | 1-17 |
| Arrange Group or Bus in LSB or MSB Order .....             | 1-18 |
| Simulator Settings .....                                   | 1-18 |
| Simulation Verification Options .....                      | 1-22 |
| Simulation Output Files Options .....                      | 1-25 |
| Simulation Report .....                                    | 1-26 |
| Simulation Waveform .....                                  | 1-26 |
| Simulating Bidirectional Pin .....                         | 1-27 |
| Logical Memories Report .....                              | 1-28 |
| Simulation Coverage Reports .....                          | 1-28 |
| Comparing Two Waveforms .....                              | 1-29 |
| Debugging with the Quartus II Simulator .....              | 1-30 |
| Breakpoints .....                                          | 1-30 |
| Updating Memory Content .....                              | 1-31 |

|                                                 |      |
|-------------------------------------------------|------|
| Last Simulation Vector Outputs .....            | 1-31 |
| Conventional Debugging Process .....            | 1-31 |
| Accessing Internal Signals for Simulation ..... | 1-31 |
| Scripting Support .....                         | 1-33 |
| Conclusion .....                                | 1-34 |
| Referenced Documents .....                      | 1-34 |
| Document Revision History .....                 | 1-35 |

## Chapter 2. Mentor Graphics ModelSim Support

|                                                                               |      |
|-------------------------------------------------------------------------------|------|
| Introduction .....                                                            | 2-1  |
| Background .....                                                              | 2-1  |
| Software Compatibility .....                                                  | 2-3  |
| Altera Design Flow with ModelSim-Altera or Modelsim Software .....            | 2-3  |
| Simulation Libraries .....                                                    | 2-5  |
| Pre-Compiled Simulation Libraries in Modelsim-Altera Software .....           | 2-5  |
| RTL Functional Simulation Libraries .....                                     | 2-6  |
| Gate-Level Simulation Libraries .....                                         | 2-7  |
| Simulation Library Files in the Quartus II Software .....                     | 2-9  |
| RTL Functional Simulation Library Files .....                                 | 2-9  |
| Gate-Level Simulation Library Files .....                                     | 2-10 |
| Simulation Netlist Files .....                                                | 2-13 |
| Generate Post-Synthesis Simulation Netlist Files .....                        | 2-13 |
| Generate Gate-Level Timing Simulation Netlist Files .....                     | 2-15 |
| Generating Timing Simulation Netlist Files with Different Timing Models ..... | 2-16 |
| Disable Timing Violation on Registers .....                                   | 2-18 |
| Perform Simulation Using ModelSim-Altera Software .....                       | 2-18 |
| Simulating the VHDL Designs (Through GUI) .....                               | 2-18 |
| Perform RTL Functional Simulation .....                                       | 2-19 |
| Compile Testbench and Design Files into the Work Library .....                | 2-19 |
| Loading the Design .....                                                      | 2-20 |
| Running the Simulation .....                                                  | 2-20 |
| Perform Post-Synthesis Simulation .....                                       | 2-21 |
| Compile Testbench and VHDL Output File into the Work Library .....            | 2-21 |
| Loading the Design .....                                                      | 2-22 |
| Running the Simulation .....                                                  | 2-23 |
| Perform Gate-Level Simulation .....                                           | 2-23 |
| Compile Testbench and VHDL Output File into the Work Library .....            | 2-23 |
| Loading the Design .....                                                      | 2-24 |
| Running the Simulation .....                                                  | 2-26 |
| Simulating the Verilog HDL Designs (Through GUI) .....                        | 2-26 |
| Perform RTL Functional Simulation .....                                       | 2-26 |
| Compile Testbench and Design Files into the Work Library .....                | 2-26 |
| Loading the Design .....                                                      | 2-27 |
| Running the Simulation .....                                                  | 2-28 |

---

|                                                                           |      |
|---------------------------------------------------------------------------|------|
| Perform Post-Synthesis Simulation .....                                   | 2-28 |
| Compile Testbench and Verilog HDL Output File into the Work Library ..... | 2-29 |
| Loading the Design .....                                                  | 2-30 |
| Running the Simulation .....                                              | 2-30 |
| Perform Gate-Level Simulation .....                                       | 2-31 |
| Compile Testbench and Verilog HDL Output File into the Work Library ..... | 2-31 |
| Loading the Design .....                                                  | 2-32 |
| Running the Simulation .....                                              | 2-33 |
| Simulating the VHDL Designs (Through Command-line) .....                  | 2-33 |
| Perform RTL Functional Simulation .....                                   | 2-33 |
| Compile Testbench and Design Files into the Work Library .....            | 2-34 |
| Loading the Design .....                                                  | 2-34 |
| Running the Simulation .....                                              | 2-35 |
| Perform Post-Synthesis Simulation .....                                   | 2-35 |
| Compile Testbench and VHDL Output File into the Work Library .....        | 2-35 |
| Loading the Design .....                                                  | 2-36 |
| Running the Simulation .....                                              | 2-36 |
| Perform Gate-Level Simulation .....                                       | 2-37 |
| Compile Testbench and VHDL Output File into the Work Library .....        | 2-37 |
| Loading the Design .....                                                  | 2-38 |
| Running the Simulation .....                                              | 2-38 |
| Simulating the Verilog HDL Designs (Through Command-line) .....           | 2-38 |
| Perform RTL Functional Simulation .....                                   | 2-39 |
| Compile Testbench and Design Files into the Work Library .....            | 2-39 |
| Loading the Design .....                                                  | 2-39 |
| Running the Simulation .....                                              | 2-40 |
| Perform Post-Synthesis Simulation .....                                   | 2-40 |
| Compile Testbench and Verilog Output File into the Work Library .....     | 2-40 |
| Loading the Design .....                                                  | 2-41 |
| Running the Simulation .....                                              | 2-41 |
| Perform Gate-Level Simulation .....                                       | 2-42 |
| Compile Testbench and Verilog Output File into the Work Library .....     | 2-42 |
| Loading the Design .....                                                  | 2-43 |
| Running the Simulation .....                                              | 2-43 |
| Perform Simulation Using Modelsim Software .....                          | 2-43 |
| Simulating the VHDL Designs (Through GUI) .....                           | 2-44 |
| Perform RTL Functional Simulation .....                                   | 2-44 |
| Create Simulation Libraries .....                                         | 2-44 |
| Compile Simulation Models into Simulation Libraries .....                 | 2-45 |
| Compile Testbench and Design Files into the Work Library .....            | 2-45 |
| Loading the Design .....                                                  | 2-46 |
| Running the Simulation .....                                              | 2-46 |
| Perform Post-Synthesis Simulation .....                                   | 2-47 |
| Create Simulation Libraries .....                                         | 2-47 |
| Compile Simulation Models into Simulation Libraries .....                 | 2-48 |
| Compile Testbench and VHDL Output File into the Work Library .....        | 2-48 |
| Loading the Design .....                                                  | 2-49 |
| Running the Simulation .....                                              | 2-49 |

|                                                                       |      |
|-----------------------------------------------------------------------|------|
| Perform Gate-Level Simulation .....                                   | 2-50 |
| Create Simulation Libraries .....                                     | 2-50 |
| Compile Simulation Models into Simulation Libraries .....             | 2-51 |
| Compile Testbench and Design Files into the Work Library .....        | 2-51 |
| Loading the Design .....                                              | 2-52 |
| Running the Simulation .....                                          | 2-53 |
| Simulating the Verilog HDL Designs (Through GUI) .....                | 2-53 |
| Perform RTL Functional Simulation .....                               | 2-53 |
| Create Simulation Libraries .....                                     | 2-53 |
| Compile Simulation Models into Simulation Libraries .....             | 2-54 |
| Compile Testbench and Design Files into the Work Library .....        | 2-55 |
| Loading the Design .....                                              | 2-55 |
| Running the Simulation .....                                          | 2-56 |
| Perform Post-Synthesis Simulation .....                               | 2-56 |
| Create Simulation Libraries .....                                     | 2-56 |
| Compile Simulation Models into Simulation Libraries .....             | 2-57 |
| Compile Testbench and Verilog Output File into the Work Library ..... | 2-58 |
| Loading the Design .....                                              | 2-58 |
| Running the Simulation .....                                          | 2-59 |
| Perform Gate-Level Simulation .....                                   | 2-59 |
| Create Simulation Libraries .....                                     | 2-59 |
| Compile Simulation Models into Simulation Libraries .....             | 2-60 |
| Compile Testbench and Verilog Output File into the Work Library ..... | 2-61 |
| Loading the Design .....                                              | 2-61 |
| Running the Simulation .....                                          | 2-62 |
| Simulating the VHDL Designs (Through Command-line) .....              | 2-62 |
| Perform RTL Functional Simulation .....                               | 2-63 |
| Create Simulation Libraries .....                                     | 2-63 |
| Compile Simulation Models into Simulation Libraries .....             | 2-64 |
| Compile Testbench and Design Files into the Work Library .....        | 2-64 |
| Loading the Design .....                                              | 2-65 |
| Running the Simulation .....                                          | 2-65 |
| Perform Post-Synthesis Simulation .....                               | 2-65 |
| Create Simulation Libraries .....                                     | 2-65 |
| Compile Simulation Models into Simulation Libraries .....             | 2-66 |
| Compile Testbench and VHDL Output Files into the Work Library .....   | 2-66 |
| Loading the Design .....                                              | 2-67 |
| Running the Simulation .....                                          | 2-67 |
| Perform Gate-Level Simulation .....                                   | 2-67 |
| Create Simulation Libraries .....                                     | 2-68 |
| Compile Simulation Models into Simulation Libraries .....             | 2-68 |
| Compile Testbench and VHDL Output Files into the Work Library .....   | 2-69 |
| Loading the Design .....                                              | 2-69 |
| Running the Simulation .....                                          | 2-69 |
| Simulating the Verilog HDL Designs (Through Command-line) .....       | 2-70 |
| Perform RTL Functional Simulation .....                               | 2-70 |
| Create Simulation Libraries .....                                     | 2-70 |
| Compile Simulation Models into Simulation Libraries .....             | 2-71 |
| Compile Testbench and Design Files into the Work Library .....        | 2-71 |

---

|                                                                                |      |
|--------------------------------------------------------------------------------|------|
| Loading the Design .....                                                       | 2-72 |
| Running the Simulation .....                                                   | 2-72 |
| Perform Post-Synthesis Simulation .....                                        | 2-72 |
| Create Simulation Libraries .....                                              | 2-73 |
| Compile Simulation Models into Simulation Libraries .....                      | 2-73 |
| Compile Testbench and Verilog Output Files into the Work Library .....         | 2-74 |
| Loading the Design .....                                                       | 2-74 |
| Running the Simulation .....                                                   | 2-74 |
| Perform Gate-Level Simulation .....                                            | 2-75 |
| Create Simulation Libraries .....                                              | 2-75 |
| Compile Simulation Models into Simulation Libraries .....                      | 2-76 |
| Compile Testbench and Verilog Output Files into the Work Library .....         | 2-76 |
| Loading the Design .....                                                       | 2-76 |
| Running the Simulation .....                                                   | 2-77 |
| Simulating Designs that Include Transceivers .....                             | 2-77 |
| Stratix GX RTL Functional Simulation .....                                     | 2-77 |
| Performing RTL Functional Simulation for Stratix GX in VHDL .....              | 2-78 |
| Performing RTL Functional Simulation for Stratix GX in Verilog HDL .....       | 2-78 |
| Stratix GX Gate-Level Timing Simulation .....                                  | 2-79 |
| Performing Gate-Level Timing Simulation for Stratix GX in VHDL .....           | 2-79 |
| Performing Gate-Level Timing Simulation for Stratix GX in Verilog HDL .....    | 2-80 |
| Stratix II GX RTL Functional Simulation .....                                  | 2-81 |
| Performing RTL Functional Simulation for Stratix II GX in VHDL .....           | 2-82 |
| Performing RTL Functional Simulation for Stratix II GX in Verilog HDL .....    | 2-83 |
| Stratix II GX Gate-Level Timing Simulation .....                               | 2-84 |
| Performing Gate-Level Timing Simulation for Stratix II GX in VHDL .....        | 2-84 |
| Performing Gate-Level Timing Simulation for Stratix II GX in Verilog HDL ..... | 2-85 |
| Transport Delays .....                                                         | 2-85 |
| +transport_path_delays .....                                                   | 2-85 |
| +transport_int_delays .....                                                    | 2-85 |
| Using the NativeLink Feature with ModelSim-Altera or ModelSim Software .....   | 2-86 |
| Setting Up NativeLink .....                                                    | 2-86 |
| Performing an RTL Simulation Using NativeLink .....                            | 2-87 |
| Performing a Gate-Level Simulation Using NativeLink .....                      | 2-89 |
| Setting Up a Testbench .....                                                   | 2-90 |
| Creating a Testbench .....                                                     | 2-92 |
| Generating a Timing VCD File for PowerPlay .....                               | 2-92 |
| Scripting Support .....                                                        | 2-93 |
| Generating a Post-Synthesis Simulation Netlist for ModelSim .....              | 2-93 |
| Tcl Commands .....                                                             | 2-94 |
| Command Prompt .....                                                           | 2-94 |
| Generating a Gate-Level Timing Simulation Netlist for ModelSim .....           | 2-94 |
| Tcl Commands .....                                                             | 2-94 |
| Command Line .....                                                             | 2-94 |
| Software Licensing and Licensing Setup in ModelSim-Altera .....                | 2-95 |
| LM_LICENSE_FILE Variable .....                                                 | 2-95 |
| Conclusion .....                                                               | 2-96 |

|                                 |      |
|---------------------------------|------|
| Referenced Documents .....      | 2-96 |
| Document Revision History ..... | 2-97 |

## Chapter 3. Synopsys VCS Support

|                                                                                             |      |
|---------------------------------------------------------------------------------------------|------|
| Introduction .....                                                                          | 3-1  |
| Software Requirements .....                                                                 | 3-1  |
| Using VCS in the Quartus II Design Flow .....                                               | 3-2  |
| RTL Functional Simulations .....                                                            | 3-4  |
| Megafunctions Requiring Atom Libraries .....                                                | 3-5  |
| RTL Functional Simulation with Altera Memory Blocks .....                                   | 3-5  |
| Post-Synthesis Simulation .....                                                             | 3-5  |
| Generating a Post-Synthesis Simulation Netlist .....                                        | 3-6  |
| Gate-Level Timing Simulation .....                                                          | 3-8  |
| Generating a Gate-Level Timing Simulation Netlist .....                                     | 3-8  |
| Generating a Timing Netlist with Different Timing Models .....                              | 3-9  |
| First slow corner (slow, 1100 mV, 85° C): .....                                             | 3-10 |
| Second slow corner (slow, 1100 mV, 0° C): .....                                             | 3-10 |
| Fast corner (fast, 1100 mV, 0° C): .....                                                    | 3-10 |
| Disable Timing Violation on Registers .....                                                 | 3-11 |
| Perform Timing Simulation Using the Post-Synthesis Netlist .....                            | 3-11 |
| Common VCS Software Compiler Options .....                                                  | 3-12 |
| Using VirSim .....                                                                          | 3-13 |
| Debugging Support Command-Line Interface .....                                              | 3-13 |
| Simulating Designs that Include Transceivers .....                                          | 3-14 |
| Stratix GX RTL Functional Simulation .....                                                  | 3-14 |
| Compiling Library Files for Functional Stratix GX Simulation in Verilog HDL .....           | 3-14 |
| Stratix GX Gate-Level Timing Simulation .....                                               | 3-14 |
| Compiling Library Files for Timing Stratix GX Simulation in Verilog HDL .....               | 3-15 |
| Stratix II GX RTL Functional Simulation .....                                               | 3-15 |
| Compiling Library Files for Stratix II GX RTL Functional Simulation in Verilog HDL .....    | 3-16 |
| Stratix II GX Gate-Level Timing Simulation .....                                            | 3-17 |
| Compiling Library Files for Stratix II GX Gate-Level Timing Simulation in Verilog HDL ..... | 3-17 |
| Transport Delays .....                                                                      | 3-17 |
| +transport_path_delays .....                                                                | 3-17 |
| +transport_int_delays .....                                                                 | 3-18 |
| Using NativeLink with the VCS Software .....                                                | 3-18 |
| Setting Up NativeLink .....                                                                 | 3-18 |
| Performing an RTL Simulation Using NativeLink .....                                         | 3-19 |
| Performing a Gate-Level Timing Simulation Using NativeLink .....                            | 3-20 |
| Setting Up a Testbench .....                                                                | 3-21 |
| Creating a Testbench .....                                                                  | 3-22 |
| Generating a Timing VCD File for PowerPlay .....                                            | 3-23 |
| Scripting Support .....                                                                     | 3-24 |

---

|                                                                 |      |
|-----------------------------------------------------------------|------|
| Generating a Post-Synthesis Simulation Netlist for VCS .....    | 3-24 |
| Tcl Commands .....                                              | 3-24 |
| Command Prompt .....                                            | 3-24 |
| Generating a Gate-Level Timing Simulation Netlist for VCS ..... | 3-25 |
| Tcl Commands .....                                              | 3-25 |
| Command Prompt .....                                            | 3-25 |
| Conclusion .....                                                | 3-25 |
| Referenced Documents .....                                      | 3-26 |
| Document Revision History .....                                 | 3-27 |

## Chapter 4. Cadence NC-Sim Support

|                                                                               |      |
|-------------------------------------------------------------------------------|------|
| Introduction .....                                                            | 4-1  |
| Software Requirements .....                                                   | 4-1  |
| Simulation Flow Overview .....                                                | 4-2  |
| Operation Modes .....                                                         | 4-4  |
| Quartus II Software and NC Simulation Flow Overview .....                     | 4-5  |
| RTL Functional Simulation .....                                               | 4-6  |
| Create Libraries .....                                                        | 4-6  |
| Basic Library Setup .....                                                     | 4-7  |
| Using Multiple cds.lib Files .....                                            | 4-7  |
| Create a cds.lib File in Command-Line Mode .....                              | 4-8  |
| Create a cds.lib File in GUI Mode .....                                       | 4-8  |
| LPM Functions, Altera Megafunctions, and Altera Primitive Library Setup ..... | 4-9  |
| Megafunctions Requiring Atom Libraries .....                                  | 4-11 |
| Compile Source Code and Testbenches .....                                     | 4-12 |
| Compilation in Command-Line Mode .....                                        | 4-12 |
| Compilation in GUI Mode .....                                                 | 4-13 |
| Elaborate Your Design .....                                                   | 4-14 |
| Elaboration in Command-Line Mode .....                                        | 4-14 |
| Elaboration in GUI Mode .....                                                 | 4-15 |
| Add Signals to View .....                                                     | 4-16 |
| Adding Signals in Command-Line Mode .....                                     | 4-16 |
| Adding Signals in GUI Mode .....                                              | 4-17 |
| Simulate the Design .....                                                     | 4-19 |
| RTL Functional Simulation in Command-Line Mode .....                          | 4-20 |
| RTL Functional Simulation in GUI Mode .....                                   | 4-20 |
| Post-Synthesis Simulation .....                                               | 4-20 |
| Quartus II Simulation Output Files .....                                      | 4-20 |
| Create Libraries .....                                                        | 4-22 |
| Compile Project Files and Libraries .....                                     | 4-22 |
| Elaborate Your Design .....                                                   | 4-22 |
| Add Signals to the View .....                                                 | 4-22 |
| Simulate Your Design .....                                                    | 4-22 |
| Gate-Level Timing Simulation .....                                            | 4-23 |
| Generating a Gate-Level Timing Simulation Netlist .....                       | 4-23 |
| Generating a Timing Netlist with Different Timing Models .....                | 4-24 |
| First slow corner (slow, 1100 mV, 85° C) .....                                | 4-25 |

|                                                                                      |      |
|--------------------------------------------------------------------------------------|------|
| Second slow corner (slow, 1100 mV, 0° C) .....                                       | 4-25 |
| Fast corner (fast, 1100 mV, 0° C) .....                                              | 4-25 |
| Disable Timing Violation on Registers .....                                          | 4-26 |
| Perform Timing Simulation Using Post-Synthesis Netlist .....                         | 4-26 |
| Quartus II Timing Simulation Libraries .....                                         | 4-27 |
| Create Libraries .....                                                               | 4-27 |
| Compile the Project Files and Libraries .....                                        | 4-27 |
| Elaborate Your Design .....                                                          | 4-28 |
| Compiling the Standard Delay Output File (VHDL Only) in Command-Line Mode ....       | 4-28 |
| Compiling the Standard Delay Output File (VHDL Only) in GUI Mode .....               | 4-29 |
| Add Signals to View .....                                                            | 4-30 |
| Simulate Your Design .....                                                           | 4-30 |
| Simulating Designs that Include Transceivers .....                                   | 4-30 |
| Stratix GX RTL Functional Simulation .....                                           | 4-30 |
| Compiling Library Files for Functional Stratix GX Simulation in VHDL .....           | 4-31 |
| Compiling Library Files for Functional Stratix GX Simulation in Verilog HDL .....    | 4-31 |
| Stratix GX Gate-Level Timing Simulation .....                                        | 4-31 |
| Compiling Library Files for Timing Stratix GX Simulation in VHDL .....               | 4-32 |
| Compiling Library Files for Timing Stratix GX Simulation in Verilog HDL .....        | 4-32 |
| Stratix II GX RTL Functional Simulation .....                                        | 4-32 |
| Compiling Library Files for Functional Stratix II GX Simulation in VHDL .....        | 4-35 |
| Compiling Library Files for Functional Stratix II GX Simulation in Verilog HDL ..... | 4-35 |
| Stratix II GX Gate-Level Timing Simulation .....                                     | 4-35 |
| Compiling Library Files for Timing Stratix II GX Simulation in VHDL .....            | 4-36 |
| Compiling Library Files for Timing Stratix II GX Simulation in Verilog HDL .....     | 4-36 |
| Pulse Reject Delays .....                                                            | 4-37 |
| -PULSE_R .....                                                                       | 4-37 |
| -PULSE_INT_R .....                                                                   | 4-37 |
| Using the NativeLink Feature with NC-Sim .....                                       | 4-37 |
| Setting Up NativeLink .....                                                          | 4-37 |
| Performing an RTL Simulation Using NativeLink .....                                  | 4-38 |
| Performing a Gate Level Simulation Using NativeLink .....                            | 4-41 |
| Setting Up a Testbench .....                                                         | 4-42 |
| Creating a Testbench .....                                                           | 4-43 |
| Generating a Timing VCD File for PowerPlay .....                                     | 4-44 |
| Scripting Support .....                                                              | 4-44 |
| Generate NC-Sim Simulation Output Files .....                                        | 4-45 |
| Tcl Commands: .....                                                                  | 4-45 |
| Command Prompt .....                                                                 | 4-45 |
| Conclusion .....                                                                     | 4-46 |
| Referenced Documents .....                                                           | 4-46 |
| Document Revision History .....                                                      | 4-47 |

## Chapter 5. Aldec Active-HDL Support

|                                                            |     |
|------------------------------------------------------------|-----|
| Introduction .....                                         | 5-1 |
| Software Compatibility .....                               | 5-1 |
| Using Active-HDL Software in Quartus II Design Flows ..... | 5-2 |

---

|                                                                     |      |
|---------------------------------------------------------------------|------|
| Simulation Libraries .....                                          | 5-4  |
| Simulation Library Files in the Quartus II Software .....           | 5-4  |
| RTL Functional Simulation Library Files .....                       | 5-5  |
| Gate-Level Timing Simulation Library Files .....                    | 5-6  |
| Simulation Netlist Files .....                                      | 5-8  |
| Generate Post-Synthesis Simulation Netlist Files .....              | 5-8  |
| Generate Gate-Level Timing Simulation Netlist Files .....           | 5-10 |
| Generating Different Timing Models .....                            | 5-11 |
| Disable Timing Violation on Registers .....                         | 5-13 |
| Perform Simulation Using the Active-HDL Software (GUI Mode) .....   | 5-13 |
| Simulating the VHDL Designs .....                                   | 5-13 |
| Perform RTL Functional Simulation .....                             | 5-14 |
| Create and Compile Simulation Libraries .....                       | 5-14 |
| Compile Testbench and Design Files into the Work Library .....      | 5-16 |
| Loading the Design .....                                            | 5-16 |
| Running the Simulation .....                                        | 5-17 |
| Perform Post-Synthesis Simulation .....                             | 5-17 |
| Create and Compile Simulation Libraries .....                       | 5-17 |
| Compile the Testbench and Design File into the Work Library .....   | 5-19 |
| Loading the Design .....                                            | 5-20 |
| Running the Simulation .....                                        | 5-20 |
| Perform Gate-Level Timing Simulation .....                          | 5-20 |
| Create and Compile Simulation Libraries .....                       | 5-21 |
| Compile the Testbench and Design File into the Work Library .....   | 5-22 |
| Loading the Design .....                                            | 5-23 |
| Running the Simulation .....                                        | 5-24 |
| Simulating Verilog HDL Designs .....                                | 5-24 |
| Perform RTL Functional Simulation .....                             | 5-24 |
| Create and Compile Simulation Libraries .....                       | 5-24 |
| Compile the Testbench and Design Files into the Work Library .....  | 5-26 |
| Loading the Design .....                                            | 5-27 |
| Running the Simulation .....                                        | 5-28 |
| Perform Post-Synthesis Simulation .....                             | 5-28 |
| Create and Compile Simulation Libraries .....                       | 5-28 |
| Compile the Testbench and Design File into the Work Library .....   | 5-30 |
| Loading the Design .....                                            | 5-31 |
| Running the Simulation .....                                        | 5-32 |
| Perform Gate-Level Timing Simulation .....                          | 5-32 |
| Create and Compile Simulation Libraries .....                       | 5-32 |
| Compile the Testbench and Design File into the Work Library .....   | 5-34 |
| Loading the Design .....                                            | 5-35 |
| Running the Simulation .....                                        | 5-35 |
| Perform Simulation Using the Active-HDL Software (Batch Mode) ..... | 5-35 |
| Simulating the VHDL Designs .....                                   | 5-36 |
| Perform RTL Functional Simulation .....                             | 5-36 |
| Create Simulation Libraries .....                                   | 5-36 |
| Compile Simulation Models into Simulation Libraries .....           | 5-37 |

|                                                                             |      |
|-----------------------------------------------------------------------------|------|
| Compile the Testbench and Design Files into the Work Library .....          | 5-37 |
| Loading the Design .....                                                    | 5-38 |
| Running the Simulation .....                                                | 5-38 |
| Perform Post-Synthesis Simulation .....                                     | 5-39 |
| Create Simulation Libraries .....                                           | 5-39 |
| Compile Simulation Models into Simulation Libraries .....                   | 5-39 |
| Compile the Testbench and VHDL Output File into the Work Library .....      | 5-40 |
| Loading the Design .....                                                    | 5-40 |
| Running the Simulation .....                                                | 5-41 |
| Perform Gate-Level Timing Simulation .....                                  | 5-41 |
| Create Simulation Libraries .....                                           | 5-42 |
| Compile Simulation Models into Simulation Libraries .....                   | 5-42 |
| Compile the Testbench and VHDL Output File into the Work Library .....      | 5-43 |
| Loading the Design .....                                                    | 5-43 |
| Running the Simulation .....                                                | 5-43 |
| Simulating the Verilog HDL Designs .....                                    | 5-44 |
| Perform RTL Functional Simulation .....                                     | 5-44 |
| Create Simulation Libraries .....                                           | 5-44 |
| Compile Simulation Models into Simulation Libraries .....                   | 5-45 |
| Compile the Testbench and Design Files into the Work Library .....          | 5-45 |
| Loading the Design .....                                                    | 5-46 |
| Running the Simulation .....                                                | 5-46 |
| Perform Post-Synthesis Simulation .....                                     | 5-46 |
| Create Simulation Libraries .....                                           | 5-47 |
| Compile Simulation Models into Simulation Libraries .....                   | 5-47 |
| Compile the Testbench and Verilog Output File into the Work Library .....   | 5-48 |
| Loading the Design .....                                                    | 5-48 |
| Running the Simulation .....                                                | 5-48 |
| Perform Gate-Level Timing Simulation .....                                  | 5-49 |
| Create Simulation Libraries .....                                           | 5-49 |
| Compile Simulation Models into Simulation Libraries .....                   | 5-49 |
| Compile the Testbench and Verilog Output File into the Work Library .....   | 5-50 |
| Loading the Design .....                                                    | 5-50 |
| Running the Simulation .....                                                | 5-51 |
| Simulating Designs that Include Transceivers .....                          | 5-51 |
| Stratix GX RTL Functional Simulation .....                                  | 5-51 |
| Performing RTL Functional Simulation for Stratix GX in VHDL .....           | 5-52 |
| Performing Functional Simulation for Stratix GX in Verilog HDL .....        | 5-52 |
| Stratix GX Gate-Level Timing Simulation .....                               | 5-53 |
| Performing Timing Simulation for Stratix GX in VHDL .....                   | 5-54 |
| Performing Gate-Level Timing Simulation for Stratix GX in Verilog HDL ..... | 5-55 |
| Stratix II GX RTL Functional Simulation .....                               | 5-55 |
| Performing RTL Functional Simulation for Stratix II GX in VHDL .....        | 5-57 |
| Performing RTL Functional Simulation for Stratix II GX in Verilog HDL ..... | 5-58 |
| Stratix II GX Gate-Level Timing Simulation .....                            | 5-59 |
| Performing Timing Simulation for Stratix II GX in VHDL .....                | 5-59 |
| Performing Timing Simulation for Stratix II GX in Verilog HDL .....         | 5-60 |

---

|                                                                        |      |
|------------------------------------------------------------------------|------|
| Transport Delays .....                                                 | 5-61 |
| Using the NativeLink Feature in Active-HDL Software .....              | 5-62 |
| Setting Up NativeLink .....                                            | 5-62 |
| Performing an RTL Simulation Using NativeLink .....                    | 5-62 |
| Performing a Gate-Level Timing Simulation Using NativeLink .....       | 5-65 |
| Setting Up a Testbench .....                                           | 5-66 |
| Creating a Testbench .....                                             | 5-67 |
| Generating VCD Files for PowerPlay .....                               | 5-68 |
| Scripting Support .....                                                | 5-69 |
| Generating a Post-Synthesis Simulation Netlist for Active-HDL .....    | 5-69 |
| Tcl Commands .....                                                     | 5-69 |
| Command Prompt .....                                                   | 5-69 |
| Generating a Gate-Level Timing Simulation Netlist for Active-HDL ..... | 5-70 |
| Tcl Commands .....                                                     | 5-70 |
| Command Line .....                                                     | 5-70 |
| Conclusion .....                                                       | 5-70 |
| Referenced Documents .....                                             | 5-71 |
| Document Revision History .....                                        | 5-71 |

## Chapter 6. Simulating Altera IP in Third-Party Simulation Tools

|                                                                               |      |
|-------------------------------------------------------------------------------|------|
| Introduction .....                                                            | 6-1  |
| IP Functional Simulation Flow .....                                           | 6-2  |
| Verilog HDL and VHDL IP Functional Simulation (IPFS) Models .....             | 6-3  |
| Instantiate the IP in Your Design .....                                       | 6-4  |
| Perform Simulation .....                                                      | 6-4  |
| Simulating Altera IP Using the Quartus II NativeLink Feature .....            | 6-5  |
| Set up a Quartus II Project .....                                             | 6-6  |
| Select the Third-Party Simulation Tool .....                                  | 6-6  |
| Specify the Path for the Third-Party Simulator .....                          | 6-8  |
| Specify the Testbench Settings .....                                          | 6-8  |
| Analyze and Elaborate the Quartus II Project .....                            | 6-10 |
| Run RTL Functional Simulation .....                                           | 6-10 |
| Simulating Altera IP Without the Quartus II NativeLink Feature .....          | 6-10 |
| Design Language Examples .....                                                | 6-13 |
| Verilog HDL Example: Simulating the IPFS Model in the ModelSim Software ..... | 6-13 |
| VHDL Example: Simulating the IPFS Model in the ModelSim Software .....        | 6-15 |
| NC-VHDL Example: Simulating the IPFS Model in the NC-VHDL Software .....      | 6-17 |
| Verilog HDL Example: Simulating Your IPFS Model in VCS .....                  | 6-18 |
| Single-Step Process .....                                                     | 6-18 |
| Two-Step Process (Compilation and Simulation) .....                           | 6-18 |
| Conclusion .....                                                              | 6-18 |
| Referenced Documents .....                                                    | 6-19 |
| Document Revision History .....                                               | 6-19 |

## Section II. Timing Analysis

### Chapter 7. The Quartus II TimeQuest Timing Analyzer

|                                                                                 |      |
|---------------------------------------------------------------------------------|------|
| Introduction .....                                                              | 7-1  |
| Getting Started with the Quartus II TimeQuest Timing Analyzer .....             | 7-2  |
| Setting Up the Quartus II TimeQuest Timing Analyzer .....                       | 7-2  |
| Compilation Flow with the Quartus II TimeQuest Timing Analyzer Guidelines ..... | 7-3  |
| Running the Quartus II TimeQuest Timing Analyzer .....                          | 7-4  |
| Directly from the Quartus II Software .....                                     | 7-4  |
| Stand-Alone Mode .....                                                          | 7-5  |
| Command-Line Mode .....                                                         | 7-5  |
| Timing Analysis Overview .....                                                  | 7-6  |
| Clock Analysis .....                                                            | 7-11 |
| Clock Setup Check .....                                                         | 7-11 |
| Clock Hold Check .....                                                          | 7-13 |
| Recovery and Removal .....                                                      | 7-15 |
| Multicycle Paths .....                                                          | 7-16 |
| Metastability .....                                                             | 7-19 |
| Common Clock Path Pessimism .....                                               | 7-22 |
| Clock-As-Data .....                                                             | 7-24 |
| The Quartus II TimeQuest Timing Analyzer Flow Guidelines .....                  | 7-26 |
| Create a Timing Netlist .....                                                   | 7-26 |
| Read the Synopsys Design Constraints File .....                                 | 7-26 |
| Update Timing Netlist .....                                                     | 7-27 |
| Generate Timing Reports .....                                                   | 7-27 |
| Collections .....                                                               | 7-28 |
| Application Examples .....                                                      | 7-29 |
| SDC Constraint Files .....                                                      | 7-29 |
| Fitter and Timing Analysis with SDC Files .....                                 | 7-30 |
| Specifying SDC Files for Place-and-Route .....                                  | 7-30 |
| Specifying SDC Files for Static Timing Analysis .....                           | 7-30 |
| Synopsys Design Constraints File Precedence .....                               | 7-31 |
| Clock Specification .....                                                       | 7-32 |
| Clocks .....                                                                    | 7-32 |
| Generated Clocks .....                                                          | 7-34 |
| Virtual Clocks .....                                                            | 7-37 |
| Multi-Frequency Clocks .....                                                    | 7-38 |
| Automatic Clock Detection .....                                                 | 7-39 |
| Derive PLL Clocks .....                                                         | 7-40 |
| Default Clock Constraints .....                                                 | 7-42 |
| Clock Groups .....                                                              | 7-43 |
| Clock Effect Characteristics .....                                              | 7-45 |
| Clock Latency .....                                                             | 7-45 |
| Clock Uncertainty .....                                                         | 7-46 |
| Derive Clock Uncertainty .....                                                  | 7-47 |
| Intra-Clock Transfers .....                                                     | 7-48 |
| Inter-Clock Transfers .....                                                     | 7-49 |

---

|                                                             |       |
|-------------------------------------------------------------|-------|
| I/O Interface Clock Transfers .....                         | 7-49  |
| I/O Specifications .....                                    | 7-51  |
| Input and Output Delay .....                                | 7-51  |
| Set Input Delay .....                                       | 7-51  |
| Set Output Delay .....                                      | 7-53  |
| Timing Exceptions .....                                     | 7-54  |
| Precedence .....                                            | 7-55  |
| False Path .....                                            | 7-55  |
| Minimum Delay .....                                         | 7-56  |
| Maximum Delay .....                                         | 7-58  |
| Multicycle Path .....                                       | 7-59  |
| Application Examples .....                                  | 7-61  |
| Constraint and Exception Removal .....                      | 7-63  |
| Timing Reports .....                                        | 7-64  |
| report_timing .....                                         | 7-64  |
| report_metastability .....                                  | 7-68  |
| Settings .....                                              | 7-69  |
| Metastability Analysis .....                                | 7-69  |
| Synchronization Register Chain Length .....                 | 7-70  |
| report_clock_transfers .....                                | 7-71  |
| report_clocks .....                                         | 7-72  |
| report_min_pulse_width .....                                | 7-72  |
| report_net_timing .....                                     | 7-74  |
| report_sdc .....                                            | 7-75  |
| report_ucp .....                                            | 7-75  |
| report_path .....                                           | 7-77  |
| report_bottleneck .....                                     | 7-78  |
| report_datasheet .....                                      | 7-79  |
| report_rskm .....                                           | 7-80  |
| report_tccs .....                                           | 7-81  |
| report_path .....                                           | 7-82  |
| check_timing .....                                          | 7-84  |
| report_clock_fmax_summary .....                             | 7-86  |
| create_timing_summary .....                                 | 7-88  |
| Timing Analysis Features .....                              | 7-89  |
| Multi-Corner Analysis .....                                 | 7-89  |
| Advanced I/O Timing and Board Trace Model Assignments ..... | 7-91  |
| Wildcard Assignments and Collections .....                  | 7-91  |
| Resetting a Design .....                                    | 7-93  |
| Cross-Probing .....                                         | 7-93  |
| locate .....                                                | 7-94  |
| The TimeQuest Timing Analyzer GUI .....                     | 7-96  |
| The Quartus II Software Interface and Options .....         | 7-97  |
| View Pane .....                                             | 7-97  |
| View Pane: Splitting .....                                  | 7-98  |
| View Pane: Removing Split Windows .....                     | 7-99  |
| Tasks Pane .....                                            | 7-100 |

|                                                                        |       |
|------------------------------------------------------------------------|-------|
| Opening a Project and Writing a Synopsys Design Constraints File ..... | 7-100 |
| Netlist Setup Folder .....                                             | 7-101 |
| Reports Folder .....                                                   | 7-101 |
| Macros Folder .....                                                    | 7-102 |
| Console Pane .....                                                     | 7-103 |
| Report Pane .....                                                      | 7-103 |
| Constraints .....                                                      | 7-103 |
| Name Finder .....                                                      | 7-105 |
| Target Pane .....                                                      | 7-107 |
| SDC Editor .....                                                       | 7-107 |
| Conclusion .....                                                       | 7-108 |
| Referenced Documents .....                                             | 7-108 |
| Document Revision History .....                                        | 7-109 |

## Chapter 8. Switching to the Quartus II TimeQuest Timing Analyzer

|                                                                                        |      |
|----------------------------------------------------------------------------------------|------|
| Introduction .....                                                                     | 8-1  |
| Benefits of Switching to the Quartus II TimeQuest Analyzer .....                       | 8-1  |
| Chapter Contents .....                                                                 | 8-2  |
| Switching to the Quartus II TimeQuest Analyzer .....                                   | 8-2  |
| Compile Your Design .....                                                              | 8-2  |
| Create an SDC File .....                                                               | 8-3  |
| Conversion Utility .....                                                               | 8-3  |
| Perform Timing Analysis with the Quartus II TimeQuest Timing Analyzer .....            | 8-4  |
| Run the Quartus II TimeQuest Analyzer .....                                            | 8-4  |
| Set the Default Timing Analyzer .....                                                  | 8-4  |
| Differences Between Quartus II TimeQuest and Quartus II Classic Timing Analyzers ..... | 8-5  |
| Terminology .....                                                                      | 8-5  |
| Netlist .....                                                                          | 8-6  |
| Collections .....                                                                      | 8-7  |
| Constraints .....                                                                      | 8-7  |
| Constraint Files .....                                                                 | 8-7  |
| Constraint Entry .....                                                                 | 8-8  |
| Time Units .....                                                                       | 8-9  |
| MegaCore Functions .....                                                               | 8-9  |
| Bus Name Format .....                                                                  | 8-10 |
| Constraint File Priority .....                                                         | 8-10 |
| Constraint Priority .....                                                              | 8-11 |
| Ambiguous Constraints .....                                                            | 8-12 |
| Clocks .....                                                                           | 8-13 |
| Related and Unrelated Clocks .....                                                     | 8-13 |
| Clock Offset .....                                                                     | 8-14 |
| Clock Latency .....                                                                    | 8-15 |
| Offset and Latency Example .....                                                       | 8-15 |
| Clock Offset Scenario .....                                                            | 8-16 |
| Clock Latency Scenario .....                                                           | 8-17 |
| Clock Uncertainty .....                                                                | 8-18 |
| Derived and Generated Clocks .....                                                     | 8-19 |

|                                             |      |
|---------------------------------------------|------|
| Automatic Clock Detection .....             | 8-19 |
| derive_clocks Command .....                 | 8-20 |
| derive_pll_clocks Command .....             | 8-22 |
| Hold Relationship .....                     | 8-23 |
| Clock Objects .....                         | 8-23 |
| Hold Multicycle .....                       | 8-24 |
| Fitter Behavior .....                       | 8-27 |
| Fitter Performance .....                    | 8-27 |
| Reporting .....                             | 8-27 |
| Paths and Pairs .....                       | 8-28 |
| Default Reports .....                       | 8-28 |
| Netlist Names .....                         | 8-29 |
| Non-Integer Clock Periods .....             | 8-29 |
| Other Features .....                        | 8-30 |
| Scripting API .....                         | 8-32 |
| Timing Assignment Conversion .....          | 8-33 |
| Setup Relationship .....                    | 8-33 |
| Hold Relationship .....                     | 8-34 |
| Clock Latency .....                         | 8-34 |
| Clock Uncertainty .....                     | 8-34 |
| Inverted Clock .....                        | 8-35 |
| Not a Clock .....                           | 8-35 |
| Default Required $f_{MAX}$ Assignment ..... | 8-35 |
| Virtual Clock Reference .....               | 8-36 |
| Clock Settings .....                        | 8-37 |
| Multicycle .....                            | 8-37 |
| Clock Enable Multicycle .....               | 8-38 |
| I/O Constraints .....                       | 8-38 |
| Input and Output Delay .....                | 8-39 |
| $t_{SU}$ Requirement .....                  | 8-40 |
| $t_H$ Requirement .....                     | 8-43 |
| $t_{CO}$ Requirement .....                  | 8-45 |
| Minimum $t_{CO}$ Requirement .....          | 8-48 |
| $t_{PD}$ Requirement .....                  | 8-50 |
| Combinational Path Delay Scenario .....     | 8-50 |
| Minimum $t_{PD}$ Requirement .....          | 8-51 |
| Cut Timing Path .....                       | 8-52 |
| Maximum Delay .....                         | 8-52 |
| Minimum Delay .....                         | 8-52 |
| Maximum Clock Arrival Skew .....            | 8-53 |
| Maximum Data Arrival Skew .....             | 8-53 |
| Constraining Skew on an Output Bus .....    | 8-53 |
| Conversion Utility .....                    | 8-55 |
| Unsupported Global Assignments .....        | 8-56 |
| Recommended Global Assignments .....        | 8-56 |
| Clock Conversion .....                      | 8-58 |
| Instance Assignment Conversion .....        | 8-59 |

|                                                                                                                                                                 |      |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| PLL Phase Shift Conversion .....                                                                                                                                | 8-61 |
| $t_{CO}$ Requirement Conversion .....                                                                                                                           | 8-62 |
| Entity-Specific Assignments .....                                                                                                                               | 8-63 |
| Paths between Unrelated Clock Domains .....                                                                                                                     | 8-63 |
| Unsupported Instance Assignments .....                                                                                                                          | 8-64 |
| Reviewing Conversion Results .....                                                                                                                              | 8-64 |
| Warning Messages .....                                                                                                                                          | 8-64 |
| Ignored QSF Variable <i>&lt;assignment&gt;</i> .....                                                                                                            | 8-65 |
| Global <i>&lt;name&gt;</i> = <i>&lt;value&gt;</i> .....                                                                                                         | 8-65 |
| QSF: Expected <i>&lt;name&gt;</i> to be set to <i>&lt;expected value&gt;</i> but it is set to <i>&lt;actual value&gt;</i> .....                                 | 8-65 |
| QSF: Found Global Fmax Requirement. Translation will be done using derive_clocks .....                                                                          | 8-65 |
| TAN Report Database not found. HDL based assignments will not be migrated ....                                                                                  | 8-65 |
| Ignored Entity Assignment (Entity <i>&lt;entity&gt;</i> ): <i>&lt;variable&gt;</i> = <i>&lt;value&gt;</i> -from <i>&lt;from&gt;</i> -to <i>&lt;to&gt;</i> ..... | 8-65 |
| Ignoring OFFSET_FROM_BASE_CLOCK assignment for clock <i>&lt;clock&gt;</i> .....                                                                                 | 8-66 |
| Clock <i>&lt;clock&gt;</i> has no FMAX_REQUIREMENT - No clock was generated .....                                                                               | 8-66 |
| No Clock Settings defined in QSF file .....                                                                                                                     | 8-66 |
| Clocks .....                                                                                                                                                    | 8-66 |
| Clock Transfers .....                                                                                                                                           | 8-66 |
| Path Details .....                                                                                                                                              | 8-67 |
| Unconstrained Paths .....                                                                                                                                       | 8-67 |
| Bus Names .....                                                                                                                                                 | 8-68 |
| Other .....                                                                                                                                                     | 8-68 |
| Re-Running the Conversion Utility .....                                                                                                                         | 8-68 |
| Notes .....                                                                                                                                                     | 8-68 |
| Output Pin Load Assignments .....                                                                                                                               | 8-68 |
| Constraint Target Types .....                                                                                                                                   | 8-69 |
| DDR Constraints with the DDR Timing Wizard .....                                                                                                                | 8-69 |
| HardCopy Stratix Device Handoff .....                                                                                                                           | 8-69 |
| Unsupported SDC Features .....                                                                                                                                  | 8-69 |
| Constraint Passing .....                                                                                                                                        | 8-70 |
| Optimization .....                                                                                                                                              | 8-70 |
| Clock Network Delay Reporting .....                                                                                                                             | 8-70 |
| PowerPlay Power Analysis .....                                                                                                                                  | 8-70 |
| Project Management .....                                                                                                                                        | 8-71 |
| Conversion Utility .....                                                                                                                                        | 8-71 |
| $t_{PD}$ and Minimum $t_{PD}$ Requirement Conversion .....                                                                                                      | 8-71 |
| Referenced Documents .....                                                                                                                                      | 8-72 |
| Document Revision History .....                                                                                                                                 | 8-72 |

## Chapter 9. Quartus II Classic Timing Analyzer

|                                       |     |
|---------------------------------------|-----|
| Introduction .....                    | 9-1 |
| Timing Analysis Tool Setup .....      | 9-2 |
| Static Timing Analysis Overview ..... | 9-2 |
| Clock Analysis .....                  | 9-4 |

---

|                                                                          |      |
|--------------------------------------------------------------------------|------|
| Clock Setup Check .....                                                  | 9-4  |
| Clock Hold Check .....                                                   | 9-6  |
| Multicycle Paths .....                                                   | 9-7  |
| Clock Settings .....                                                     | 9-8  |
| Individual Clock Settings .....                                          | 9-8  |
| Default Clock Settings .....                                             | 9-8  |
| Clock Types .....                                                        | 9-9  |
| Base Clocks .....                                                        | 9-9  |
| Derived Clocks .....                                                     | 9-9  |
| Undefined Clocks .....                                                   | 9-10 |
| PLL Clocks .....                                                         | 9-10 |
| Clock Uncertainty .....                                                  | 9-11 |
| Clock Latency .....                                                      | 9-12 |
| Timing Exceptions .....                                                  | 9-15 |
| Multicycle .....                                                         | 9-15 |
| Destination Multicycle Setup Exception .....                             | 9-15 |
| Destination Multicycle Hold Exception .....                              | 9-16 |
| Source Multicycle Setup Exception .....                                  | 9-17 |
| Source Multicycle Hold Exception .....                                   | 9-18 |
| Default Hold Multicycle .....                                            | 9-19 |
| Clock Enable Multicycle .....                                            | 9-19 |
| Setup Relationship and Hold Relationship .....                           | 9-22 |
| Maximum Delay and Minimum Delay .....                                    | 9-24 |
| False Paths .....                                                        | 9-24 |
| I/O Analysis .....                                                       | 9-26 |
| External Input Delay and Output Delay Assignments .....                  | 9-26 |
| Input Delay Assignment .....                                             | 9-26 |
| Output Delay Assignment .....                                            | 9-28 |
| Virtual Clocks .....                                                     | 9-29 |
| Asynchronous Paths .....                                                 | 9-30 |
| Recovery and Removal .....                                               | 9-30 |
| Recovery Report .....                                                    | 9-31 |
| Removal Report .....                                                     | 9-32 |
| Skew Management .....                                                    | 9-34 |
| Maximum Clock Arrival Skew .....                                         | 9-34 |
| Maximum Data Arrival Skew .....                                          | 9-35 |
| Generating Timing Analysis Reports with <code>report_timing</code> ..... | 9-36 |
| Other Timing Analyzer Features .....                                     | 9-38 |
| Wildcard Assignments .....                                               | 9-38 |
| Assignment Groups .....                                                  | 9-38 |
| Fast Corner Analysis .....                                               | 9-40 |
| Early Timing Estimation .....                                            | 9-40 |
| Timing Constraint Checker .....                                          | 9-41 |
| Latch Analysis .....                                                     | 9-42 |
| Timing Analysis Using the Quartus II GUI .....                           | 9-43 |
| Assignment Editor .....                                                  | 9-43 |
| Timing Settings .....                                                    | 9-44 |

---

|                                               |      |
|-----------------------------------------------|------|
| Clock Settings Dialog Box .....               | 9-45 |
| More Timing Settings Dialog Box .....         | 9-46 |
| Timing Reports .....                          | 9-47 |
| Advanced List Path .....                      | 9-49 |
| Early Timing Estimate .....                   | 9-51 |
| Assignment Groups .....                       | 9-51 |
| Scripting Support .....                       | 9-52 |
| Creating Clocks .....                         | 9-53 |
| Base Clocks .....                             | 9-53 |
| Derived Clocks .....                          | 9-53 |
| Clock Latency .....                           | 9-53 |
| Clock Uncertainty .....                       | 9-54 |
| Cut Timing Paths .....                        | 9-54 |
| Input Delay Assignment .....                  | 9-54 |
| Maximum and Minimum Delay .....               | 9-55 |
| Maximum Clock Arrival Skew .....              | 9-55 |
| Maximum Data Arrival Skew .....               | 9-55 |
| Multicycle .....                              | 9-56 |
| Output Delay Assignment .....                 | 9-56 |
| Report Timing .....                           | 9-57 |
| Setup and Hold Relationships .....            | 9-57 |
| Assignment Group .....                        | 9-57 |
| Virtual Clock .....                           | 9-58 |
| MAX+PLUS II Timing Analysis Methodology ..... | 9-58 |
| $f_{MAX}$ Relationships .....                 | 9-58 |
| Slack .....                                   | 9-58 |
| I/O Timing .....                              | 9-60 |
| $t_{SU}$ Timing .....                         | 9-60 |
| $t_H$ Timing .....                            | 9-60 |
| $t_{CO}$ Timing .....                         | 9-61 |
| Minimum $t_{CO}$ (min $t_{CO}$ ) .....        | 9-62 |
| $t_{PD}$ Timing .....                         | 9-62 |
| Minimum $t_{PD}$ (min $t_{PD}$ ) .....        | 9-62 |
| The Timing Analyzer Tool .....                | 9-62 |
| Conclusion .....                              | 9-63 |
| Referenced Documents .....                    | 9-63 |
| Document Revision History .....               | 9-64 |

## Chapter 10. Synopsys PrimeTime Support

|                                                                       |      |
|-----------------------------------------------------------------------|------|
| Introduction .....                                                    | 10-1 |
| Quartus II Settings for Generating the PrimeTime Software Files ..... | 10-2 |
| Files Generated for the PrimeTime Software Environment .....          | 10-3 |
| The Netlist .....                                                     | 10-3 |
| The SDO File .....                                                    | 10-4 |
| Generating Multiple Operating Conditions with TimeQuest .....         | 10-4 |
| The Tcl Script .....                                                  | 10-7 |
| Generated File Summary .....                                          | 10-9 |

---

|                                                                                                       |       |
|-------------------------------------------------------------------------------------------------------|-------|
| Running the PrimeTime Software .....                                                                  | 10-10 |
| Analyzing Quartus II Projects .....                                                                   | 10-10 |
| Other pt_shell Commands .....                                                                         | 10-11 |
| PrimeTime Timing Reports .....                                                                        | 10-12 |
| Sample of the PrimeTime Software Timing Report .....                                                  | 10-12 |
| Comparing Timing Reports from the Quartus II Classic Timing Analyzer and the PrimeTime Software ..... | 10-13 |
| Clock Setup Relationship and Slack .....                                                              | 10-13 |
| Clock Hold Relationship and Slack .....                                                               | 10-17 |
| Input Delay and Output Delay Relationships and Slack .....                                            | 10-21 |
| Static Timing Analyzer Differences .....                                                              | 10-23 |
| The Quartus II Classic Timing Analyzer and the PrimeTime Software .....                               | 10-23 |
| Rise/Fall Support .....                                                                               | 10-23 |
| Minimum and Maximum Delays .....                                                                      | 10-23 |
| Recovery/Removal Analysis .....                                                                       | 10-23 |
| Encrypted Intellectual Property Blocks .....                                                          | 10-24 |
| Registered Clock Signals .....                                                                        | 10-24 |
| Multiple Source and Destination Register Pairs .....                                                  | 10-25 |
| Latches .....                                                                                         | 10-25 |
| LVDS I/O .....                                                                                        | 10-25 |
| Clock Latency .....                                                                                   | 10-26 |
| Input and Output Delay Assignments .....                                                              | 10-26 |
| Generated Clocks Derived from Generated Clocks .....                                                  | 10-26 |
| The Quartus II TimeQuest Timing Analyzer and the PrimeTime Software .....                             | 10-26 |
| Encrypted Intellectual Property Blocks .....                                                          | 10-26 |
| Latches .....                                                                                         | 10-27 |
| LVDS I/O .....                                                                                        | 10-27 |
| The Quartus II TimeQuest Timing Analyzer SDC File and PrimeTime Compatibility .....                   | 10-27 |
| Clock and Data Paths .....                                                                            | 10-27 |
| Inverting and Non-Inverting Propagation .....                                                         | 10-28 |
| Multiple Rise/Fall Numbers For a Timing Arc .....                                                     | 10-28 |
| Virtual Generated Clocks .....                                                                        | 10-28 |
| Generated Clocks Derived from Generated Clocks .....                                                  | 10-28 |
| Conclusion .....                                                                                      | 10-28 |
| Referenced Documents .....                                                                            | 10-29 |
| Document Revision History .....                                                                       | 10-30 |

## Section III. Power Estimation and Analysis

### Chapter 11. PowerPlay Power Analysis

|                                                                         |      |
|-------------------------------------------------------------------------|------|
| Introduction .....                                                      | 11-1 |
| Quartus II Early Power Estimator File .....                             | 11-2 |
| PowerPlay Early Power Estimator File Generator Compilation Report ..... | 11-5 |
| Types of Power Analyses .....                                           | 11-6 |
| Factors Affecting Power Consumption .....                               | 11-7 |

|                                                                                                 |       |
|-------------------------------------------------------------------------------------------------|-------|
| Device Selection .....                                                                          | 11-7  |
| Environmental Conditions .....                                                                  | 11-7  |
| Air Flow .....                                                                                  | 11-8  |
| Heat Sink and Thermal Compound .....                                                            | 11-8  |
| Ambient Temperature .....                                                                       | 11-8  |
| Board Thermal Model .....                                                                       | 11-8  |
| Design Resources .....                                                                          | 11-8  |
| Number, Type, and Loading of I/O Pins .....                                                     | 11-9  |
| Number and Type of Logic Elements, Multiplier Elements, and RAM Blocks .....                    | 11-9  |
| Number and Type of Global Signals .....                                                         | 11-9  |
| Signal Activities .....                                                                         | 11-9  |
| PowerPlay Power Analyzer Flow .....                                                             | 11-10 |
| Operating Conditions .....                                                                      | 11-11 |
| Signal Activities Data Sources .....                                                            | 11-12 |
| Simulation Results .....                                                                        | 11-13 |
| Using Simulation Files in Modular Design Flows .....                                            | 11-14 |
| Complete Design Simulation .....                                                                | 11-15 |
| Modular Design Simulation .....                                                                 | 11-16 |
| Multiple Simulations on the Same Entity .....                                                   | 11-16 |
| Overlapping Simulations .....                                                                   | 11-17 |
| Partial Simulations .....                                                                       | 11-17 |
| Node Name Matching Considerations .....                                                         | 11-18 |
| Glitch Filtering .....                                                                          | 11-18 |
| Node and Entity Assignments .....                                                               | 11-20 |
| Timing Assignments to Clock Nodes .....                                                         | 11-21 |
| Default Toggle Rate Assignment .....                                                            | 11-22 |
| Vectorless Estimation .....                                                                     | 11-22 |
| Using the PowerPlay Power Analyzer .....                                                        | 11-22 |
| Common Analysis Flows .....                                                                     | 11-23 |
| Signal Activities from Full Post-Fit Netlist (Timing) Simulation .....                          | 11-23 |
| Signal Activities from RTL (Functional) Simulation, Supplemented by Vectorless Estimation ..... | 11-23 |
| Signal Activities from Vectorless Estimation, User-Supplied Input Pin Activities .....          | 11-23 |
| Signal Activities from User Defaults Only .....                                                 | 11-23 |
| Generating a SAF or VCD File Using the Quartus II Simulator .....                               | 11-23 |
| Generating a VCD File Using a Third-Party Simulator .....                                       | 11-27 |
| Generating a VCD File from ModelSim Software .....                                              | 11-30 |
| Running the PowerPlay Power Analyzer Using the Quartus II GUI .....                             | 11-30 |
| PowerPlay Power Analyzer Compilation Report .....                                               | 11-39 |
| Summary .....                                                                                   | 11-39 |
| Settings .....                                                                                  | 11-39 |
| Simulation Files Read .....                                                                     | 11-39 |
| Operating Conditions Used .....                                                                 | 11-39 |
| Thermal Power Dissipated by Block .....                                                         | 11-39 |
| Thermal Power Dissipation by Block Type (Device Resource Type) .....                            | 11-40 |
| Thermal Power Dissipation by Hierarchy .....                                                    | 11-40 |
| Core Dynamic Thermal Power Dissipation by Clock Domain .....                                    | 11-40 |

|                                                                  |       |
|------------------------------------------------------------------|-------|
| Current Drawn from Voltage Supplies .....                        | 11-40 |
| Confidence Metric Details .....                                  | 11-40 |
| Signal Activities .....                                          | 11-41 |
| Messages .....                                                   | 11-41 |
| Specific Rules for Reporting .....                               | 11-41 |
| Scripting Support .....                                          | 11-42 |
| Running the PowerPlay Power Analyzer from the Command Line ..... | 11-42 |
| Conclusion .....                                                 | 11-43 |
| Referenced Documents .....                                       | 11-44 |
| Document Revision History .....                                  | 11-45 |

## Section IV. Signal Integrity

### Chapter 12. Signal Integrity Analysis with Third-Party Tools

|                                                                      |       |
|----------------------------------------------------------------------|-------|
| Introduction .....                                                   | 12-1  |
| I/O Model Selection: IBIS or HSPICE .....                            | 12-4  |
| FPGA to Board Signal Integrity Analysis Flow .....                   | 12-5  |
| Create I/O and Board Trace Model Assignments .....                   | 12-7  |
| Output File Generation .....                                         | 12-7  |
| Customize the Output Files .....                                     | 12-8  |
| Set Up and Run Simulations in Third-Party Tools .....                | 12-8  |
| Interpret Simulation Results .....                                   | 12-9  |
| Simulation with IBIS Models .....                                    | 12-9  |
| Elements of an IBIS Model .....                                      | 12-9  |
| Creating Accurate IBIS Models .....                                  | 12-10 |
| Download IBIS Models .....                                           | 12-10 |
| Generate Custom IBIS Models with the IBIS Writer .....               | 12-11 |
| Design Simulation Using the Mentor Graphics HyperLynx Software ..... | 12-14 |
| Configuring LineSim to Use Altera IBIS Models .....                  | 12-16 |
| Integrating Altera IBIS Models into LineSim Simulations .....        | 12-18 |
| Running and Interpreting LineSim Simulations .....                   | 12-21 |
| Simulation with HSPICE Models .....                                  | 12-22 |
| Supported Devices and Signaling .....                                | 12-23 |
| Accessing HSPICE Simulation Kits .....                               | 12-23 |
| The Double Counting Problem in HSPICE Simulations .....              | 12-24 |
| Defining the Double Counting Problem .....                           | 12-24 |
| The Solution to Double Counting .....                                | 12-25 |
| HSPICE Writer Tool Flow .....                                        | 12-27 |
| Applying I/O Assignments .....                                       | 12-27 |
| Enabling HSPICE Writer .....                                         | 12-27 |
| Enabling HSPICE Writer Using Assignments .....                       | 12-29 |
| Naming Conventions for HSPICE Files .....                            | 12-29 |
| Invoking HSPICE Writer .....                                         | 12-29 |
| Invoking HSPICE Writer from the Command Line .....                   | 12-30 |
| Customizing Automatically Generated HSPICE Decks .....               | 12-31 |

|                                                             |       |
|-------------------------------------------------------------|-------|
| Running an HSPICE Simulation .....                          | 12-32 |
| Interpreting the Results of an Output Simulation .....      | 12-32 |
| Interpreting the Results of an Input Simulation .....       | 12-33 |
| Viewing and Interpreting Tabular Simulation Results .....   | 12-33 |
| Viewing Graphical Simulation Results .....                  | 12-33 |
| Making Design Adjustments Based on HSPICE Simulations ..... | 12-35 |
| Sample Input for I/O HSPICE Simulation Deck .....           | 12-37 |
| Header Comment .....                                        | 12-37 |
| Simulation Conditions .....                                 | 12-39 |
| Simulation Options .....                                    | 12-39 |
| Constant Definition .....                                   | 12-40 |
| Buffer Netlist .....                                        | 12-41 |
| Drive Strength .....                                        | 12-41 |
| I/O Buffer Instantiation .....                              | 12-41 |
| Board Trace and Termination .....                           | 12-43 |
| Stimulus Model .....                                        | 12-43 |
| Simulation Analysis .....                                   | 12-43 |
| Sample Output for I/O HSPICE Simulation Deck .....          | 12-44 |
| Header Comment .....                                        | 12-44 |
| Simulation Conditions .....                                 | 12-46 |
| Simulation Options .....                                    | 12-46 |
| Constraint Definition .....                                 | 12-47 |
| I/O Buffer Netlist .....                                    | 12-48 |
| Drive Strength .....                                        | 12-48 |
| I/O Buffer Instantiation .....                              | 12-49 |
| Board and Trace Termination .....                           | 12-50 |
| Double-Counting Compensation Circuitry .....                | 12-50 |
| Simulation Analysis .....                                   | 12-52 |
| Advanced Topics .....                                       | 12-52 |
| PVT Simulations .....                                       | 12-52 |
| Hold Time Analysis .....                                    | 12-53 |
| I/O Voltage Variations .....                                | 12-54 |
| Correlation Report .....                                    | 12-54 |
| Conclusion .....                                            | 12-54 |
| Referenced Documents .....                                  | 12-54 |
| Document Revision History .....                             | 12-55 |

## **Section V. In-System Design Debugging**

### **Chapter 13. Quick Design Debugging Using SignalProbe**

|                                               |      |
|-----------------------------------------------|------|
| Introduction .....                            | 13-1 |
| Debugging Using the SignalProbe Feature ..... | 13-1 |
| Reserve the SignalProbe Pins .....            | 13-2 |
| Perform a Full Compilation .....              | 13-4 |
| Assign a SignalProbe Source .....             | 13-4 |

---

|                                                                                                                                                |       |
|------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Add Registers to the Pipeline Path to SignalProbe Pin .....                                                                                    | 13-5  |
| Perform a SignalProbe Compilation .....                                                                                                        | 13-7  |
| Analyze the Results of the SignalProbe Compilation .....                                                                                       | 13-8  |
| Generate the Programming File .....                                                                                                            | 13-9  |
| SignalProbe ECO flows .....                                                                                                                    | 13-9  |
| SignalProbe ECO Flow with Quartus II Incremental Compilation .....                                                                             | 13-9  |
| SignalProbe ECO Flow without Quartus Incremental Compilation .....                                                                             | 13-10 |
| Common Questions About the SignalProbe Feature .....                                                                                           | 13-12 |
| Why Did I Get the Following Error Message, "Error: There are No Enabled SignalProbes to Process"? .....                                        | 13-12 |
| How Can I Retain My SignalProbe ECOs during Re-compilation of My Design? .....                                                                 | 13-12 |
| Why Did My SignalProbe Source Disappear in the Change Manager? .....                                                                           | 13-12 |
| What is an ECO and Where Can I Find More Information on ECO? .....                                                                             | 13-13 |
| How Do I Migrate My Previous SignalProbe Assignments in the Quartus II Software Versions 5.1 and below to Versions 6.0 and Higher? .....       | 13-13 |
| What are all the Changes for the SignalProbe Feature between the Quartus II Software Version 5.1 and Earlier, and Version 6.0 and Later? ..... | 13-14 |
| Scripting Support .....                                                                                                                        | 13-15 |
| Make a SignalProbe Pin .....                                                                                                                   | 13-15 |
| Delete a SignalProbe Pin .....                                                                                                                 | 13-15 |
| Enable a SignalProbe Pin .....                                                                                                                 | 13-16 |
| Disable a SignalProbe Pin .....                                                                                                                | 13-16 |
| Perform a SignalProbe Compilation .....                                                                                                        | 13-16 |
| Migrate Previous SignalProbe Pins to the Quartus II Software Versions 6.0 and Later .....                                                      | 13-16 |
| Script Example .....                                                                                                                           | 13-16 |
| Using SignalProbe with the APEX Device Family .....                                                                                            | 13-17 |
| Adding SignalProbe Sources .....                                                                                                               | 13-17 |
| Performing a SignalProbe Compilation .....                                                                                                     | 13-18 |
| Running SignalProbe with Smart Compilation .....                                                                                               | 13-19 |
| Understanding the Results of a SignalProbe Compilation .....                                                                                   | 13-19 |
| Analyzing SignalProbe Routing Failures .....                                                                                                   | 13-21 |
| SignalProbe Scripting Support for APEX Devices .....                                                                                           | 13-21 |
| Reserving SignalProbe Pins .....                                                                                                               | 13-22 |
| Adding SignalProbe Sources .....                                                                                                               | 13-22 |
| Assigning I/O Standards .....                                                                                                                  | 13-22 |
| Adding Registers for Pipelining .....                                                                                                          | 13-23 |
| Run SignalProbe Automatically .....                                                                                                            | 13-23 |
| Run SignalProbe Manually .....                                                                                                                 | 13-23 |
| Enable or Disable All SignalProbe Routing .....                                                                                                | 13-24 |
| Running SignalProbe with Smart Compilation .....                                                                                               | 13-24 |
| Allow SignalProbe to Modify Fitting Results .....                                                                                              | 13-24 |
| Conclusion .....                                                                                                                               | 13-24 |
| Referenced Documents .....                                                                                                                     | 13-25 |
| Document Revision History .....                                                                                                                | 13-26 |

## Chapter 14. Design Debugging Using the SignalTap II Embedded Logic Analyzer

|                                                                                   |       |
|-----------------------------------------------------------------------------------|-------|
| Introduction .....                                                                | 14-1  |
| Hardware and Software Requirements .....                                          | 14-3  |
| Design Flow Using the SignalTap II Logic Analyzer .....                           | 14-5  |
| SignalTap II Logic Analyzer Task Flow .....                                       | 14-6  |
| Add the SignalTap II Logic Analyzer to Your Design .....                          | 14-7  |
| Configure the SignalTap II Logic Analyzer .....                                   | 14-7  |
| Define Triggers .....                                                             | 14-7  |
| Compile the Design .....                                                          | 14-7  |
| Program the Target Device or Devices .....                                        | 14-7  |
| Run the SignalTap II Logic Analyzer .....                                         | 14-8  |
| View, Analyze, and Use Captured Data .....                                        | 14-8  |
| Add the SignalTap II Logic Analyzer to Your Design .....                          | 14-8  |
| Creating and Enabling a SignalTap II File .....                                   | 14-8  |
| Creating a SignalTap II File .....                                                | 14-8  |
| Enabling and Disabling a SignalTap II File for the Current Project .....          | 14-10 |
| Using the MegaWizard Plug-In Manager to Create Your Embedded Logic Analyzer ..... | 14-10 |
| Creating an HDL Representation Using the MegaWizard Plug-In Manager .....         | 14-10 |
| SignalTap II Megafunction Ports .....                                             | 14-14 |
| Instantiating the SignalTap II Logic Analyzer in Your HDL .....                   | 14-14 |
| Embedding Multiple Analyzers in One FPGA .....                                    | 14-15 |
| Monitoring FPGA Resources Used by the SignalTap II Logic Analyzer .....           | 14-15 |
| Configure the SignalTap II Logic Analyzer .....                                   | 14-16 |
| Assigning an Acquisition Clock .....                                              | 14-16 |
| Adding Signals to the SignalTap II File .....                                     | 14-17 |
| Signal Preservation .....                                                         | 14-19 |
| Assigning Data Signals Using the Node Finder .....                                | 14-20 |
| Assigning Data Signals Using the Technology Map Viewer .....                      | 14-21 |
| Node List Signal Use Options .....                                                | 14-21 |
| Untappable Signals .....                                                          | 14-22 |
| Adding Signals with a Plug-In .....                                               | 14-22 |
| Debugging Finite State Machines .....                                             | 14-24 |
| Modifying and Restoring Mnemonic Tables for State Machines .....                  | 14-26 |
| Additional Considerations .....                                                   | 14-26 |
| Specifying the Sample Depth .....                                                 | 14-27 |
| Capturing Data to a Specific RAM Type .....                                       | 14-27 |
| Choosing the Buffer Acquisition Mode .....                                        | 14-27 |
| Circular Buffer .....                                                             | 14-28 |
| Segmented Buffer .....                                                            | 14-29 |
| Managing Multiple SignalTap II Files and Configurations .....                     | 14-30 |
| Define Triggers .....                                                             | 14-31 |
| Creating Basic Trigger Conditions .....                                           | 14-31 |
| Creating Advanced Trigger Conditions .....                                        | 14-32 |
| Examples of Advanced Triggering Expressions .....                                 | 14-34 |
| Trigger Condition Flow Control .....                                              | 14-36 |
| Sequential Triggering .....                                                       | 14-36 |
| Custom State-Based Triggering .....                                               | 14-38 |

---

|                                                                                   |       |
|-----------------------------------------------------------------------------------|-------|
| State Diagram Pane .....                                                          | 14-41 |
| State Machine Pane .....                                                          | 14-41 |
| Resources Pane .....                                                              | 14-41 |
| SignalTap II Trigger Flow Description Language .....                              | 14-42 |
| State Labels .....                                                                | 14-43 |
| Boolean_expression .....                                                          | 14-43 |
| Action_list .....                                                                 | 14-44 |
| <i>Resource Manipulation Action</i> .....                                         | 14-45 |
| Buffer Control Action .....                                                       | 14-45 |
| State Transition Action .....                                                     | 14-46 |
| Specifying the Trigger Position .....                                             | 14-46 |
| Creating a Power-Up Trigger .....                                                 | 14-47 |
| Enabling a Power-Up Trigger .....                                                 | 14-47 |
| Managing and Configuring Power-Up and Runtime Trigger Conditions .....            | 14-48 |
| Using External Triggers .....                                                     | 14-49 |
| Trigger In .....                                                                  | 14-49 |
| Trigger Out .....                                                                 | 14-50 |
| Using the Trigger Out of One Analyzer as the Trigger In of Another Analyzer ..... | 14-50 |
| Compile the Design .....                                                          | 14-52 |
| Faster Compilations with Quartus II Incremental Compilation .....                 | 14-53 |
| Enabling Incremental Compilation for Your Design .....                            | 14-53 |
| Using Incremental Compilation with the SignalTap II Logic Analyzer .....          | 14-54 |
| Preventing Changes Requiring Recompilation .....                                  | 14-56 |
| Timing Preservation with the SignalTap II Logic Analyzer .....                    | 14-56 |
| Performance and Resource Considerations .....                                     | 14-57 |
| Program the Target Device or Devices .....                                        | 14-59 |
| Programming a Single Device .....                                                 | 14-59 |
| Programming Multiple Devices to Debug Multiple Designs .....                      | 14-60 |
| Run the SignalTap II Logic Analyzer .....                                         | 14-60 |
| Capturing Data Using Segmented Buffers .....                                      | 14-62 |
| Running with a Power-Up Trigger .....                                             | 14-64 |
| Running with Runtime Triggers .....                                               | 14-64 |
| Performing a Force Trigger .....                                                  | 14-64 |
| SignalTap II Status Messages .....                                                | 14-65 |
| View, Analyze, and Use Captured Data .....                                        | 14-66 |
| Viewing Captured Data .....                                                       | 14-66 |
| Creating Mnemonics for Bit Patterns .....                                         | 14-67 |
| Automatic Mnemonics with a Plug-In .....                                          | 14-68 |
| Locating a Node in the Design .....                                               | 14-69 |
| Saving Captured Data .....                                                        | 14-69 |
| Converting Captured Data to Other File Formats .....                              | 14-70 |
| Creating a SignalTap II List File .....                                           | 14-70 |
| Other Features .....                                                              | 14-70 |
| Using the SignalTap II MATLAB MEX Function to Capture Data .....                  | 14-70 |
| Using SignalTap II in a Lab Environment .....                                     | 14-72 |
| Remote Debugging Using the SignalTap II Logic Analyzer .....                      | 14-73 |
| Equipment Setup .....                                                             | 14-73 |

|                                                                                                          |       |
|----------------------------------------------------------------------------------------------------------|-------|
| Software Setup on the Remote PC .....                                                                    | 14-73 |
| Software Setup on the Local PC .....                                                                     | 14-74 |
| SignalTap II Setup on the Local PC .....                                                                 | 14-76 |
| SignalTap II Scripting Support .....                                                                     | 14-76 |
| SignalTap II Command Line Options .....                                                                  | 14-77 |
| SignalTap II Tcl Commands .....                                                                          | 14-79 |
| Design Example: Using SignalTap II Logic Analyzers in SOPC Builder Systems .....                         | 14-81 |
| Custom Triggering Flow Application Examples .....                                                        | 14-81 |
| Design Example 1: Specifying a Custom Trigger Position .....                                             | 14-81 |
| Design Example 2: Trigger When triggercond1 Occurs Ten Times between triggercond2 and triggercond3 ..... | 14-82 |
| Conclusion .....                                                                                         | 14-84 |
| Referenced Documents .....                                                                               | 14-84 |
| Document Revision History .....                                                                          | 14-85 |

## **Chapter 15. In-System Debugging Using External Logic Analyzers**

|                                                                                      |       |
|--------------------------------------------------------------------------------------|-------|
| Introduction .....                                                                   | 15-1  |
| Choosing a Logic Analyzer .....                                                      | 15-2  |
| Required Components .....                                                            | 15-3  |
| FPGA Device Support .....                                                            | 15-3  |
| Debugging Your Design Using the Logic Analyzer Interface .....                       | 15-4  |
| Creating an LAI File .....                                                           | 15-4  |
| Creating a New Logic Analyzer Interface File .....                                   | 15-5  |
| Opening an Existing External Analyzer Interface File .....                           | 15-6  |
| Saving the External Analyzer Interface File .....                                    | 15-6  |
| Configuring the Logic Analyzer Interface File Core Parameters .....                  | 15-7  |
| Mapping the Logic Analyzer Interface File Pins to Available I/O Pins .....           | 15-9  |
| Mapping Internal Signals to the Logic Analyzer Interface Banks .....                 | 15-10 |
| Using the Node Finder .....                                                          | 15-11 |
| Enabling the Logic Analyzer Interface Before Compiling Your Quartus II Project ..... | 15-11 |
| Compiling Your Quartus II Project .....                                              | 15-12 |
| Programming Your FPGA Using the Logic Analyzer Interface .....                       | 15-13 |
| Using the Logic Analyzer Interface with Multiple Devices .....                       | 15-14 |
| Configuring Banks in the Logic Analyzer Interface File .....                         | 15-15 |
| Acquiring Data on Your Logic Analyzer .....                                          | 15-15 |
| Advanced Features .....                                                              | 15-15 |
| Using the Logic Analyzer Interface with Incremental Compilation .....                | 15-15 |
| Creating Multiple Logic Analyzer Interface Instances in One FPGA .....               | 15-16 |
| Conclusion .....                                                                     | 15-17 |
| Referenced Documents .....                                                           | 15-17 |
| Document Revision History .....                                                      | 15-18 |

## **Chapter 16. In-System Updating of Memory and Constants**

|                                                                         |      |
|-------------------------------------------------------------------------|------|
| Introduction .....                                                      | 16-1 |
| Overview .....                                                          | 16-1 |
| Device Megafunction Support .....                                       | 16-2 |
| Using In-System Updating of Memory and Constants with Your Design ..... | 16-3 |

---

|                                                                                                        |       |
|--------------------------------------------------------------------------------------------------------|-------|
| Creating In-System Modifiable Memories Constants .....                                                 | 16-3  |
| Running the In-System Memory Content Editor .....                                                      | 16-4  |
| Instance Manager .....                                                                                 | 16-5  |
| Editing Data Displayed in the Hex Editor .....                                                         | 16-7  |
| Importing and Exporting Memory Files .....                                                             | 16-7  |
| Viewing Memories and Constants in the Hex Editor .....                                                 | 16-7  |
| Scripting Support .....                                                                                | 16-9  |
| Programming the Device Using the In-System Memory Content Editor .....                                 | 16-10 |
| Example: Using the In-System Memory Content Editor with the SignalTap II Embedded Logic Analyzer ..... | 16-10 |
| Conclusion .....                                                                                       | 16-11 |
| Referenced Documents .....                                                                             | 16-11 |
| Document Revision History .....                                                                        | 16-12 |

## Chapter 17. Design Debugging Using In-System Sources and Probes

|                                                                         |       |
|-------------------------------------------------------------------------|-------|
| Introduction .....                                                      | 17-1  |
| Overview .....                                                          | 17-2  |
| Hardware and Software Requirements .....                                | 17-3  |
| Design Flow Using In-System Sources and Probes .....                    | 17-4  |
| Configuring the altsource_probes Megafunction .....                     | 17-6  |
| Instantiating the altsource_probe Megafunction .....                    | 17-8  |
| Compiling the Design .....                                              | 17-8  |
| Running the In-System Sources and Probes Editor .....                   | 17-9  |
| Programming Your Device Using the JTAG Chain Configuration Window ..... | 17-11 |
| Instance Manager .....                                                  | 17-12 |
| Sources and Probes Editor Window .....                                  | 17-13 |
| Reading Probe Data .....                                                | 17-13 |
| Writing Data .....                                                      | 17-14 |
| Data Organization .....                                                 | 17-14 |
| Tcl Support .....                                                       | 17-15 |
| Design Example: Dynamic PLL Reconfiguration .....                       | 17-19 |
| Conclusion .....                                                        | 17-22 |
| Referenced Documents .....                                              | 17-22 |
| Document Revision History .....                                         | 17-22 |

## Section VI. Formal Verification

### Chapter 18. Cadence Encounter Conformal Support

|                                                            |      |
|------------------------------------------------------------|------|
| Introduction .....                                         | 18-1 |
| Formal Verification Versus Simulation .....                | 18-2 |
| Formal Verification: What You Need to Know .....           | 18-2 |
| Formal Verification Design Flow .....                      | 18-2 |
| Quartus II Integrated Synthesis .....                      | 18-3 |
| EDA Tool Support for Quartus II Integrated Synthesis ..... | 18-3 |
| Synplify Pro .....                                         | 18-3 |

|                                                                                           |       |
|-------------------------------------------------------------------------------------------|-------|
| EDA Tool Support for Synplify Pro .....                                                   | 18-4  |
| RTL Coding Guidelines for Quartus II Integrated Synthesis .....                           | 18-5  |
| Synthesis Directives and Attributes .....                                                 | 18-5  |
| Stuck-at Registers .....                                                                  | 18-7  |
| ROM, LPM_DIVIDE, and Shift Register Inference .....                                       | 18-8  |
| RAM Inference .....                                                                       | 18-8  |
| Latch Inference .....                                                                     | 18-9  |
| Combinational Loops .....                                                                 | 18-9  |
| Finite State Machine Coding Styles .....                                                  | 18-9  |
| Black Boxes in the Encounter Conformal Flow .....                                         | 18-10 |
| Tcl Command .....                                                                         | 18-11 |
| GUI .....                                                                                 | 18-12 |
| Generating the Post-Fit Netlist Output File and the Encounter Conformal Setup Files ..... | 18-12 |
| The Quartus II Software Generated Files, Formal Verification Scripts, and Directories ... | 18-17 |
| Understanding the Formal Verification Scripts for Encounter Conformal .....               | 18-19 |
| The Encounter Conformal Commands within the Quartus II Software-Generated Scripts .....   | 18-19 |
| Comparing Designs Using Encounter Conformal .....                                         | 18-22 |
| Running the Encounter Conformal Software from the GUI .....                               | 18-22 |
| Running the Encounter Conformal Software From a System Command Prompt .....               | 18-24 |
| Known Issues and Limitations .....                                                        | 18-24 |
| Black Box Models .....                                                                    | 18-27 |
| Conformal Dofile/Script Example .....                                                     | 18-30 |
| Conclusion .....                                                                          | 18-31 |
| Referenced Documents .....                                                                | 18-31 |
| Document Revision History .....                                                           | 18-32 |

## **Section VII. Device Programming**

### **Chapter 19. Quartus II Programmer**

|                                                   |       |
|---------------------------------------------------|-------|
| Introduction .....                                | 19-1  |
| Programming Flow .....                            | 19-1  |
| Programming and Configuration Modes .....         | 19-4  |
| JTAG Mode .....                                   | 19-4  |
| Passive Serial Mode .....                         | 19-4  |
| Active Serial Mode .....                          | 19-5  |
| In-Socket Programming Mode .....                  | 19-5  |
| Programmer Overview .....                         | 19-6  |
| Tools Menu .....                                  | 19-11 |
| Hardware Setup .....                              | 19-12 |
| Hardware Settings .....                           | 19-12 |
| JTAG Settings .....                               | 19-13 |
| Device Programming and Configuration .....        | 19-14 |
| Single Device Programming and Configuration ..... | 19-14 |
| Multi-Device Programming and Configuration .....  | 19-14 |

|                                                                                 |       |
|---------------------------------------------------------------------------------|-------|
| Bypassing an Altera Device .....                                                | 19-15 |
| Bypassing a Non-Altera Device .....                                             | 19-15 |
| Chain Description File .....                                                    | 19-17 |
| Design Security Key Programming .....                                           | 19-17 |
| Optional Programming Files .....                                                | 19-18 |
| Types of Programming and Configuration Files .....                              | 19-18 |
| Generating Optional Programming Files .....                                     | 19-20 |
| Create Programming Files .....                                                  | 19-20 |
| Convert Programming Files .....                                                 | 19-20 |
| Generating Optional Programming or Configuration Files During Compilation ..... | 19-21 |
| Flash Loaders .....                                                             | 19-21 |
| Parallel Flash Loader .....                                                     | 19-21 |
| Serial Flash Loader .....                                                       | 19-21 |
| Other Programming Tools .....                                                   | 19-22 |
| Quartus II Stand-Alone Programmer .....                                         | 19-22 |
| jtagconfig Debugging Tool .....                                                 | 19-22 |
| Scripting Support .....                                                         | 19-22 |
| Conclusion .....                                                                | 19-23 |
| Referenced Documents .....                                                      | 19-24 |
| Document Revision History .....                                                 | 19-24 |





# Chapter Revision Dates

The chapters in this book, the Quartus II Handbook, Volume 3, were revised on the following dates. Where chapters or groups of chapters are available separately, part numbers are listed.

**Chapter 1. Quartus II Simulator**

Revised: *May 2008*

Part number: *QII53017-8.0.0*

**Chapter 2. Mentor Graphics ModelSim Support**

Revised: *May 2008*

Part number: *QII53001-8.0.0*

**Chapter 3. Synopsys VCS Support**

Revised: *May 2008*

Part number: *QII53002-8.0.0*

**Chapter 4. Cadence NC-Sim Support**

Revised: *May 2008*

Part number: *QII53003-8.0.0*

**Chapter 5. Aldec Active-HDL Support**

Revised: *May 2008*

Part number: *QII53023-8.0.0*

**Chapter 6. Simulating Altera IP in Third-Party Simulation Tools**

Revised: *May 2008*

Part number: *QII53014-8.0.0*

**Chapter 7. The Quartus II TimeQuest Timing Analyzer**

Revised: *May 2008*

Part number: *QII53018-8.0.0*

**Chapter 8. Switching to the Quartus II TimeQuest Timing Analyzer**

Revised: *May 2008*

Part number: *QII53019-8.0.0*

**Chapter 9. Quartus II Classic Timing Analyzer**

Revised: *May 2008*

Part number: *QII53004-8.0.0*

Chapter 10. Synopsys PrimeTime Support  
Revised: *May 2008*  
Part number: *QII53005-8.0.0*

Chapter 11. PowerPlay Power Analysis  
Revised: *May 2008*  
Part number: *QII53013-8.0.0*

Chapter 12. Signal Integrity Analysis with Third-Party Tools  
Revised: *May 2008*  
Part number: *QII53020-8.0.0*

Chapter 13. Quick Design Debugging Using SignalProbe  
Revised: *May 2008*  
Part number: *QII53008-8.0.0*

Chapter 14. Design Debugging Using the SignalTap II Embedded Logic Analyzer  
Revised: *May 2008*  
Part number: *QII53009-8.0.0*

Chapter 15. In-System Debugging Using External Logic Analyzers  
Revised: *May 2008*  
Part number: *QII53016-8.0.0*

Chapter 16. In-System Updating of Memory and Constants  
Revised: *May 2008*  
Part number: *QII53012-8.0.0*

Chapter 17. Design Debugging Using In-System Sources and Probes  
Revised: *May 2008*  
Part number: *QII53021-8.0.0*

Chapter 18. Cadence Encounter Conformal Support  
Revised: *May 2008*  
Part number: *QII53011-8.0.0*

Chapter 19. Quartus II Programmer  
Revised: *May 2008*  
Part number: *QII53022-8.0.0*

This handbook provides comprehensive information about the Altera® Quartus® II design software, version 8.0.

## How to Contact Altera

For the most up-to-date information about Altera products, refer to the following table.

| Information Type   | Contact (1)                                                                                   |
|--------------------|-----------------------------------------------------------------------------------------------|
| Technical support  | <a href="http://www.altera.com/mysupport/">www.altera.com/mysupport/</a>                      |
| Technical training | <a href="http://www.altera.com/training/">www.altera.com/training/</a><br>custrain@altera.com |
| Product literature | <a href="http://www.altera.com/literature/">www.altera.com/literature/</a>                    |
| FTP site           | <a href="http://ftp.altera.com">ftp.altera.com</a>                                            |

*Note to table:*

(1) You can also contact your local Altera sales office or sales representative.

## Third-Party Software Product Information

Third-party software products described in this handbook are not Altera products, are licensed by Altera from third parties, and are subject to change without notice. Updates to these third-party software products may not be concurrent with Quartus II software releases. Altera has assumed responsibility for the selection of such third-party software products and its use in the Quartus II 8.0 software release. To the extent that the software products described in this handbook are derived from third-party software, no third party warrants the software, assumes any liability regarding use of the software, or undertakes to furnish you any support or information relating to the software. EXCEPT AS EXPRESSLY SET FORTH IN THE APPLICABLE ALTERA PROGRAM LICENSE SUBSCRIPTION AGREEMENT UNDER WHICH THIS SOFTWARE WAS PROVIDED TO YOU, ALTERA AND THIRD-PARTY LICENSORS DISCLAIM ALL WARRANTIES WITH RESPECT TO THE USE OF SUCH THIRD-PARTY SOFTWARE CODE OR DOCUMENTATION IN THE SOFTWARE, INCLUDING, WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE, AND NONINFRINGEMENT. For more information, including the latest available version of specific third-party software products, refer to the documentation for the software in question.

# Typographic Conventions

This document uses the typographic conventions shown below.

| Visual Cue                                      | Meaning                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bold Type with Initial Capital Letters</b>   | Command names, dialog box titles, checkbox options, and dialog box options are shown in bold, initial capital letters. Example: <b>Save As</b> dialog box.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>bold type</b>                                | External timing parameters, directory names, project names, disk drive names, filenames, filename extensions, and software utility names are shown in bold type. Examples: <b>f<sub>MAX</sub></b> , <b>\qdesigns</b> directory, <b>d:</b> drive, <b>chiptrip.gdf</b> file.                                                                                                                                                                                                                                                                                                                       |
| <i>Italic Type with Initial Capital Letters</i> | Document titles are shown in italic type with initial capital letters. Example: <i>AN 75: High-Speed Board Design</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <i>Italic type</i>                              | Internal timing parameters and variables are shown in italic type. Examples: <i>t<sub>PIA</sub></i> , <i>n + 1</i> .<br><br>Variable names are enclosed in angle brackets (< >) and shown in italic type. Example: <file name>, <project name>.pof file.                                                                                                                                                                                                                                                                                                                                         |
| Initial Capital Letters                         | Keyboard keys and menu names are shown with initial capital letters. Examples: Delete key, the Options menu.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| "Subheading Title"                              | References to sections within a document and titles of on-line help topics are shown in quotation marks. Example: "Typographic Conventions."                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Courier type                                    | Signal and port names are shown in lowercase Courier type. Examples: <code>data1</code> , <code>tdi</code> , <code>input</code> . Active-low signals are denoted by suffix <code>n</code> , e.g., <code>resetn</code> .<br><br>Anything that must be typed exactly as it appears is shown in Courier type. For example: <code>c:\qdesigns\tutorial\chiptrip.gdf</code> . Also, sections of an actual file, such as a Report File, references to parts of files (e.g., the AHDL keyword <code>SUBDESIGN</code> ), as well as logic function names (e.g., <code>TRI</code> ) are shown in Courier. |
| 1., 2., 3., and a., b., c., etc.                | Numbered steps are used in a list of items when the sequence of the items is important, such as the steps listed in a procedure.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ✓, —, N/A                                       | Used in table cells to indicate the following: ✓ indicates a "Yes" or "Applicable" statement; — indicates a "No" or "Not Supported" statement; N/A indicates that the table cell entry is not applicable to the item of interest.                                                                                                                                                                                                                                                                                                                                                                |
| ■ • •                                           | Bullets are used in a list of items when the sequence of the items is not important.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| ✓                                               | The checkmark indicates a procedure that consists of one step only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ☞                                               | The hand points to information that requires special attention.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ⚠ CAUTION                                       | A caution calls attention to a condition or possible situation that can damage or destroy the product or the user's work.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| ⚠ WARNING                                       | A warning calls attention to a condition or possible situation that can cause injury to the user.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| →                                               | The angled arrow indicates you should press the Enter key.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| → →                                             | The feet direct you to more information on a particular topic.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

As the design complexity of FPGAs continues to rise, verification engineers are finding it increasingly difficult to simulate their system-on-a-programmable-chip (SOPC) designs in a timely manner. The verification process is now the bottleneck in the FPGA design flow. You can perform functional and timing simulation of your design by using the Quartus® II Simulator. The Quartus II software also provides a wide range of features for performing simulation of designs in EDA simulation tools.

This section includes the following chapters:

- Chapter 1, Quartus II Simulator
- Chapter 2, Mentor Graphics ModelSim Support
- Chapter 3, Synopsys VCS Support
- Chapter 4, Cadence NC-Sim Support
- Chapter 5, Aldec Active-HDL Support
- Chapter 6, Simulating Altera IP in Third-Party Simulation Tools



For information about the revision history for chapters in this section, refer to each individual chapter for that chapter's revision history.



## Introduction

With today's FPGAs becoming faster and more complex, designers face challenges in validating their designs. Simulation verifies the correctness of the design, reducing board testing and debugging time.

Altera® offers the Simulator as part of the Quartus® II software to assist designers with design verification. The Quartus II Simulator has a comprehensive set of features that are covered in the following sections:

- “Simulation Flow”
- “Waveform Editor” on page 1–6
- “Simulator Settings” on page 1–18
- “Simulation Report” on page 1–26
- “Debugging with the Quartus II Simulator” on page 1–30
- “Scripting Support” on page 1–33

This chapter describes how to perform different types of simulations with the Quartus II Simulator.

The Quartus II Simulator supports the following device families:

- Arria™ GX
- Stratix® III, Stratix II, Stratix, Stratix GX, Stratix II GX
- Cyclone® III, Cyclone II, Cyclone
- HardCopy® II, HardCopy
- MAX® II, MAX 3000A, MAX 7000AE, MAX 7000B, MAX 7000S
- ACEX® 1K
- APEX™ 20KC, APEX 20KE, APEX II
- FLEX 10K®, FLEX® 10KA, FLEX 10KE, FLEX 6000



The Quartus II Simulator does not support newer devices introduced after Stratix III and Quartus II software version 8.0 and later. Use the ModelSim-Altera Edition to run simulations on designs targeting device introductions after Stratix III. For more information about the ModelSim-Altera Edition simulator, refer to the *Mentor Graphics ModelSim Support* chapter in volume 3 of the *Quartus II Handbook*.

## Simulation Flow

You can perform functional and timing simulations with the Quartus II Simulator. Both types of simulation verify the correctness and behavior of your design. Functional simulations are run at the beginning of the Quartus II design flow and timing simulations are run at the end.

[Figure 1-1](#) shows the Quartus II Simulator flow.

Figure 1-1. Simulation Flow

**Notes to Figure 1-1:**

- (1) For more information about EDA Simulators, refer to the *Simulation* section in volume 3 of the *Quartus II Handbook*.
- (2) You can use Signal Activity Files (.saf) or Value Change Dump Files (.vcf) in the PowerPlay Power Analyzer to check power resources.

As shown in [Figure 1–1](#), your design simulation can happen at the functional level, where your design’s logical behavior is verified and no timing information is used in simulation. Timing simulation can happen after your design has been compiled (synthesized and placed and routed) and after you use the timing data of your design’s resources. In Timing simulation, your design’s logical behavior is verified with the device’s worst-case timing models. Timing simulation using the Fast Timing Model is also a type of timing simulation where best-case timing data is used.

To perform functional simulations with the Quartus II Simulator, you must first generate a functional simulation netlist. A functional netlist file is a flattened netlist extracted from the design files that does not contain timing information.

For timing simulations, you must first perform place-and-route and static timing analysis to generate a timing simulation netlist. A timing simulation netlist includes timing delays of each device atom block and the routing delays.

If you want to use third-party EDA simulation tools, you can generate a netlist using EDA Netlist Writer. You can use this netlist with your testbench files in third-party simulation tools.



For more information about third-party simulators, refer to the respective EDA Simulation chapter in the [Simulation](#) section in volume 3 of the *Quartus II Handbook*.

The Quartus II Simulator supports Functional, Timing, and Timing using Fast Timing Model simulations. The following sections describe how to perform these simulations.

## Functional Simulation

To run a functional simulation, perform the following steps:

1. On the Processing menu, click **Generate Functional Simulation Netlist**. This flattens the functional simulation netlist extracted from the design files. The netlist does not contain timing information.
2. On the Assignments menu, click **Settings**. The **Settings** dialog box appears.
3. In the **Category** list, select **Simulator Settings**. The **Simulator Settings** page appears.
4. In the **Simulation mode** list, select **Functional**.

5. In the **Simulation input** box, specify the vector source. You must specify the vector file to run the simulation.
6. Click **OK**.
7. On the Processing menu, click **Start Simulation**.

## Timing Simulation

To run a timing simulation, perform the following steps:

1. On the Processing menu, click **Start Compilation** or click the **Compilation** button on the toolbar. This flattens the design and generates an internal netlist with timing delay information annotated.
2. On the Assignments menu, click **Settings**. The **Settings** dialog box appears.
3. In the **Category** list, select **Simulator Settings**. The **Simulator Settings** page appears.
4. In the **Simulation Mode** list, select **Timing**.
5. In the **Simulation input** list, specify the vector source. You must specify the vector file to run the simulation.
6. Click **OK**.
7. On the Processing menu, click **Start Simulation**.

## Timing Simulation Using Fast Timing Model Simulation

To run a timing simulation using a fast timing model, perform the following steps:

1. On the Processing menu, point to **Start** and click **Start Analysis and Synthesis**.
2. On the Processing menu, point to **Start** and click **Start Fitter**.  
You must perform fast timing analysis before you can perform a timing simulation using the fast timing models.
3. On the Processing menu, point to **Start** and click **Start Classic Timing Analyzer (Fast Timing Model)**.

4. On the Assignments menu, click **Settings**. The **Settings** dialog box appears.
5. In the **Category** list, select **Simulator Settings**. The **Simulator Settings** page appears.
6. In the **Simulation mode** list, select **Timing using Fast Timing Model**.
7. In the **Simulation input** box, specify the vector source. You must specify the vector file to run the simulation.
8. Click **OK**.
9. On the Processing menu, click **Start Simulation**.

## Waveform Editor

The most common input stimulus for the Quartus II Simulator are VWFs. You can use the Quartus II Waveform Editor to generate a VWF.

### Creating VWFs

To create a VWF, perform the following steps:

1. On the File menu, click **New**. The **New** dialog box appears.
2. Click the **Other Files** tab, and select **Vector Waveform File**.
3. Click **OK**. A blank Waveform Editor window appears ([Figure 1–2](#)).

Figure 1–2. Waveform Editor Window



4. Add nodes and buses. To add a node or bus, on the Edit menu, click **Insert** and click **Insert Node or Bus**. The **Insert Node or Bus** dialog box appears (Figure 1–3). All nodes and buses, as well as the internal signals, are listed under **Name** in the Waveform Editor window.



You can also open the **Insert Node or Bus** dialog box by double-clicking under **Name** in the Waveform Editor.

---

**Figure 1–3. Insert Node or Bus Dialog Box**



- 
5. You can customize the type of node or bus you want to add. If you have a large design with many nodes or buses, you may want to use the Node Finder for node or bus selection. To use the Node Finder, click **Node Finder**. The **Node Finder** dialog box appears (Figure 1–4).

**Figure 1–4. Node Finder Dialog Box**

You can use the Node Finder to find your nodes for simulation among all the nodes and buses in your design. Use the Node Finder to filter and add nodes to your waveform. The Node Finder is equipped with multiple default filter options. By using the correct filter in the Node Finder, you can find the internal node's name and add it to your Vector Waveform File for simulation.



Your node might not appear in the simulation waveform and might be ignored during simulation. This happens because the node has been renamed or synthesized away by the Quartus II software. To prevent this from happening, Altera recommends using the register and pin nodes to simulate your design.

Table 1–1 describes twelve of the Node Finder default filters.

| <b>Table 1–1. Filter Options</b>   |                                                                                                                                                         |
|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Filter</b>                      | <b>Description</b>                                                                                                                                      |
| <b>Pins: input</b>                 | Finds all input pin names in your design file(s).                                                                                                       |
| <b>Pins: output</b>                | Finds all output pin names in your design file(s).                                                                                                      |
| <b>Pins: bidirectional</b>         | Finds all bidirectional pin names in your design file(s).                                                                                               |
| <b>Pins: virtual</b>               | Finds all virtual pin names.                                                                                                                            |
| <b>Pins: all</b>                   | Finds all pin names in your design file(s).                                                                                                             |
| <b>Registers: pre-synthesis</b>    | Finds all user-entered register names contained in the design after design elaboration, but before physical synthesis does any synthesis optimizations. |
| <b>Registers: post-fitting</b>     | Finds all user-entered register names in your design file(s) that survived physical synthesis and fitting.                                              |
| <b>Design Entry (all names)</b>    | Finds all user-entered names in your design file(s).                                                                                                    |
| <b>Post-Compilation</b>            | Finds all user-entered and compiler-generated names that do not have location assignments and survived fitting.                                         |
| <b>SignalTap II: pre-synthesis</b> | Finds all internal device nodes in the pre-synthesis netlist that can be analyzed by the SignalTap® II Logic Analyzer.                                  |
| <b>SignalTap II: post-fitting</b>  | Finds all internal device nodes in the post-fitting netlist that can be analyzed by the SignalTap II Logic Analyzer.                                    |
| <b>SignalProbe</b>                 | Finds all SignalProbe™ device nodes in the post-fitting netlist.                                                                                        |

To customize your own filters in the Node Finder, perform the following steps:

- a. Click **Customize**. The **Customize Filter** dialog box appears.
  - b. To configure settings, click **New**. The **New Custom Filter** dialog box appears.
  - c. In the **Filter name** box, type the name of the custom filter.
  - d. In the **Copy settings from filter** list, select the filter setting.
  - e. Click **OK**.
  - f. You can now customize your filters in the **Customize Filter** dialog box.
6. In the **Look in** box, you can view and edit the current search hierarchy path. You can type the search hierarchy path or you can browse for the hierarchy path by clicking the browse button.

You can move up the search hierarchy by selecting hierarchical names in the **Select Hierarchy Level** dialog box. This ensures that in a large design with many signals, you can specify which hierarchy you would like to get the node from to reduce the amount of signals displayed.

7. After you have configured the filter and specified the correct hierarchy in the **Node Finder** dialog box, click **List** to display all relevant nodes or buses.

Select any node(s) or bus(es) from the **Nodes Found** list and click **>** to include it in the waveform, or you can click **>>** to include all nodes and buses displayed in the **Nodes Found** list.

8. Click **OK**.

 You can also add nodes to the Waveform Editor by dragging nodes from the Project Navigator, Netlist Viewers, or Block Diagram, and dropping them into the Waveform Editor.

9. Create a waveform for a signal. The Quartus II Waveform Editor toolbar includes some of the most common waveform settings, making waveform vector drawings easier and user friendly. [Figure 1–5](#) shows the options available on the Waveform Editor toolbar.

**Figure 1–5. Waveform Editor Toolbar**



10. After you edit your waveform, save the waveform. On the File menu, click **Save As**. The **Save As** dialog box appears. Type your file name, specify the file type, and click **Save**.



Instead of using the Node Finder to insert your nodes for your VWF, you can also drag-and-drop any nodes from the Netlist Viewer to your Simulation Vector Waveform File. For more information on Netlist Viewers, refer to *Analyzing Designs with the Quartus II Netlist Viewers* in volume 1 of the *Quartus II Handbook*.

### Count Value

Count Value applies a count value to a bus to increment the value of the bus by a specified time interval. Instead of manually editing the values for each node, the Count Value feature on the Waveform Editor toolbar automatically creates the counting values for buses. This feature enables you to specify a starting value for a bus, what time interval to increment, and when to stop counting. You can also configure transition occurrences, while setting the count type and increment number. When you click on the **Count Value** button in the Waveform Editor toolbar, the **Count Value** dialog box appears (Figure 1–6). You can also open the **Count Value** dialog box by right-clicking the selected node, pointing to **Value**, and clicking **Count Value**.

Figure 1–6. Count Value Dialog Box



### Clock

You can use the Clock feature in the Waveform Editor toolbar to automatically generate the clock wave, rather than drawing each clock triggering pulse. To generate a clock signal with the **Clock** dialog box,

click the **Overwrite Clock** button on the Waveform Editor toolbar. Furthermore, you can determine the start and end time of a clock signal, whether to manually configure the period (the offset and the duty cycle), or whether to generate the clock based on a specified clock. [Figure 1–7](#) shows the **Clock** dialog box.

**Figure 1–7. Clock Dialog Box**



### Arbitrary Value

Arbitrary Value allows you to overwrite a node value over the selected waveform, waveform interval, or across one or more nodes or groups. To overwrite a node value, perform the following steps:

1. Select a node or a bus and click the **Arbitrary Value** button on the Waveform Editor toolbar ([Figure 1–5](#)). The **Arbitrary Value** dialog box appears ([Figure 1–8](#)).
2. Under **Time range**, specify the start and end time you want to overwrite for the node value.
3. In the **Radix** list, select the radix type.
4. Specify the new value you want overwritten in the **Numeric or named value** box.
5. Click **OK**.

---

**Figure 1-8. Arbitrary Value Dialog Box**

---

### Random Value

Random Value allows you to generate random node values over the selected waveform, waveform interval, or across one or more nodes or groups. [Figure 1-9](#) shows the **Random Values** dialog box.

You can generate random node values by every grid interval, every half grid interval, at random intervals, or at fixed intervals.

---

**Figure 1-9. Random Values Dialog Box**

---

## Generating a Testbench

You can export your VWF as a VHDL Test Bench File (.vht) or Verilog Test Bench File (.vt). This is useful when you want to use a vector waveform in different EDA tools. You must run an analysis and

elaboration before you can export a waveform vector. To export a waveform vector, have your vector waveform open and perform the following steps:

1. On the File menu, click **Export**. The **Export** dialog box appears.
2. In the **Save as type** list, select **VHDL Test Bench File (\*.vht)** or **Verilog Test Bench File (\*.vt)**.
3. You can optionally turn on **Add self-checking code to file**. This option adds additional logic to check the results of the output and compares it to the original VWF.



You must open your project in the Quartus II software before you can export a VWF.



For more information about using the generated testbench in other EDA tools, refer to the respective EDA simulator chapter in the *Simulation* section in volume 3 of the *Quartus II Handbook*.

## Grid Size

When you select portions of your waveform, the selection area snaps to time intervals specified in the **Grid Size** dialog box. You can customize the grid size in the Waveform Editor. You can change the grid size based on the clock settings or by setting the time period. To customize the grid size, on the Edit menu, click **Grid Size**.

## Time Bars

Add time bars in the Waveform Editor to compare edges between different signals. You can also use time bars to jump forward and backward to the next edge transition in the selected signal, and read the logic level of signals by sliding the Time Bar in your waveform. The logic level is displayed in the **Value at** column of the Waveform Editor.

The **Time Bar Organizer** dialog box enables you to create, delete, and edit a time bar, and to create a master time bar. Only one master time bar is allowed per waveform file. To use the Time Bar Organizer, on the Edit menu, point to **Time Bar** and click **Time Bar Organizer**.



Under **Existing time bars**, in the **Absolute time** column, the red **M** indicates the master time bar (Figure 1-10).

**Figure 1–10. Time Bar Organizer Dialog Box**

### Stretch or Compress a Waveform Interval

You can stretch or compress a waveform interval in the Waveform Editor, which enables you to analyze the effects on a waveform. For example, you can check the behavior of your design at high speeds for a short interval by using the compress option to compress the waveform. You can also use this feature to delay the transition of a signal by stretching the waveform.

You have to specify the original start and end time, and the new time for the waveform you want to stretch or compress. If you want to stretch or compress all the nodes or buses, deselect all nodes and buses and set the stretch or compress feature.

To stretch or compress a waveform interval, on the Edit menu, point to **Value** and click **Stretch or Compress Waveform Interval**. The **Stretch or Compress Waveform Interval** dialog box appears.

The “To time value” end time specified in the **Stretch or Compress Waveform Interval** dialog box cannot be larger than the “End Time” specified in the **Simulator Settings** page of the **Settings** dialog box (Figure 1–12). Otherwise, the Quartus II software displays a message indicating the invalid time value.

## End Time

The End Time setting enables you to change the end time of the VWF. The end time represents the maximum length of time in the VWF. You can specify the end time and your preferred time unit, and have different extension values for different nodes or buses. With the waveform open, specify the end time by performing the following steps:

1. On the Edit menu, click **End Time**. The **End Time** dialog box appears (Figure 1-11).

**Figure 1-11. End Time Dialog Box**



2. In the **Time** box, specify the end time and select the time unit in the **Time** list.
3. Under **Default extension options**, in the **Extension value** list, select the value.
4. Under **End time extension per signal**, you can select specific extension values for each signal by clicking in the **Extension value** column.



The options in the **End time** dialog box are different settings than those under **Simulation period** in the **Settings** dialog box. Simulation period is the period that the Quartus II software simulates the stimuli. End time is the maximum length of time in the VWF. For information on the simulation period, refer to [Table 1-2 on page 1-20](#).

## Arrange Group or Bus in LSB or MSB Order

You can arrange a group or bus in Least Significant Bit (LSB) or Most Significant Bit (MSB) order. If you arrange in LSB order, the LSB is on top and MSB is at the bottom. If you arrange in MSB order, the MSB is on top and LSB is at bottom.

To arrange a group or bus in LSB or MSB order, perform the following steps:

1. Select the bus that you want to change the LSB or MSB order. You can also select multiple buses in the waveform editor.
2. On the Edit menu, point to **Group and Bus Bit Order** and click either **MSB on top, LSB on Bottom** to change the bus or group in MSB order or click **LSB on top, MSB on Bottom** to change the bus or group in LSB order.

## Simulator Settings

You can enhance your output, reduce debugging time, and provide better coverage before running a simulation. This section covers the different simulation modes supported by the Quartus II Simulator. Additionally, the Quartus II Simulator offers common setup features like glitch filtering, setup and hold violation detection, and simulation coverage.

To set up simulation settings, perform the following steps:

1. On the Assignments menu, click **Settings**. The **Settings** dialog box appears.
2. In the **Category** list, select **Simulator Settings**. The **Simulator Settings** page appears ([Figure 1-12](#)).

**Figure 1-12. Simulator Settings Page**

Table 1–2 shows the options in the **Simulator Settings** page.

| <b>Table 1–2. Quartus II Simulator Settings (Part 1 of 2)</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Settings and Options</b>                                   | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>Simulation mode (1)</b>                                    | <p><b>Functional</b><br/>This simulation mode uses a pre-synthesis compiler database to simulate the logical performance of a project without the timing information. This mode enables you to check the functionality of the design. All nodes and buses are preserved in this simulation because functional simulation is performed before synthesis, partitioning, or fitting. A VWF is required to perform this simulation mode.</p> <p><b>Timing</b><br/>This simulation mode uses the compiled netlist that includes timing information. With this simulation mode, you can check setup, hold violation, glitches, and simulation coverage. You can remove nodes or buses using the Quartus II Compiler when logic is optimized. This simulation mode uses the worst case timing model.</p> <p><b>Timing using Fast Timing Model</b><br/>This simulation mode is similar to timing simulation but this mode uses the best-case timing model.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| <b>Simulation input</b>                                       | <p>You must include the vector file in the <b>Simulation input</b> box. You can type the name of the file or use the browse button to open the <b>Select File</b> dialog box. In the <b>Files of type</b> list, you can select Vector Waveform File (*.vwf), Compressed Vector Waveform File (*.cvwf), Value Change Dump File (*.vcd), Vector Table Output File (*.tbl), Vector Text File (*.vec), Simulation Channel File (.scf), or <b>All Files</b> (*.*).</p> <p>TBL files contain input vectors and output logic levels in a tabular-format list. You can generate this file using a VWF. However, if you would like to maintain, view, or update the vectors, VWFs offer better visibility. VWF or TBL file formats are interchangeable. You can generate TBL files from VWFs and vice versa. You can create a VWF with the Waveform Editor. For more information about the Waveform Editor, refer to <a href="#">“Waveform Editor” on page 1–6</a>.</p> <p>The Quartus II software also supports MAX+PLUS® II simulation vector files, such as VEC and SCF.</p> <p>A CVWF is the simplified version, non-readable format of the VWF format. This file type is in binary format and is generally smaller in file size. You can use CVWFs in the Waveform Editor and simulation.</p> <p>A VCD file is an ASCII file that contains header information, variable definitions, and the value changes for specified variables, or all variables, in a given design. The value changes for a variable are given in scalar or vector format based on the nature of the variable.</p> |

| <b>Table 1–2. Quartus II Simulator Settings (Part 2 of 2)</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Settings and Options</b>                                   | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>Simulation period</b>                                      | The simulation period determines the length of time that the simulator runs the stimuli with the maximum period being equal to the end time of a VWF. If the simulation period is configured shorter than the end time, all signals beyond the simulation period are displayed as Unknown (X). Therefore, you can also shorten the simulation period or end the simulation earlier by selecting <b>End Simulation at</b> and specifying the time and selecting the time unit. If the simulation period is configured longer than the end time, the simulation will stop at the end time. For information on the end time, refer to “ <a href="#">End Time</a> ” on page 1–17.                                                                        |
| <b>Glitch filtering options</b>                               | Specifies whether to enable glitch filtering for simulations. You can select one of the following options:<br><br><b>Auto</b> —The Simulator performs glitch filtering when SAF generation is enabled in the <b>Simulation Output Files</b> page of the <b>Settings</b> dialog box.<br><br><b>Always</b> —The Simulator always performs glitch filtering, even if SAF generation is not enabled.<br><br><b>Never</b> —The Simulator never performs glitch filtering, even if SAF generation is enabled.                                                                                                                                                                                                                                              |
| <b>More Settings</b>                                          | If you click <b>More Settings</b> , the <b>More Simulator Settings</b> dialog box appears. The following options are available under <b>Existing option settings</b> .<br><br><b>Cell Delay Model Type</b><br>Specifies the type of delay model to be used for cell delays: transport or inertial. The default is transport.<br><br><b>Interconnect Delay Model Type</b><br>Specifies the type of delay model to be used for interconnect delays: transport or inertial. The default is transport.<br><br><b>Preserve fewer signal transition to reduce memory requirements</b><br>This option is effective on lower performance workstations because turning on this option flushes signal transitions from memory to disk for memory optimization. |

**Note to Table 1–2:**

- (1) The Quartus II Simulator may flag an error message if zero-time oscillation occurs in your design. Zero-time oscillation occurs when a particular output signal does not achieve a stable output value at a particular fixed time, which may be due to your design containing combinational logic path loops.

## Simulation Verification Options

Figure 1–13 shows the **Simulation Verification** page.

**Figure 1–13. Simulation Verification Page**



Table 1–3 shows the options in the **Simulation Verification** page.

| <b>Table 1–3. Quartus II Simulation Verification (Part 1 of 2)</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Settings and Options</b>                                        | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <b>Check outputs</b>                                               | <p><b>Check outputs</b> checks expected outputs against actual outputs in the simulation report. After turning on <b>Check outputs</b>, click the <b>Waveform Comparison Settings</b> button. The <b>Waveform Comparison Settings</b> dialog box appears.</p> <p>In the <b>Waveform Comparison Settings</b> dialog box, you can specify the waveform comparison time frame and the comparison options. You can also set the tolerance level for all the signals by specifying the tolerance limit in the <b>Default comparison timing tolerance</b> box. The <b>Maximum comparison mismatches</b> box is the amount of mismatches the Quartus II Simulator is allowed to accept before it stops comparing.</p> <p>You can also set the type of transition the comparison should trigger in the <b>Waveform Comparison Settings</b> dialog box. You can assign trigger comparisons based on <b>Input signal transition edges</b>, <b>All signal transition edges</b>, or <b>Selected Signal transition edges</b>.</p> <p>To customize the waveform comparison matching rules, you can also click the <b>Comparison Rules</b> button. The <b>Comparison Rules</b> dialog box appears, allowing you to customize the comparison matching rules.</p> |
| <b>Setup and hold time violation detection</b>                     | <p>This option detects setup and hold time violation. Setup time is the period required by a synchronous signal to stabilize before the arrival of a clock edge. Hold time is the time required by a synchronous signal to maintain after the same clock edge. If the <b>Setup and hold time violation detection</b> option is turned on, a warning in the <b>Messages</b> window appears if any setup or hold time violation is detected during the simulation. This option is only for Timing and Timing using Fast Timing Model simulation modes.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| <b>Glitch detection</b>                                            | <p>Conditions occur when two or more signals toggle simultaneously and can cause glitches or unwanted short pulses. The <b>Glitch detection</b> option enables you to detect glitches and specify the time interval that defines a glitch. If two logic level transitions occur in a period shorter than the specified time period, the resulting glitch is detected and reported in the <b>Processing</b> tab of the <b>Messages</b> window.</p> <p>If you turn on the <b>Glitch detection</b> option, you can specify the acceptable glitch width. A <b>Messages</b> window appears when a pulse is smaller than the specified glitch width that is detected. The <b>Glitch detection</b> option is only available for Timing and Timing using Fast Timing Model simulation modes.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| <b>Table 1-3. Quartus II Simulation Verification (Part 2 of 2)</b>                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Settings and Options</b>                                                                       | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <b>Simulation coverage reporting</b>                                                              | This option reports the ratio of outputs (coverage) actually simulated to the number of outputs in the netlist and is expressed as a percentage. When you turn on the <b>Simulation coverage reporting</b> option, the <b>Report Settings</b> button is available. If you click <b>Report Settings</b> , the <b>Report Settings</b> dialog box appears. The three types of coverage reports you can select from are <b>Display complete 1/0 value coverage report</b> , <b>Display missing 1-value coverage report</b> , and <b>Display missing 0-value coverage report</b> . |
| <b>Disable setup and hold time violation detection for input registers of bi-directional pins</b> | This option enables you to disable setup and hold time violations detection in input registers of all bidirectional pins in the simulated design during Timing or Timing using Fast Timing Model simulation.                                                                                                                                                                                                                                                                                                                                                                  |

## Simulation Output Files Options

Figure 1-14 shows the **Simulation Output Files** page.

**Figure 1-14. Simulation Output Files Page**



Table 1–4 shows the options in the **Simulation Output Files** page.

| <b>Table 1–4. Quartus II Simulation Output Files</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Setting and Options</b>                           | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>Simulation output waveform</b>                    | <p>Specify the simulation output waveform options.</p> <p><b>Automatically add pins to simulation output waveforms</b><br/>The <b>Automatically add pins to simulation output waveforms</b> option automatically adds all outputs that are available in the design to the waveform reports. If your design has large amounts of outputs, turning on this option ensures all outputs are monitored during simulation.</p> <p><b>Overwrite simulation input file with simulation results</b><br/>This option overwrites the vector source file with simulation results. This option is ignored when the <b>Check outputs</b> setting is turned on. This option adds the result to the vector file and generally, it can give you more visibility during the debugging process. <a href="#">(1)</a></p> <p><b>Group bus channel in simulation results</b><br/>This option automatically groups bus channels in the output waveform that are shown in the simulation reports. By turning off this option, all output waveforms have a node to represent each bus signal.</p> |
| <b>Signal activity output for power analysis</b>     | When you perform your simulation with the Quartus II Simulator, you can generate a SAF file, which is used by the PowerPlay Power Analyzer to assist you with power analysis. <a href="#">(2)</a> , <a href="#">(3)</a>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>VCD output for power analysis</b>                 | When you perform simulation with the Quartus II Simulator, you can generate a VCD file, which is used by the PowerPlay Power Analyzer to assist you with power analysis. <a href="#">(2)</a> , <a href="#">(3)</a>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

**Notes to Table 1–4:**

- (1) A backup copy of the source vector file is saved under the **db** folder with the name `<project>.sim_ori <vector file format type>`.
- (2) Instead of using the SAF or Generate VCD file (\*.vcd), you can also save your output waveform as a VCD file to perform power analysis.
- (3) For more information about the PowerPlay Power Analyzer, refer to the [PowerPlay Power Analysis](#) chapter in volume 3 of the *Quartus II Handbook*.

## Simulation Report

Comprehensive reports are shown after the completion of each simulation. These reports are important to ensure designs meet timing and logical correctness. These simulation reports also play an important role in debugging.

### Simulation Waveform

Simulation Waveforms are part of the Simulation report. In this report, the stimuli and the results of the simulation are displayed.

You can export the simulation waveform as a VHDL Test Bench File or a Verilog Test Bench File for use in other EDA tools. You can also save a simulation as a VWF or Vector Table Output File for use with the Quartus II software.

When you try to edit the Simulation Waveform, the **Edit Input Vector File** dialog box appears, asking whether you would like to edit the vector input file with the results of the simulation or if you would like to overwrite the vector input file with other vector inputs (Figure 1-15).

**Figure 1-15. Edit Input Vector File**



You can overwrite your simulation input file with the simulation results so that your input vector file is updated with the resulting waveform after a simulation. For more information, refer to the **Overwrite simulation input file with simulation results** option in Table 1-2.

If you do not want to overwrite the simulation input file in every simulation run, perform the following to overwrite simulation input files with simulation results after a simulation:

On the Processing Menu, point to **Simulation Debug** and click **Overwrite Vector Inputs with Simulation Outputs**.

## Simulating Bidirectional Pin

A bidirectional pin is represented in the waveform by two channels. One channel represents the input to the bidirectional pin, and the other channel represents the output from the bidirectional pin. You can enter the input channel into the waveform by using the **Node Finder** dialog box. The output channel is automatically created by the Quartus II Simulator and named *<bidir pin name> ~result*.

## Logical Memories Report

The Quartus II software writes out the contents of each memory module after simulation. Therefore, if you use memory cells in your design, you can analyze the contents of the logic memory structures in the device in the Logical Memories Report. The Logical Memories Report displays individual reports for each memory block and contains the data stored in the memory cell used at the end of simulation.

After being simulated, a memory module's contents are stored in the Logical Memories section of the simulation report file.

To view this section, perform the following steps:

1. On the Processing menu, click **Simulation Report**. The Simulation Report window appears.
2. In the report window, click on the "+" next to **Logical Memories**.

## Simulation Coverage Reports

The **Coverage Summary** report contains the following summary information for the simulation:

- Total toggling coverage as a percentage
- Total nodes checked in the design
- Total output ports checked
- Total output ports with complete 1/0-value coverage
- Total output ports with no 1/0-value coverage
- Total output ports with no 1-value coverage
- Total output ports with no 0-value coverage

The **Complete 1/0-Value Coverage** report lists the following information:

- Node name
- Output port name
- Output port type for output ports that toggle between 1 and 0 during the simulation

The **Missing 0-Value Coverage** report and **Missing 1-Value Coverage** report list the following information:

- Node name
- Output port name
- Output port type for output ports that do not toggle to the designated value

For more information about Simulation Coverage reports, refer to the **Simulation coverage reporting** option in [Table 1–2 on page 1–20](#).

The following are individual reports and their definitions:

#### Complete 1/0 value coverage report

Displays all the nodes or buses that toggle between 1 and 0 during simulation.

#### Missing 1-value coverage and Missing 0-value coverage reports

Displays all the nodes that do not toggle to the designated value.

## Comparing Two Waveforms

You can compare your simulation results against previous simulations using the compare option. To compare two waveforms in the **Simulation Report**, turn on the **Check outputs** option. For more information about the **Check outputs** option, refer to [Table 1–2 on page 1–20](#). With the **Check outputs** option turned on, the two comparable waveforms are visible in black and red. The black waveforms represent the original output or the expected output, and the red waveforms represent the compared output or the actual output. [Figure 1–16](#) shows an example of expected output waveform versus actual output waveform.

**Figure 1–16. Example of Simulation Waveform from the Simulation Report When Check Output is Turned On**



## Debugging with the Quartus II Simulator

The Quartus II software includes tools to help with simulation debugging. This section covers some debugging tools and their use.

### Breakpoints

Inserting breakpoints into the simulation process enables the simulator to break at the desired time or on the desired node or bus condition. You can monitor the activity of nodes or buses during specified times and pinpoint the cause of mismatched signal levels between expected and actual. To use breakpoints, perform the following steps:

1. On the Processing menu, point to **Simulation Debug** and click **Breakpoints**. The **Breakpoints** dialog box appears (Figure 1-17).

**Figure 1-17. Breakpoints Dialog Box**



2. Click **New** to create a new breakpoint. The **New Breakpoint** dialog box appears. In this dialog box, you can specify the name, the equation, and the action of the breakpoint. You can also enable or disable this breakpoint by using the **Enable Breakpoint** check box.
3. In the Equation text box, click **condition**. You can configure the logical conditions of individual nodes or buses, or you can set the time.
4. After you configure the equation conditions, select the action for the Quartus II Simulator. In the Action pull-down list, select **Stop**, **Warning Message**, **Error Message**, or **Information Message**. This selection defines the action once the condition is met.
5. You can also enter the text that appears when the Simulator encounters the breakpoint. If you do not make an entry in this box, the Quartus II software displays a default message.

## Updating Memory Content

If your design includes memories, when the simulator stops at a breakpoint, you can view and edit the contents of the memories. To view your memories during a breakpoint in the simulation, on the Processing menu, point to **Simulation Debug** and click **Embedded Memory**.

## Last Simulation Vector Outputs

The Last Simulation Vector Outputs command opens the Output Simulation Waveforms report generated by the last simulation. To use this command, on the Processing menu, point to **Simulation Debug** and click **Last Simulation Vector Outputs**.

You can open the current input vectors that you defined in the **Simulator Settings** dialog box with the **Current Vector Inputs** command. To use this command, on the Processing menu, point to **Simulation Debug** and click **Current Vector Inputs**. Lastly, you can overwrite the vector source file with the simulation outputs which open the resulting file.

## Conventional Debugging Process

During the design phase, tapping out internal signals is a common practice to debug simulation errors. Therefore, the Quartus II software enables you to tap out the signal for simulation debug and also enables you to pull out the internal signal to the physical I/O. The Quartus II software also offers SignalTap II and SignalProbe to further assist you with debugging.

### *Accessing Internal Signals for Simulation*

You can conventionally debug by probing out the internal signals, which enables you to preserve the internal signals during synthesis. You can probe the internal signal by selecting the node or bus and specifying a name, and then adding an output port to the schematic with a similar name. [Figure 1-18](#) shows an example of accessing internal signals for simulation from a schematic diagram.

Figure 1–18. Example of Tapping Out Internal Signal



For timing simulations, the simulation netlist is based on the Compilation post-Synthesis and post-Fitting netlist. Therefore, some of the internal nodes or buses are optimized away during compilation of the netlist. If an internal node is optimized away, the Quartus II software shows a warning in the **Warning** tab of the Messages window similar to the following message:

Warning: Compiler packed, optimized or synthesized away node "DataU". Ignored vector source file node.

This internal node is ignored by the Quartus II Simulator.

If you would like to tap out the D and Q ports of registers, turn on **Add D and Q ports of register node to Simulation Output Waveform** from the Assignment Editor. This feature is only available for functional simulations.

## Scripting Support

You can run procedures and make settings described in this chapter in a Tcl script. You can also run some procedures at a command prompt. For detailed information about scripting command options, refer to the Quartus II Command-Line and Tcl API Help browser. To run the Help browser, type the following command at the command prompt:

```
quartus_sh --qhelp ↵
```

The *Quartus II Scripting Reference Manual* includes the same information in PDF form.



For more information about Tcl scripting, refer to the *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*. Refer to the *Quartus II Settings File Reference Manual* for information about all settings and constraints in the Quartus II software. For more information about command-line scripting, refer to the *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*.

You can change the Functional, Timing, or Timing using Fast Timing Model simulation modes with the following command:

```
simulation_mode <mode> ↵
```

To initialize the simulation for the current design, use the following command. During initialization, the Simulator builds the simulation netlist and sets the simulation time to zero.

The option `-ignore_vector_file` is set to **Off** by default when the source vector file exists for simulation. The Quartus II software ignores the source vector file during simulation if the option `-ignore_vector_file` is set to **On**. The `-end_time` option is used only when the `-ignore_vector_file` option is set to **On**.

```
initialize_simulation [-h | -help] [-long_help] [-check_outputs <On | Off>] \
[-end_time <end_time>] [-glitch_filtering <On | Off>] [-ignore_vector_file <On | Off>] \
[-memory_limiter <On | Off>] [-power_vcd_output <target_file>] [-read_settings_files <On | \
Off>] \ [-saf_output <target_file>] [-sim_mode <functional | timing | timing_using_fast_timing_model>] \
[-vector_source <vector_source_file>] [-write_settings_files <On | Off>] \
-simulation_results_format <VWF | CVWF | VCD> -vector_source <vector source file>
```

To force the specified signal or group of signals to the specified value, type the following at a command prompt:

```
force_simulation_value [-h | -help] [-long_help] -node <hpath> <value> ↵
```

To turn on the simulator to simulate the design for a specified time, type the following at a command prompt:

```
run_simulation [-h | -help] [-long_help] [-time <time>] ↵
```



If you do not set a specific length of time for the simulation run, it runs a complete simulation.

To create a breakpoint with a specified equation and action, type the following at a command prompt:

```
create_simulation_breakpoint [-h | -help] [-long_help] \
-action [Give Warning | Give Info | Give Error] \
-breakpoint <breakpoint_name> -equation <equation> [-user_message <message_text>] ↵
```

To delete a breakpoint with a specified name, type the following at a command prompt:

```
delete_simulation_breakpoint [-h | -help] [-long_help] \
-breakpoint <breakpoint_name> ↵
```

## Conclusion

Simulation plays an important role in ensuring the quality of a product. The Quartus II software offers various tools to assist you with simulation and helps reduce debugging time with the introduction of features like Glitch Filtering and Breakpoints.

## Referenced Documents

This chapter references the following documents:

- *Analyzing Designs with the Quartus II Netlist Viewers* in volume 1 of the *Quartus II Handbook*
- *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*
- *Mentor Graphics ModelSim Support* chapter in volume 3 of the *Quartus II Handbook*
- *PowerPlay Power Analysis* chapter in volume 3 of the *Quartus II Handbook*
- *Quartus II Scripting Reference Manual*
- *Quartus II Settings File Reference Manual*
- *Section I: Simulation* section in volume 3 of the *Quartus II Handbook*
- *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*

# Document Revision History

Table 1–5 shows the revision history for this chapter.

| <b>Table 1–5. Document Revision History</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                  |
|---------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|
| <b>Date and Document Version</b>            | <b>Changes Made</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <b>Summary of Changes</b>                        |
| May 2008 v.8.0.0                            | Updated “Introduction” on page 1–1.<br>Updated “Referenced Documents” on page 1–34.                                                                                                                                                                                                                                                                                                                                                                                                | Updated for the Quartus II software version 8.0. |
| October 2007 v7.2.0                         | Reorganized “Referenced Documents” on page 1–33.                                                                                                                                                                                                                                                                                                                                                                                                                                   | —                                                |
| May 2007 v7.1.0                             | <ul style="list-style-type: none"> <li>● Updated a command in Scripting Support.</li> <li>● Updated Breakpoints.</li> <li>● Added procedure to Logical Memories Report.</li> <li>● Updated sections, added sections and deleted sections in Simulator Settings.</li> <li>● Updated Simulation Report.</li> <li>● Updated Table 1-2.</li> <li>● Added Arrange Group or Bus in LSB in MSB Order.</li> <li>● Updated Creating VWFs.</li> <li>● Added Referenced Documents.</li> </ul> | Updated for the Quartus II software version 7.1. |
| March 2007 v7.0.0                           | Updated Quartus II software 7.0 revision and date only. No other changes made to chapter.                                                                                                                                                                                                                                                                                                                                                                                          | —                                                |
| November 2006 v6.1.0                        | Updated for the Quartus II software version 6.1. <ul style="list-style-type: none"> <li>● Added references to Value Change Dump File (.vcd)</li> <li>● Added Random Value section</li> <li>● Other minor changes</li> </ul>                                                                                                                                                                                                                                                        | Updated for the Quartus II software version 6.1. |
| May 2006 v6.0.0                             | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | —                                                |



## Introduction

An Altera® software subscription includes a license for the ModelSim-Altera software on a PC or UNIX platform. You can use the ModelSim-Altera software to perform register transfer level (RTL) functional, post-synthesis, and gate-level timing simulations for either Verilog HDL or VHDL designs that target an Altera FPGA. This chapter provides detailed instructions on how to simulate your design in the ModelSim-Altera version or the Mentor Graphics® ModelSim® software version. This chapter gives you details on the specific libraries that are needed for a RTL functional, post-synthesis, and gate-level timing simulation.

The following topics are discussed in this chapter:

- “Background” on page 2–1
- “Software Compatibility” on page 2–3
- “Altera Design Flow with ModelSim-Altera or Modelsim Software” on page 2–3
- “Simulating Designs that Include Transceivers” on page 2–77
- “Simulation Libraries” on page 2–5
- “Simulation Netlist Files” on page 2–13
- “Perform Simulation Using ModelSim-Altera Software” on page 2–18
- “Perform Simulation Using Modelsim Software” on page 2–43
- “Simulating Designs that Include Transceivers” on page 2–77
- “Using the NativeLink Feature with ModelSim-Altera or ModelSim Software” on page 2–86
- “Generating a Timing VCD File for PowerPlay” on page 2–92
- “Scripting Support” on page 2–93
- “Software Licensing and Licensing Setup in ModelSim-Altera” on page 2–95



For more information about the current Quartus II software version, refer to the Altera website at [www.altera.com](http://www.altera.com).

## Background

ModelSim-Altera software is included with your Altera software subscription and can be licensed for PC, Solaris, or Linux platforms to support either Verilog HDL or VHDL simulation. ModelSim-Altera software supports RTL functional, post-synthesis, and gate-level timing simulations for all Altera devices.

Table 2–1 describes the differences between the Mentor Graphics ModelSim SE/PE and ModelSim-Altera software versions.

| <b>Table 2–1. Comparison of ModelSim Software Versions</b>                                                                     |                    |                    |                                     |                                     |
|--------------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------|-------------------------------------|-------------------------------------|
| <b>Product Feature</b>                                                                                                         | <b>ModelSim SE</b> | <b>ModelSim PE</b> | <b>ModelSim-Altera</b>              | <b>ModelSim-Altera Web Edition</b>  |
| 100% VHDL, Verilog, mixed-HDL support                                                                                          | Optional           | Optional           | Supports only single-HDL simulation | Supports only single-HDL simulation |
| Complete HDL debugging environment                                                                                             | ✓                  | ✓                  | ✓                                   | ✓                                   |
| Optimized direct compile architecture                                                                                          | ✓                  | ✓                  | ✓                                   | ✓                                   |
| Industry-standard scripting                                                                                                    | ✓                  | ✓                  | ✓                                   | ✓                                   |
| Flexible licensing                                                                                                             | ✓                  | Optional           | ✓                                   | —                                   |
| Verilog PLI support. Interfaces Verilog HDL designs to customer C code and third-party software                                | ✓                  | ✓                  | ✓                                   | ✓                                   |
| VHDL FLI support. Interfaces VHDL designs to customer C code and third-party software                                          | ✓                  | —                  | —                                   | —                                   |
| Standard Delay Format File annotation                                                                                          | ✓                  | ✓                  | ✓(1)                                | ✓ (1)                               |
| Advanced debugging features and language-neutral licensing                                                                     | ✓                  | —                  | —                                   | —                                   |
| Customizable, user-expandable graphical user interface GUI and integrated simulation performance analyzer                      | ✓                  | —                  | —                                   | —                                   |
| Integrated code coverage analysis and SWIFT support                                                                            | ✓                  | —                  | —                                   | —                                   |
| Accelerated VITAL and Verilog HDL primitives (3 times faster), and register transfer level (RTL) acceleration (5 times faster) | ✓                  | —                  | —                                   | —                                   |
| Platform support                                                                                                               | PC, UNIX, Linux    | PC only            | PC, UNIX, Linux                     | PC only                             |
| Precompiled Libraries                                                                                                          | No                 | No                 | Yes                                 | Yes                                 |

*Note to Table 2–1:*

(1) ModelSim-Altera software only allows SDF annotation to modules in the Altera library.

## Software Compatibility

[Table 2–2](#) shows which ModelSim-Altera and Modelsim software version is compatible with the Quartus II software versions. ModelSim versions provided directly from Mentor Graphics do not correspond to specific Quartus II software versions.

For help with ModelSim-Altera licensing set up, refer to “[Software Licensing and Licensing Setup in ModelSim-Altera](#)” on page 2–95.

**Table 2–2. Compatibility Between Software Versions**

| ModelSim-Altera Software                            | Quartus II Software (1)                                 |
|-----------------------------------------------------|---------------------------------------------------------|
| ModelSim-Altera and Modelsim software version 6.1g  | Quartus II software version 6.1, 7.0, 7.1, 7.2, and 8.0 |
| ModelSim-Altera and Modelsim software version 6.1d  | Quartus II software version 6.0                         |
| ModelSim-Altera and Modelsim software version 6.0e  | Quartus II software version 5.1                         |
| ModelSim-Altera and Modelsim software version 6.0c  | Quartus II software version 5.0                         |
| ModelSim-Altera and Modelsim software version 5.8.e | Quartus II software version 4.2                         |
| ModelSim-Altera and Modelsim software version 5.8   |                                                         |

*Note to Table 2–2:*

- (1) Updated ModelSim-Altera pre-compiled libraries are available for download on Altera’s website for each release of the Quartus II service pack.

## Altera Design Flow with ModelSim-Altera or Modelsim Software

[Figure 2–1](#) illustrates an Altera design flow using Mentor Graphics ModelSim-Altera software or ModelSim software.

**Figure 2–1. Altera Design Flow with ModelSim-Altera Software, Modelsim Software, and Quartus II Software**



### **Notes to Figure 2-1:**

- (1) A RTL functional simulation is performed before a gate-level timing simulation or post-synthesis simulation. RTL functional simulation verifies the functionality of the design before synthesis and place-and-route. If you are performing a RTL functional simulation through NativeLink, you must complete Analysis and Elaboration first.
  - (2) A post-synthesis simulation verifies the functionality of a design after synthesis has been performed.
  - (3) Gate-level timing simulation is a post place-and-route simulation to verify the operation of the design after timing delays have been calculated.
  - (4) In Modelsim-Altera software, you do not need to compile the simulation library files as the simulation library files are already pre-compiled for you.

## Simulation Libraries

Simulation model libraries are required to run a simulation whether you are running a RTL functional simulation, post-synthesis simulation, or gate-level timing simulation. In general, running a RTL functional simulation requires the RTL functional simulation model libraries, while running a post-synthesis or gate-level timing simulation requires the gate-level timing simulation model libraries. You must compile the necessary library files before you can run the simulation.

However, there are few exceptions where you are also required to compile gate-level timing simulation library files to perform RTL functional simulation. For example, the following are some of the Altera megafunctions gate-level libraries required to perform a RTL functional simulation in third-party simulators:

- ALTCLKBUF
- ALTCLKCTRL
- ALTDQS
- ALTDQ
- ALTDDIO\_IN
- ALTDDIO\_OUT
- ALTDDIO\_BIDIR
- ALTUFM\_NONE
- ALTUFM\_PARALLEL
- ALTUFM\_SPI
- ALTMEMMULT
- ALTREMOTE\_UPDATE



To identify what type of simulation libraries are required to run the simulation for certain Altera megafunction, refer to the last page in the Altera megafunction MegaWizard. This explains what simulation library files are required to perform a RTL functional simulation for that particular megafunction.

Simulating the Transceiver Megafunction (for example, ALT2GXB) is also another exception which requires the gate-level libraries to perform RTL functional simulation and vice-versa. For detailed, step-by-step instructions about how to simulate the Transceiver Megafunction, refer to “[Simulating Designs that Include Transceivers](#)” on page [2-77](#).

### Pre-Compiled Simulation Libraries in Modelsim-Altera Software

In Modelsim-Altera software, the pre-compiled libraries for both functional and gate-level simulations are available. You do not need to explicitly compile these library files before running the simulation directly.

### RTL Functional Simulation Libraries

RTL functional simulation libraries include the LPM simulation model, Altera megafunction simulation model, and the low-level primitive simulation model. **Table 2–3** shows the pre-compiled library name and the location in the Modelsim-Altera software for all the RTL functional simulation models in VHDL.

| <b>Table 2–3. Pre-Compiled RTL Functional Simulation Libraries in Modelsim-Altera Software (VHDL)</b> |                                  |                                                                                    |
|-------------------------------------------------------------------------------------------------------|----------------------------------|------------------------------------------------------------------------------------|
| <b>RTL Simulation Model</b>                                                                           | <b>Pre-Compiled Library Name</b> | <b>Location in Modelsim-Altera</b>                                                 |
| LPM                                                                                                   | <b>lpm</b>                       | <code>&lt;ModelSim-Altera installation directory&gt;\altera\vhdl\220model\</code>  |
| Altera Megafunction                                                                                   | <b>altera_mf</b>                 | <code>&lt;ModelSim-Altera installation directory&gt;\altera\vhdl\altera_mf\</code> |
| Low-level Primitives                                                                                  | <b>altera</b>                    | <code>&lt;ModelSim-Altera installation directory&gt;\altera\vhdl\altera\</code>    |
| ALTGXBX<br>Megafunction<br>(Stratix GX)                                                               | <b>altgxb</b>                    | <code>&lt;ModelSim-Altera installation directory&gt;\altera\vhdl\altgxb\</code>    |

**Table 2–4** shows the pre-compiled library name and the location in the Modelsim-Altera software for all the RTL functional simulation models in Verilog.

| <b>Table 2–4. Pre-Compiled RTL Functional Simulation Libraries in Modelsim-Altera Software (Verilog)</b> |                                  |                                                                                       |
|----------------------------------------------------------------------------------------------------------|----------------------------------|---------------------------------------------------------------------------------------|
| <b>RTL Simulation Model</b>                                                                              | <b>Pre-Compiled Library Name</b> | <b>Location in Modelsim-Altera</b>                                                    |
| LPM                                                                                                      | <b>lpm_ver</b>                   | <code>&lt;ModelSim-Altera installation directory&gt;\altera\verilog\220model\</code>  |
| Altera Megafunction                                                                                      | <b>altera_mf_ver</b>             | <code>&lt;ModelSim-Altera installation directory&gt;\altera\verilog\altera_mf\</code> |
| Low-level Primitives                                                                                     | <b>altera_ver</b>                | <code>&lt;ModelSim-Altera installation directory&gt;\altera\verilog\altera\</code>    |
| ALTGXBX<br>Megafunction<br>(Stratix GX)                                                                  | <b>altgxb_ver</b>                | <code>&lt;ModelSim-Altera installation directory&gt;\altera\verilog\altgxb\</code>    |

### Gate-Level Simulation Libraries

Gate-level simulation libraries include the supported Altera device atom simulation models. Table 2–5 shows the pre-compiled library name and location in the Modelsim-Altera software for all gate-level simulation models in VHDL.

**Table 2–5. Pre-Compiled Gate-Level Simulation Libraries in Modelsim-Altera Software (VHDL) (Part 1 of 2)**

| Device Simulation Model                   | Pre-Compiled Library Name | Location in <i>Modelsim-Altera</i>                                      |
|-------------------------------------------|---------------------------|-------------------------------------------------------------------------|
| Arria® GX (without transceiver block)     | <b>arriagx</b>            | <ModelSim-Altera installation directory>\altera\vhdl\arriagx\           |
| Arria GX (with transceiver block)         | <b>arriagx_hssi</b>       | <ModelSim-Altera installation directory>\altera\vhdl\arriagx_hssi\      |
| Stratix® IV                               | <b>stratixiv</b>          | <ModelSim-Altera installation directory>\altera\vhdl\stratixiv\         |
| Stratix IV (with transceiver block)       | <b>stratixiv_hssi</b>     | <ModelSim-Altera installation directory>\altera\vhdl\stratixiv_hssi\    |
| Stratix IV (with PCI Express)             | <b>stratixiv_pcie_hip</b> | <ModelSim-Altera installation directory>\altera\vhdl\stratixiv_pcie_hip |
| Stratix III                               | <b>stratixiii</b>         | <ModelSim-Altera installation directory>\altera\vhdl\stratixiii\        |
| Stratix II                                | <b>stratixii</b>          | <ModelSim-Altera installation directory>\altera\vhdl\stratixii\         |
| Stratix II GX (without transceiver block) | <b>stratixiigx</b>        | <ModelSim-Altera installation directory>\altera\vhdl\stratixiigx\       |
| Stratix II GX (with transceiver block)    | <b>stratixiigx_hssi</b>   | <ModelSim-Altera installation directory>\altera\vhdl\stratixiigx_hssi\  |
| Stratix                                   | <b>stratix</b>            | <ModelSim-Altera installation directory>\altera\vhdl\stratix\           |
| Stratix GX (without transceiver block)    | <b>stratixgx</b>          | <ModelSim-Altera installation directory>\altera\vhdl\stratixgx\         |
| Stratix GX (with transceiver block)       | <b>stratixgx_gxb</b>      | <ModelSim-Altera installation directory>\altera\vhdl\stratixiigx_gxb\   |
| Cyclone® II                               | <b>cycloneii</b>          | <ModelSim-Altera installation directory>\altera\vhdl\cycloneii\         |
| Cyclone                                   | <b>cyclone</b>            | <ModelSim-Altera installation directory>\altera\vhdl\cyclone\           |
| MAX® II                                   | <b>maxii</b>              | <ModelSim-Altera installation directory>\altera\vhdl\maxii\             |
| MAX 7000 and MAX 3000                     | <b>max</b>                | <ModelSim-Altera installation directory>\altera\vhdl\max\               |
| APEX™ II                                  | <b>apexii</b>             | <ModelSim-Altera installation directory>\altera\vhdl\apexii\            |
| APEX 20K                                  | <b>apex20k</b>            | <ModelSim-Altera installation directory>\altera\vhdl\apex20k\           |

**Table 2-5. Pre-Compiled Gate-Level Simulation Libraries in Modelsim-Altera Software (VHDL) (Part 2 of 2)**

| Device Simulation Model              | Pre-Compiled Library Name | Location in Modelsim-Altera                                   |
|--------------------------------------|---------------------------|---------------------------------------------------------------|
| APEX 20KC, APEX 20KE, and Excalibur™ | <b>apex20ke</b>           | <ModelSim-Altera installation directory>\altera\vhdl\apex20ke |
| FLEX® 10KE and ACEX® 1K              | <b>flex10ke</b>           | <ModelSim-Altera installation directory>\altera\vhdl\flex10ke |

Table 2-6 shows the pre-compiled library name and the location in the Modelsim-Altera software for all the gate-level simulation models in Verilog.

**Table 2-6. Pre-Compiled Gate-Level Simulation Libraries in Modelsim-Altera Software (Verilog) (Part 1 of 2)**

| Device Simulation Model                   | Pre-Compiled Library Name     | Location in Modelsim-Altera                                                 |
|-------------------------------------------|-------------------------------|-----------------------------------------------------------------------------|
| Arria GX (without transceiver block)      | <b>arriagx_ver</b>            | <ModelSim-Altera installation directory>\altera\verilog\arriagx\            |
| Arria GX (with transceiver block)         | <b>arriagx_hssi_ver</b>       | <ModelSim-Altera installation directory>\altera\verilog\arriagx_hssi\       |
| Stratix IV                                | <b>stratixiv_ver</b>          | <ModelSim-Altera installation directory>\altera\verilog\stratixiv\          |
| Stratix IV (with transceiver block)       | <b>stratixiv_hssi_ver</b>     | <ModelSim-Altera installation directory>\altera\verilog\stratixiv_hssi\     |
| Stratix IV (with PCI Express)             | <b>stratixiv_pcie_hip_ver</b> | <ModelSim-Altera installation directory>\altera\verilog\stratixiv_pcie_hip\ |
| Stratix III                               | <b>stratixiii_ver</b>         | <ModelSim-Altera installation directory>\altera\verilog\stratixiii\         |
| Stratix II                                | <b>stratixii_ver</b>          | <ModelSim-Altera installation directory>\altera\verilog\stratixii\          |
| Stratix II GX (without transceiver block) | <b>stratixiigx_ver</b>        | <ModelSim-Altera installation directory>\altera\verilog\stratixiigx\        |
| Stratix II GX (with transceiver block)    | <b>stratixiigx_hssi_ver</b>   | <ModelSim-Altera installation directory>\altera\verilog\stratixiigx_hssi\   |
| Stratix                                   | <b>stratix_ver</b>            | <ModelSim-Altera installation directory>\altera\verilog\stratix\            |
| Stratix GX (without transceiver block)    | <b>stratixgx_ver</b>          | <ModelSim-Altera installation directory>\altera\verilog\stratixgx\          |
| Stratix GX (with transceiver block)       | <b>stratixgx_gxb_ver</b>      | <ModelSim-Altera installation directory>\altera\verilog\stratixgx_gxb\      |
| Cyclone II                                | <b>cycloneii_ver</b>          | <ModelSim-Altera installation directory>\altera\verilog\cycloneii\          |
| Cyclone                                   | <b>cyclone_ver</b>            | <ModelSim-Altera installation directory>\altera\verilog\cyclone\            |
| MAX II                                    | <b>maxii_ver</b>              | <ModelSim-Altera installation directory>\altera\verilog\maxii\              |

**Table 2–6. Pre-Compiled Gate-Level Simulation Libraries in Modelsim-Altera Software (Verilog) (Part 2 of 2)**

| Device Simulation Model              | Pre-Compiled Library Name | Location in Modelsim-Altera                                      |
|--------------------------------------|---------------------------|------------------------------------------------------------------|
| MAX 7000 and MAX 3000                | <b>max_ver</b>            | <ModelSim-Altera installation directory>\altera\verilog\max      |
| APEX II                              | <b>apexii_ver</b>         | <ModelSim-Altera installation directory>\altera\verilog\apexii   |
| APEX 20K                             | <b>apex20k_ver</b>        | <ModelSim-Altera installation directory>\altera\verilog\apex20k  |
| APEX 20KC, APEX 20KE, and Excalibur™ | <b>apex20ke_ver</b>       | <ModelSim-Altera installation directory>\altera\verilog\apex20ke |
| FLEX 10KE and ACEX 1K                | <b>flex10ke_ver</b>       | <ModelSim-Altera installation directory>\altera\verilog\flex10ke |

## Simulation Library Files in the Quartus II Software

In Modelsim SE/PE, no pre-compiled libraries are available. You must compile the necessary libraries to perform RTL functional or gate-level simulation. The following sections show the location of these library files in the Quartus II directory structure. You can refer to these library files for a particular simulation model that you require.

### RTL Functional Simulation Library Files

Table 2–7 shows the VHDL RTL simulation model location in the Quartus II directory.

**Table 2–7. RTL Functional Simulation Library Files in the Quartus II Directory (VHDL) (Part 1 of 2)**

| RTL Simulation Model | Location in Quartus II Directory Structure                                                                                                                                                                           |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LPM                  | <Quartus II installation directory>\ledalsim_lib\220pack.vhd<br><Quartus II installation directory>\ledalsim_lib\220model.vhd<br><Quartus II installation directory>\ledalsim_lib\220model_87.vhd (1)                |
| Altera Megafunction  | <Quartus II installation directory>\ledalsim_lib\altera_mf_components.vhd<br><Quartus II installation directory>\ledalsim_lib\altera_mf.vhd<br><Quartus II installation directory>\ledalsim_lib\altera_mf_87.vhd (1) |
| Low-level Primitives | <Quartus II installation directory>\ledalsim_lib\altera_primitives_components.vhd<br><Quartus II installation directory>\ledalsim_lib\altera_primitives.vhd                                                          |

**Table 2–7. RTL Functional Simulation Library Files in the Quartus II Directory (VHDL) (Part 2 of 2)**

| RTL Simulation Model                    | Location in Quartus II Directory Structure                                                                                                      |
|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| ALTGXBX<br>Megafunction<br>(Stratix GX) | <Quartus II installation directory>\ledasim_lib\stratixgx_mf_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixgx_mf.vhd |

**Note to Table 2–7:**

- Simulating a design that uses VHDL-1987.

Table 2–8 shows the Verilog RTL simulation model location in the Quartus II directory.

**Table 2–8. RTL Functional Simulation Library Files in the Quartus II Directory (Verilog)**

| RTL Simulation Model                 | Location in Quartus II Directory Structure                          |
|--------------------------------------|---------------------------------------------------------------------|
| LPM                                  | <Quartus II installation directory>\ledasim_lib\220model.v          |
| Altera Megafunction                  | <Quartus II installation directory>\ledasim_lib\altera_mf.v         |
| Low-level Primitives                 | <Quartus II installation directory>\ledasim_lib\altera_primitives.v |
| ALTGXBX Megafunction<br>(Stratix GX) | <Quartus II installation directory>\ledasim_lib\stratixgx_mf.v      |

**Gate-Level Simulation Library Files**

Table 2–9 shows the VHDL gate-level simulation model location in the Quartus II directory.

**Table 2–9. Gate-Level Timing Simulation Library Files in Quartus II Software (VHDL) (Part 1 of 2)**

| Device Simulation Model              | Location in Quartus II Directory Structure                                                                                                                        |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Arria GX (without transceiver block) | <Quartus II installation directory>\ledasim_lib\arriagx_components.vhd<br><Quartus II installation directory>\ledasim_lib\arriagx_atoms.vhd                       |
| Arria GX (with transceiver block)    | <Quartus II installation directory>\ledasim_lib\arriagx_hssi_components.vhd<br><Quartus II installation directory>\ledasim_lib\arriagx_hssi_atoms.vhd             |
| Stratix IV                           | <Quartus II installation directory>\ledasim_lib\stratixiv_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixiv_atoms.vhd                   |
| Stratix IV (with transceiver block)  | <Quartus II installation directory>\ledasim_lib\stratixiv_hssi_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixiv_hssi_atoms.vhd         |
| Stratix IV (with PCI Express)        | <Quartus II installation directory>\ledasim_lib\stratixiv_pcie_hip_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixiv_pcie_hip_atoms.vhd |

**Table 2–9. Gate-Level Timing Simulation Library Files in Quartus II Software (VHDL) (Part 2 of 2)**

| Device Simulation Model                   | Location in Quartus II Directory Structure                                                                                                                    |
|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Stratix III                               | <Quartus II installation directory>\ledasim_lib\stratixiii_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixiii_atoms.vhd             |
| Stratix II                                | <Quartus II installation directory>\ledasim_lib\stratixii_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixii_atoms.vhd               |
| Stratix II GX (without transceiver block) | <Quartus II installation directory>\ledasim_lib\stratixiigx_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixiigx_atoms.vhd           |
| Stratix II GX (with transceiver block)    | <Quartus II installation directory>\ledasim_lib\stratixiigx_hssi_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixiigx_hssi_atoms.vhd |
| Stratix                                   | <Quartus II installation directory>\ledasim_lib\stratix_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratix_atoms.vhd                   |
| Stratix GX                                | <Quartus II installation directory>\ledasim_lib\stratixgx_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixgx_atoms.vhd               |
| Stratix GX (with transceiver block)       | <Quartus II installation directory>\ledasim_lib\stratixgx_hssi_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixgx_hssi_atoms.vhd     |
| Cyclone II                                | <Quartus II installation directory>\ledasim_lib\cycloneii_components.vhd<br><Quartus II installation directory>\ledasim_lib\cycloneii_atoms.vhd               |
| Cyclone                                   | <Quartus II installation directory>\ledasim_lib\cyclone.vhd<br><Quartus II installation directory>\ledasim_lib\cyclone_atoms.vhd                              |
| MAX II                                    | <Quartus II installation directory>\ledasim_lib\maxii_components.vhd<br><Quartus II installation directory>\ledasim_lib\maxii_atoms.vhd                       |
| MAX 7000 and MAX 3000                     | <Quartus II installation directory>\ledasim_lib\max_components.vhd<br><Quartus II installation directory>\ledasim_lib\max_atoms.vhd                           |
| APEX II                                   | <Quartus II installation directory>\ledasim_lib\apexii_components.vhd<br><Quartus II installation directory>\ledasim_lib\apexii_atoms.vhd                     |
| APEX 20K                                  | <Quartus II installation directory>\ledasim_lib\apex20k_components.vhd<br><Quartus II installation directory>\ledasim_lib\apex20k_atoms.vhd                   |
| APEX 20KC, APEX 20KE, and Excalibur       | <Quartus II installation directory>\ledasim_lib\apex20ke_components.vhd<br><Quartus II installation directory>\ledasim_lib\apex20ke_atoms.vhd                 |
| FLEX 10KE and ACEX 1K                     | <Quartus II installation directory>\ledasim_lib\flex10ke_components.vhd<br><Quartus II installation directory>\ledasim_lib\flex10ke_atoms.vhd                 |

Table 2–10 shows the Verilog gate-level simulation model location in Quartus II directory.

| <b>Table 2–10. Gate-Level Timing Simulation Library Files in the Quartus II Software (Verilog)</b> |                                                                            |
|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|
| <b>Device Simulation Model</b>                                                                     | <b>Location in Quartus II Directory Structure</b>                          |
| Arria GX (without transceiver block)                                                               | <Quartus II installation directory>\eda\sim_lib\arriagx_atoms.v            |
| Arria GX (with transceiver block)                                                                  | <Quartus II installation directory>\eda\sim_lib\arriagx_hssi_atoms.v       |
| Stratix IV                                                                                         | <Quartus II installation directory>\eda\sim_lib\stratixiv_atoms.v          |
| Stratix IV (with transceiver block)                                                                | <Quartus II installation directory>\eda\sim_lib\stratixiv_hssi_atoms.v     |
| Stratix IV (with PCI Express)                                                                      | <Quartus II installation directory>\eda\sim_lib\stratixiv_pcie_hip_atoms.v |
| Stratix III                                                                                        | <Quartus II installation directory>\eda\sim_lib\stratixiii_atoms.v         |
| Stratix II                                                                                         | <Quartus II installation directory>\eda\sim_lib\stratixii_atoms.v          |
| Stratix II GX (without transceiver block)                                                          | <Quartus II installation directory>\eda\sim_lib\stratixiigx_atoms.v        |
| Stratix II GX (with transceiver block)                                                             | <Quartus II installation directory>\eda\sim_lib\stratixiigx_hssi_atoms.v   |
| Stratix                                                                                            | <Quartus II installation directory>\eda\sim_lib\stratix_atoms.v            |
| Stratix GX                                                                                         | <Quartus II installation directory>\eda\sim_lib\stratixgx_atoms.v          |
| Stratix GX (with transceiver block)                                                                | <Quartus II installation directory>\eda\sim_lib\stratixgx_hssi_atoms.v     |
| Cyclone II                                                                                         | <Quartus II installation directory>\eda\sim_lib\cycloneii_atoms.v          |
| Cyclone                                                                                            | <Quartus II installation directory>\eda\sim_lib\cyclone_atoms.v            |
| MAX II                                                                                             | <Quartus II installation directory>\eda\sim_lib\maxii_atoms.v              |
| MAX 7000 and MAX 3000                                                                              | <Quartus II installation directory>\eda\sim_lib\max_atoms.v                |
| APEX II                                                                                            | <Quartus II installation directory>\eda\sim_lib\apexii_atoms.v             |
| APEX 20K                                                                                           | <Quartus II installation directory>\eda\sim_lib\apex20k_atoms.v            |
| APEX 20KC, APEX 20KE, and Excalibur                                                                | <Quartus II installation directory>\eda\sim_lib\apex20ke_atoms.v           |
| FLEX 10KE and ACEX 1K                                                                              | <Quartus II installation directory>\eda\sim_lib\flex10ke_atoms.v           |

## Simulation Netlist Files

Simulation netlist files are required to perform post-synthesis simulation or gate-level timing simulation. These simulation netlist files are generated from the EDA Netlist Writer.

If you're performing post-synthesis simulation, the Verilog Output File (\*.**vo**) or VHDL Output File (\*.**vho**) is required. The “[Generate Post-Synthesis Simulation Netlist Files](#)” on page 2-13 section shows you the steps to generate post-synthesis simulation netlist files for \*.**vo** or \*.**vho** files.

If you're performing gate-level timing simulation, not only the \*.**vo** file or \*.**vho** file is required, but the Standard Delay Format Output File (\*.**sdo**) is also required. The \*.**sdo** file is used to annotate the delay for the elements found in the \*.**vo** or \*.**vho** file. The section, “[Generate Gate-Level Timing Simulation Netlist Files](#)” on page 2-15, shows you the steps to generate simulation netlist files for \*.**vo** or \*.**vho**, and \*.**sdo** files.

### Generate Post-Synthesis Simulation Netlist Files

The following steps describe the process of generating post-synthesis simulation netlist files in the Quartus II software:

1. Perform Analysis and Synthesis. On the Processing menu, point to **Start** and click **Start Analysis and Synthesis** (you can also perform this after step 2).
2. Turn on the **Generate Netlist for Functional Simulation Only** option by performing the following steps:
  - a. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
  - b. In the **Category** list, select **Simulation**. The **Simulation** page appears.
  - c. In the **Tool name** list:
    - If you are using ModelSim-Altera software, select **ModelSim-Altera**.
    - If you are using Mentor Graphics ModelSim software, select **ModelSim**.
  - d. Under **EDA Netlist Writer options**, in the **Format for output netlist** list, select **VHDL** or **Verilog**. You can also modify where you want the post-synthesis netlist generated by editing or browsing to a directory in the **Output directory** box.

- e. Click **More Settings**. The **More EDA Tools Simulation Settings** dialog box appears. In the **Existing options** settings list, click **Generate Netlist for Functional Simulation Only** and select **On** from the **Setting** list under **Options**.
  - f. Click **OK**.
  - g. In the **Settings** dialog box, click **OK**.
3. Run the EDA Netlist Writer. On the Processing menu, point to **Start** and click **Start EDA Netlist Writer**.

During the EDA Netlist Writer stage, the Quartus II software produces a **\*.vo** file or **\*.vho** file that can be used for post-synthesis simulations in the ModelSim software. This netlist file is mapped to architecture-specific primitives. No timing information is included at this stage. The resulting netlist is located in the output directory you specified in the **Settings** dialog box, which defaults to the `<project directory>/simulation/modelsim` directory.

If you want to generate a post-synthesis simulation netlist with just the cell delays, you can generate a **\*.sdo** file without running the fitter. In this case, the **\*.sdo** file includes all timing values for only the device cells. Interconnect delays are not included because fitting (placement and routing) has not been performed. To generate the post-synthesis netlist and the **\*.sdo** file, type the following commands at a command prompt:

```
quartus_map <project name> -c <revision name> ↵
quartus_sta <project name> -c <revision name> --post_map \
--zero_ic_delays ↵
or
quartus_tan <project name> -c <revision name> --post_map \
--zero_ic_delays ↵

quartus_eda <project name> -c <revision name> --simulation \
--tool= <3rd party EDA tool> --format=<HDL language> ↵
```

For more information on the **-format** and **-tool** options, type the following command at a command prompt:

```
quartus_eda -help=<options> ↵
```

## Generate Gate-Level Timing Simulation Netlist Files

To perform gate-level timing simulation, the ModelSim or ModelSim-Altera software requires information about how the design was placed into device-specific architectural blocks. The Quartus II software provides this information in the form of a **\*.vo** file for Verilog HDL designs and a **\*.vho** file for VHDL designs. The accompanying timing information is stored in the **\*.sdo** file, which annotates the delay for the elements found in the **\*.vo** file or **\*.vho** file.

The following steps describe the process of generating a gate-level timing simulation netlist in the Quartus II software:

1. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
2. In the **Category** list, click the “+” icon to expand **EDA Tool Settings** and select **Simulation**. The **Simulation** page appears.
3. In the **Tool name** list:
  - If you are using ModelSim-Altera software, select **ModelSim-Altera**.
  - If you are using Mentor Graphics ModelSim software, select **ModelSim**.
4. Under **EDA Netlist Writer options**, in the **Format for output netlist** list, select **VHDL** or **Verilog**. You can also modify where you want the post-synthesis netlist generated by editing or browsing to a directory in the **Output directory** box.
5. Click **OK**.
6. In the **Settings** dialog box, click **OK**.
7. If you have not run a full compilation, perform a full compilation. On the Processing menu, click **Start Compilation**.
8. If you have already run a full compilation, run the EDA Netlist Writer. On the Processing menu, point to **Start** and click **Start EDA Netlist Writer**.

During the full compilation or EDA Netlist Writer stage, the Quartus II software produces a **\*.vo** file, **\*.vho** file, and a **\*.sdo** file used for gate-level timing simulations in the ModelSim software. This netlist file is mapped to architecture-specific primitives. The

timing information for the netlist is included in the **\*.sdo** file. The resulting netlist is located in the output directory you specified in the **Settings** dialog box, which defaults to the `<project directory>/simulation/modelsim` directory.

### Generating Timing Simulation Netlist Files with Different Timing Models

In Stratix III and later devices (for example, Cyclone III and Stratix IV), you can specify different temperature and voltage parameters to generate the timing simulation netlist files. If you enable the Quartus II Classic or Quartus II TimeQuest Timing Analyzer when generating the timing simulation netlist files (**\*.vo** or **\*.vho** and **\*.sdo**), different timing models for different operating conditions are used by default. Multicorner timing analysis is run by default during the full compilation.

Table 2-11 shows an example of default-available operation conditions (model, voltage, and temperature) for Stratix III and Cyclone III devices.

| <b>Table 2-11. Default Available Operating Condition for Stratix III and Cyclone III Devices</b> |              |                |                        |
|--------------------------------------------------------------------------------------------------|--------------|----------------|------------------------|
| <b>Device Family</b>                                                                             | <b>Model</b> | <b>Voltage</b> | <b>Temperature (C)</b> |
| Stratix III                                                                                      | Slow         | 1100 mV        | 85°                    |
|                                                                                                  | Slow         | 1100 mV        | 0°                     |
|                                                                                                  | Fast         | 1100 mV        | 0°                     |
| Cyclone III                                                                                      | Slow         | 1200 mV        | 85°                    |
|                                                                                                  | Slow         | 1200 mV        | 0°                     |
|                                                                                                  | Fast         | 1200 mV        | 0°                     |

If multicorner timing analysis is not run during full compilation, perform the following steps to manually generate the simulation netlist files (**\*.vo** or **\*.vho** and **\*.sdo**) for the three different operating conditions listed in Table 2-11:

1. Generate all the available corner models at all operating conditions. Type the following command at a command prompt:

```
quartus_sta <project name> --multicorner ↵
```

2. Generate the timing simulation netlist files for all three corners specified in Table 2-11. Perform steps 2 through 8 in “[Generate Gate-Level Timing Simulation Netlist Files](#)” on page 2-15. The output files are generated in the simulation output directory.

The following examples show the timing simulation netlist files generated for the operating conditions of the preceding steps, when **Verilog** is selected as the output netlist format:

**First slow corner (slow, 1100 mV, 85° C):**

VO file— *<revision name>.vo*

SDO file— *<revision name>\_v.sdo*



The *<revision name>.vo* and *<revision name>\_v.sdo* are generated for backward compatibility in case there are existing scripts that still use them.

VO file— *<revision name>\_<speedgrade>\_1100mv\_85c\_slow.vo*

SDO file— *<revision name>\_<speedgrade>\_1100mv\_85c\_v\_slow.sdo*

**Second slow corner (slow, 1100 mV, 0° C):**

VO file— *<revision name>\_<speedgrade>\_1100mv\_0c\_slow.vo*

SDO file— *<revision name>\_<speedgrade>\_1100mv\_0c\_v\_slow.sdo*

**Fast corner (fast, 1100 mV, 0° C):**

VO file— *<revision name>\_min\_1100mv\_0c\_fast.vo*

SDO file— *<revision name>\_min\_1100mv\_0c\_v\_fast.sdo*

For older devices, a slow-corner (worst case) timing model is used by default. There are only two timing models available: slow-corner and fast-corner. To generate the timing simulation netlist files using a different timing model, you must run the Quartus II Classic or the Quartus II TimeQuest Timing Analyzer with a different timing model before you start the EDA Netlist writer.

To run the Quartus II Classic Timing Analyzer with the best-case model, on the Processing menu, point to **Start** and click **Start Classic Timing Analyzer (Fast Timing Model)**. After timing analysis is complete, the Compilation Report appears. You can also type the following command at a command prompt:

```
quartus_tan <project_name> --fast_model=on ↵
```

To run the Quartus II TimeQuest Timing Analyzer with a best-case model, use the **-fast\_model** option after you create the timing netlist. The following command enables the fast timing models:

```
create_timing_netlist --fast_model ↵
```

After running the Quartus II Classic or Quartus II TimeQuest Timing Analyzer, perform steps 2 through 8 in [“Generate Gate-Level Timing Simulation Netlist Files” on page 2–15](#) to generate the timing simulation netlist file. For fast corner timing models, the -fast post fix is added to the \*.vo or \*.vho, and \*.sdo file (for example, **my\_project\_fast.vo** or **my\_project\_fast.vho**, and **my\_project\_fast.sdo**).



For more information about running multi-corner timing analysis, refer to the *Quartus II Classic Timing Analyzer* or the *Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

## Disable Timing Violation on Registers

In certain situations, timing violation can be ignored and you might want to disable timing violations on registers. For example, timing violations that occur in internal synchronization registers used for asynchronous clock domain crossing.

By default, the **x\_onViolationOption** logic option is **On**, which means simulation shows “x” whenever a timing violation occurs. To disable showing the timing violation on certain registers, set the **x\_onViolationOption** logic option to **Off** on those registers. The following command is an example of the .qsf file.

```
set_instance_assignment -name X_ON_VIOLATION_OPTION \
OFF -to <register_name>
```

## Perform Simulation Using ModelSim-Altera Software

Simulation of Verilog HDL or VHDL designs with Modelsim-Altera software can be done at various levels to verify designs from different aspects. It is divided into three categories: RTL functional simulation, post-synthesis simulation, and gate-level timing simulation. Simulation helps you verify your designs and debug them against any possible errors the designs may have.

You can perform the simulation through GUI or Command-line. The following sections provide step-by-step instructions to perform the simulation through the GUI and Command-line. You can proceed to the specific section that meets your needs.

### Simulating the VHDL Designs (Through GUI)

Simulating the VHDL design using the ModelSim-Altera GUI is user friendly. You do not need to remember the commands to compile the libraries, or load and simulate the VHDL design files. You can go through the ModelSim-Altera GUI to perform RTL functional simulation,

post-synthesis simulation, and gate-level timing simulation. The following sections show how to perform simulation at various levels through the ModelSim-Altera GUI.

### *Perform RTL Functional Simulation*

RTL functional simulation is typically performed to verify the syntax of the code and to check the functionality of the design. The following sections show how to perform RTL functional simulation in the ModelSim-Altera software for VHDL designs.

Use the following instructions to perform a RTL functional simulation for VHDL designs in the ModelSim-Altera software.



The ModelSim-Altera software comes with pre-compiled simulation libraries. Creating simulation libraries and compiling simulation models are not required.

### **Compile Testbench and Design Files into the Work Library**

The following instructions show you how to compile your testbench and design files into the work library using the Modelsim-Altera GUI.

1. In the Modelsim-Altera software, on the File Menu, click **Change Directory**. The **Choose Folder** dialog box appears.
2. Browse to the directory where your designs are located.
3. Click **OK**.

Perform the following steps to create the work library:

1. In the ModelSim-Altera software, on the File menu, point to **New** and click **Library**. The **Create a New Library** dialog box appears.
2. Select a new library and a logical mapping to it.
3. In the **Library Name** box, type the library name **“Work”** in the text box.
4. Click **OK**.

Perform the following steps to compile the testbench and design files into the work library:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.

2. Select the library **Work**. The design files and testbench file should be compiled into the **Work** library.
3. Select the designs files and testbench file, and click **Compile**.
4. Click **Done**.



Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following steps:

1. On the Simulate menu, click **Start Simulation**. The **Start Simulation** dialog box appears.
2. In the **Start Simulation** dialog box, click the **Design** tab. In the **Resolution** list, select **ps**.
3. In the **Library** list, select and expand the **Work** library.
4. Select the top-level design unit (your testbench).
5. In the **Resolution** list, select **ps**.
6. Click the **Libraries** tab.
7. In the **Search Libraries (-L)** text box, click the **add** button to browse to the required pre-compiled library in the Modelsim-Altera software, (that is, *<Modelsim-Altera installation directory>/altera/vhdl/<pre-compiled library>*) and click **OK** to add them into the **Search Libraries (-L)** text box.



Examples of *<pre-compiled library>* are **altera\_mf** and **lpm**. The functional RTL simulation libraries are usually required for performing RTL functional simulation. For the complete set of libraries, refer to “[Pre-Compiled Simulation Libraries in Modelsim-Altera Software](#)” on page 2-5.

8. Click **OK**.

### Running the Simulation

Perform the following steps to run a simulation:

1. On the View menu, point to **Debug Windows** and click **Objects**. This command displays all objects in the current scope.
2. On the View menu, point to **Debug Windows** and click **Wave**.

3. Drag signals to monitor from the **Objects** window and drop them into the **Wave** window.
4. On the Simulating menu, point to **Run** and click **Run 100 ps** to run the simulation for 100 ps.

### *Perform Post-Synthesis Simulation*

Post-synthesis simulation can be done to verify that functionality of the design is not lost after synthesis. You can create the post-synthesis netlist in the Quartus II software and use the netlist to perform post-synthesis simulation with the ModelSim-Altera software.

Before running post-synthesis simulation, generate post-synthesis simulation netlist files. Refer to the instructions in “[Generate Post-Synthesis Simulation Netlist Files](#)” on page 2–13.

The following sections help you perform a post-synthesis simulation for a VHDL design in the ModelSim-Altera software.



The ModelSim-Altera software comes with pre-compiled simulation libraries. Creating simulation libraries and compiling simulation models are not required.

### **Compile Testbench and VHDL Output File into the Work Library**

The following instructions show how you can compile your testbench and **\*.vho** file into the work library using the ModelSim-Altera GUI.

Perform the following steps to change to the simulation output directory:

1. In the Modelsim-Altera software, on the File Menu, click **Change Directory**. The **Choose Folder** dialog box appears.
2. Browse to the directory where your testbench or **\*.vho** file is located. By default, the **\*.vho** file is located at *<project directory>/simulation/modelsim*.
3. Click **OK**.

Perform the following steps to create the work library:

1. In the ModelSim-Altera software, on the File menu, point to **New** and click **Library**. The **Create a New Library** dialog box appears.

2. Select a new library and a logical mapping to it.
3. In the **Library Name** box, type the library name “**Work**” in the text box.
4. Click **OK**.

Perform the following steps to compile the testbench and VHDL output (\*.vho) files into the work library:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.
2. Select the library **Work**. The testbench and VHDL output (\*.vho) files should be compiled into the **Work** library.
3. Select the testbench and \*.vho design files, and click **Compile**.
4. Click **Done**.



Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following steps:

1. On the Simulate menu, click **Start Simulation**. The **Start Simulation** dialog box appears.
2. In the **Start Simulation** dialog box, click the **Design** tab. In the **Resolution** list, select **ps**.
3. In the **Library** list, select and expand the **Work** library.
4. Select the top-level design unit (your testbench).
5. In the **Resolution** list, select **ps**.
6. Click the **Libraries** tab.
7. In the **Search Libraries (-L)** text box, click the **add** button to browse to the required pre-compiled library in the Modelsim-Altera software, (that is, <Modelsim-Altera installation directory>/altera/vhdl/<pre-compiled library>) and click **OK** to add them into the **Search Libraries (-L)** text box.



Examples of *<pre-compiled library>* are **stratixiii**, **stratixii**, and **stratixiigx**. Gate-level libraries are usually required for performing post-synthesis simulation. For the complete set of libraries, refer to ["Pre-Compiled Simulation Libraries in Modelsim-Altera Software" on page 2-5](#).

8. Click **OK**.

### Running the Simulation

Perform the following steps to run a simulation:

1. On the View menu, point to **Debug Windows** and click **Objects**. This command displays all objects in the current scope.
2. On the View menu, point to **Debug Windows** and click **Wave**.
3. Drag signals to monitor from the **Objects** window and drop them into the **Wave** window.
4. On the Simulating menu, point to **Run** and click **Run 100 ps** to run the simulation for 100 ps.

### Perform Gate-Level Simulation

Gate-level simulation is a very important step in ensuring that the FPGA device's functionality is still correct and meets all required timing requirements after the design was placed and routed. You can create the gate-level netlist in the Quartus II software and use the netlist to perform gate-level simulation with the ModelSim-Altera software.

Before running gate-level simulation, generate gate-level timing simulation netlist files. Refer to the instructions in ["Generate Gate-Level Timing Simulation Netlist Files" on page 2-15](#).

The following sections help you perform a gate-level simulation for a VHDL design in the ModelSim-Altera software.



The ModelSim-Altera software comes with pre-compiled simulation libraries. Creating simulation libraries and compiling simulation models are not required.

### Compile Testbench and VHDL Output File into the Work Library

The following instructions show how you can compile your testbench and **\*.vho** file into the work library using the ModelSim-Altera GUI.

Perform the following steps to change to the simulation output directory:

1. In the Modelsim-Altera software, on the File Menu, click **Change Directory**. The **Choose Folder** dialog box appears.
2. Browse to the directory where your testbench or **\*.vho** file is located. By default, the **\*.vho** file is located at *<project directory>/simulation/modelsim*.
3. Click **OK**.

Perform the following steps to create the work library:

1. In the ModelSim-Altera software, on the File menu, point to **New** and click **Library**. The **Create a New Library** dialog box appears.
2. Select a new library and a logical mapping to it.
3. In the **Library Name** box, type the library name “**Work**” in the text box.
4. Click **OK**.

Perform the following steps to compile the testbench and VHDL output (**\*.vho**) files into the work library:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.
2. Select the library **Work**. The testbench and VHDL output (**\*.vho**) files should be compiled into the **Work** library.
3. Select the testbench and VHDL output (**\*.vho**) design files, and click **Compile**.
4. Click **Done**.



Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following steps:

1. On the Simulate menu, click **Start Simulation**. The **Start Simulation** dialog box appears.

2. Click the **SDF** tab, and click **Add**. The **Add SDF Entry** dialog box appears.
3. In the **Add SDF Entry** dialog box, click **Browse** and select the **\*.sdo** file. By default the **\*.sdo** file is located at *<project directory>/simulation/modelsim*.
4. In the **Apply to Region** dialog box, type the instance path to which the **\*.sdo** file is to be applied. For example, if you are using a testbench exported into the Quartus II software from a Vector Waveform File, the instance path is set to **/i1**.



You do not have to choose from the **Delay** list because the Quartus II EDA Netlist Writer generates the **\*.sdo** file using the same value for the triplet (minimum, typical, and maximum timing values).

5. Click **OK**.
6. In the **Start Simulation** dialog box, click the **Design** tab. In the **Resolution** list, select **ps**.
7. In the **Library** list, select and expand the **Work** library.
8. Select the top-level design unit (your testbench).
9. In the **Resolution** list, select **ps**.
10. Click the **Libraries** tab.
11. In the **Search Libraries (-L)** text box, click the **add** button to browse to the required pre-compiled library in the Modelsim-Altera software, (that is, *<Modelsim-Altera installation directory>/altear/vhdl/<pre-compiled library>*) and click **OK** to add them into the **Search Libraries (-L)** text box.



Examples of *<pre-compiled library>* are **stratixiii**, **stratixii**, and **stratixiigx**. Gate-level libraries are usually required for performing gate-level timing simulation. For the complete set of libraries, refer to “[Pre-Compiled Simulation Libraries in Modelsim-Altera Software](#)” on page 2–5.

12. Click **OK**.

### Running the Simulation

Perform the following steps to run a simulation:

1. On the View menu, point to **Debug Windows** and click **Objects**. This command displays all objects in the current scope.
2. On the View menu, point to **Debug Windows** and click **Wave**.
3. Drag signals to monitor from the **Objects** window and drop them into the **Wave** window.
4. On the Simulating menu, point to **Run** and click **Run 100 ps** to run the simulation for 100 ps.

## Simulating the Verilog HDL Designs (Through GUI)

Simulating the Verilog HDL design using the ModelSim-Altera GUI is user friendly. You do not need to remember the commands to compile the libraries or load and simulate the Verilog HDL design files. You can go through the ModelSim-Altera GUI to perform RTL functional simulation, post-synthesis simulation, and gate-level timing simulation. The following sections show how to perform simulation at various levels through the ModelSim-Altera GUI.

### *Perform RTL Functional Simulation*

RTL functional simulation is typically performed to verify the syntax of the code and to check the functionality of the design. The following sections show how to perform RTL functional simulation in ModelSim-Altera for Verilog HDL designs.

Use the following instructions to perform a RTL functional simulation for Verilog HDL designs in the ModelSim-Altera software.



The ModelSim-Altera software comes with pre-compiled simulation libraries. Creating simulation libraries and compiling simulation models are not required.

### **Compile Testbench and Design Files into the Work Library**

The following instructions show you how to compile your testbench and design files into the work library using the Modelsim-Altera GUI.

Perform the following steps to change to the design directory:

1. In the Modelsim-Altera software, on the File Menu, click **Change Directory**. The **Choose Folder** dialog box appears.

2. Browse to the directory where your designs are located.
3. Click **OK**.

Perform the following steps to create the work library:

1. In the ModelSim-Altera software, on the File menu, point to **New** and click **Library**. The **Create a New Library** dialog box appears.
2. Select a new library and a logical mapping to it.
3. In the **Library Name** box, type the library name “**Work**” in the text box.
4. Click **OK**.

Perform the following steps to compile the testbench and design files into the work library:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.
2. Select the library **Work**. The design files and testbench file should be compiled into the **Work** library.
3. Select the designs files and testbench file, and click **Compile**.
4. Click **Done**.



Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following steps:

1. On the Simulate menu, click **Start Simulation**. The **Start Simulation** dialog box appears.
2. In the **Start Simulation** dialog box, click the **Design** tab. In the **Resolution** list, select **ps**.
3. In the **Library** list, select and expand the **Work** library.
4. Select the top-level design unit (your testbench).
5. In the **Resolution** list, select **ps**.

6. Click the **Libraries** tab.
7. In the **Search Libraries** (-L) text box, click the **add** button to browse to the required pre-compiled library in the Modelsim-Altera software, (that is, *<Modelsim-Altera installation directory>/altear/verilog/<pre-compiled library>*) and click **OK** to add them into the **Search Libraries** (-L) text box.



Examples of *<pre-compiled library>* are **altera\_mf\_ver** and **lpm\_ver**. The functional RTL simulation libraries are usually required for performing RTL functional simulation. For the complete set of libraries, refer to “[Pre-Compiled Simulation Libraries in Modelsim-Altera Software](#)” on page 2–5.

8. Click **OK**.

### Running the Simulation

Perform the following steps to run a simulation:

1. On the View menu, point to **Debug Windows** and click **Objects**. This command displays all objects in the current scope.
2. On the View menu, point to **Debug Windows** and click **Wave**.
3. Drag signals to monitor from the **Objects** window and drop them into the **Wave** window.
4. On the Simulating menu, point to **Run** and click **Run 100 ps** to run the simulation for 100 ps.

### Perform Post-Synthesis Simulation

Post-Synthesis simulation can be done to verify that functionality of the design is not lost after synthesis. You can create the post-synthesis netlist in the Quartus II software and use the netlist to perform Post-Synthesis simulation with the ModelSim-Altera software.

Before running post-synthesis simulation, generate post-synthesis simulation netlist files. Refer to the instructions in “[Generate Post-Synthesis Simulation Netlist Files](#)” on page 2–13.

The following sections help you perform a post-synthesis simulation for a Verilog HDL design in the ModelSim-Altera software.



The ModelSim-Altera software comes with pre-compiled simulation libraries. Creating simulation libraries and compiling simulation models are not required.

### Compile Testbench and Verilog HDL Output File into the Work Library

The following instructions show how you can compile your testbench and Verilog HDL output file (\*.vo) into the work library using the ModelSim-Altera GUI.

Perform the following steps to change to the simulation output directory:

1. In the Modelsim-Altera software, on the File Menu, click **Change Directory**. The **Choose Folder** dialog box appears.
2. Browse to the directory where your testbench or \*.vo file is located. By default, the \*.vho file is located at *<project directory>/simulation/modelsim*.
3. Click **OK**.

Perform the following steps to create the work library:

1. In the ModelSim-Altera software, on the File menu, point to **New** and click **Library**. The **Create a New Library** dialog box appears.
2. Select a new library and a logical mapping to it.
3. In the **Library Name** box, type the library name “**Work**” in the text box.
4. Click **OK**.

Perform the following steps to compile the testbench and Verilog HDL output (\*.vo) files into the work library:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.
2. Select the library **Work**. The testbench and Verilog HDL output (\*.vo) files should be compiled into the **Work** library.
3. Select the testbench and \*.vo design files, and click **Compile**.
4. Click **Done**.



Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following steps:

1. On the Simulate menu, click **Start Simulation**. The **Start Simulation** dialog box appears.
2. In the **Start Simulation** dialog box, click the **Design** tab. In the **Resolution** list, select **ps**.
3. In the **Library** list, select and expand the **Work** library.
4. Select the top-level design unit (your testbench).
5. In the **Resolution** list, select **ps**.
6. Click the **Libraries** tab.
7. In the **Search Libraries (-L)** text box, click the **add** button to browse to the required pre-compiled library in the Modelsim-Altera software, (that is, *<Modelsim-Altera installation directory>/altear/verilog/<pre-compiled library>*) and click **OK** to add them into the **Search Libraries (-L)** text box.



Examples of *<pre-compiled library>* are **stratixii\_ver**, **stratixii\_ver**, and **stratixiigx\_ver**. Gate-level libraries are usually required for performing post-synthesis simulation. For the complete set of libraries refer to “[Pre-Compiled Simulation Libraries in Modelsim-Altera Software](#)” on page 2–5.

8. Click **OK**.

### Running the Simulation

Perform the following steps to run a simulation:

1. On the View menu, point to **Debug Windows** and click **Objects**. This command displays all objects in the current scope.
2. On the View menu, point to **Debug Windows** and click **Wave**.
3. Drag signals to monitor from the **Objects** window and drop them into the **Wave** window.
4. On the Simulating menu, point to **Run** and click **Run 100 ps** to run the simulation for 100 ps.

### Perform Gate-Level Simulation

Gate-level simulation is a very important step in ensuring that the FPGA device's functionality is still correct and meets all required timing requirements after the design was placed and routed. You can create the gate-level netlist in the Quartus II software and use the netlist to perform gate-level simulation with the ModelSim-Altera software.

Before running gate-level simulation, generate gate-level timing simulation netlist files. Refer to the instructions in [“Generate Gate-Level Timing Simulation Netlist Files” on page 2-15](#).

The following sections help you perform a gate-level simulation for a Verilog HDL design in the ModelSim-Altera software.



The ModelSim-Altera software comes with pre-compiled simulation libraries. Creating simulation libraries and compiling simulation models are not required.

#### Compile Testbench and Verilog HDL Output File into the Work Library

The following instructions show how you can compile your testbench and `*.vo` file into the work library using the ModelSim-Altera GUI.

Perform the following steps to change to the simulation output directory:

1. In the Modelsim-Altera software, on the File Menu, click **Change Directory**. The **Choose Folder** dialog box appears.
2. Browse to the directory where your testbench or `*.vo` file is located. By default, the `*.vo` file is located at `<project directory>/simulation/modelsim`.
3. Click **OK**.

Perform the following steps to create the work library:

1. In the ModelSim-Altera software, on the File menu, point to **New** and click **Library**. The **Create a New Library** dialog box appears.
2. Select a new library and a logical mapping to it.
3. In the **Library Name** box, type the library name “**Work**” in the text box.
4. Click **OK**.

Perform the following steps to compile the testbench and \*.vo files into the work library:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.
2. Select the library **Work**. The testbench and \*.vo files should be compiled into the **Work** library.
3. Select the testbench and \*.vo design files, and click **Compile**.
4. Click **Done**.



Resolve compile-time errors before proceeding to the following section.

### Loading the Design

When simulating in Verilog HDL, the \*.sdo file does not have to be manually specified because in the Quartus II-generated \*.vo file, there is a **\$sdf\_annotation** task that the ModelSim-Altera software uses to look into the current directory, from which VSIM was run and uses to look for the \*.sdo file. If your \*.sdo file is not in the same directory from which you ran VSIM, copy the \*.sdo file into your current directory.

To load a design, perform the following steps:

1. On the Simulate menu, click **Start Simulation**. The **Start Simulation** dialog box appears.
2. In the **Start Simulation** dialog box, click the **Design** tab. In the **Resolution** list, select **ps**.
3. In the **Library** list, select and expand the **Work** library.
4. Select the top-level design unit (your testbench).
5. In the **Resolution** list, select **ps**.
6. Click the **Libraries** tab.
7. In the **Search Libraries (-L)** text box, click the **add** button to browse to the required pre-compiled library in the Modelsim-Altera software, (that is, *<Modelsim-Altera installation directory>/altera/verilog/<pre-compiled library>*) and click **OK** to add them into the **Search Libraries (-L)** text box.



Examples of *<pre-compiled library>* are **stratixii\_ver**, **stratixii\_ver**, and **stratixiigx\_ver**. The gate-level libraries are usually required for performing gate-level timing simulation. For the complete set of libraries, refer to “[Pre-Compiled Simulation Libraries in Modelsim-Altera Software](#)” on page 2-5.

8. Click **OK**.

### Running the Simulation

Perform the following steps to run a simulation:

1. On the View menu, point to **Debug Windows** and click **Objects**. This command displays all objects in the current scope.
2. On the View menu, point to **Debug Windows** and click **Wave**.
3. Drag signals to monitor from the **Objects** window and drop them into the **Wave** window.
4. On the Simulating menu, point to **Run** and click **Run 100 ps** to run the simulation for 100 ps.

### Simulating the VHDL Designs (Through Command-line)

Simulating VHDL design using the Modelsim-Altera command-line gives you more flexibility and control to compile the libraries, and load and simulate the VHDL design files. All these commands to perform simulation are Tcl commands which can be put into the Modelsim Macros file (\*.do). Using the \*.do file allows you to run simulation in batch mode. You only need to execute the \*.do file and the Modelsim-Altera tool automatically executes all the commands that are inside the \*.do script macro file.

You can go through the Modelsim-Altera command-line to perform RTL functional simulation, post-synthesis simulation, and gate-level simulation. The following sections show how to perform simulation at various levels through the Modelsim-Altera command-line.

#### *Perform RTL Functional Simulation*

RTL functional simulation is typically performed to verify the syntax of the code and to check the functionality of the design. The following sections show how to perform RTL functional simulation in ModelSim-Altera for VHDL designs.



The ModelSim-Altera software comes with pre-compiled simulation libraries. Creating simulation libraries and compiling simulation models are not required.

### Compile Testbench and Design Files into the Work Library

The following commands show how to compile your testbench and design files into the work library in the ModelSim-Altera command prompt.

Perform the following command to change to the design library:

```
cd <your_design_directory> ↵  
(for example, cd:/designs)
```

Perform the following command to create the work library:

```
vlib work ↵  
vmap work work ↵
```

Perform the following command to compile the testbench and design files into the work library:

```
vcom -work work <my_test_bench.vhd> <my_design_files.vhd> ↵
```



Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> work <my_test_bench> ↵
```



The *<library1>* and *<library2>* are the required libraries to compile your testbench. If you have multiple libraries, use the *-L* option multiple times in the *vsim* command.



Examples of *<pre-compiled library>* are **altera\_mf** and **lpm**. The functional RTL simulation libraries are usually required for performing RTL functional simulation. For the complete set of libraries, refer to “[Pre-Compiled Simulation Libraries in Modelsim-Altera Software](#)” on page 2-5.

## Running the Simulation

Perform the following commands to run a simulation:

```
add wave <signal name>
run <time period>
```



To add all signals in your testbench hierarchy, use the command:

```
"add wave *"
```

For example, to run the simulation for 100 ps, use the command:  
"run 100 ps"

## Perform Post-Synthesis Simulation

Post-synthesis simulation can be done to verify that functionality of the design is not lost after synthesis. You can create the post-synthesis netlist in the Quartus II software and use the netlist to perform post-synthesis simulation with the ModelSim-Altera software.

The following sections help you perform a post-synthesis simulation for a VHDL design in the ModelSim-Altera software.



The ModelSim-Altera software comes with pre-compiled simulation libraries. Creating simulation libraries and compiling simulation models are not required.

## Compile Testbench and VHDL Output File into the Work Library

Before running post-synthesis simulation, generate post-synthesis simulation netlist files. Refer to the instructions in “[Generate Post-Synthesis Simulation Netlist Files](#)” on page 2-13.

The following instructions show how to compile your testbench and \*.vho file into the work library using Modelsim-Altera GUI.

Perform the following command to change to the simulation output directory:

```
cd <simulation_output_directory>
(for example, cd:/designs/modelsim/simulation)
```



This directory contains the \*.vho file, which is generated by the netlist writer.

Perform the following commands to create the work library:

```
vlib work ↵  
vmap work work ↵
```

Perform the following command to compile the testbench and \*.vho files into the work library:

```
vcom -work work <my_test_bench.vhd> <my_design_netlists.vho> ↵
```

 Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> work <my_test_bench> ↵
```

 The <library1> and <library2> are the required libraries to compile your testbench. Examples of <pre-compiled library> are **stratixiii**, **stratixii**, and **stratixiigx**. Gate-level libraries are usually required for performing post-synthesis simulation. If you have multiple libraries, use the -L option multiple times in the vsim command. For the complete set of libraries, refer to “[Pre-Compiled Simulation Libraries in Modelsim-Altera Software](#)” on page 2–5.

### Running the Simulation

Perform the following commands to run a simulation:

```
add wave <signal name> ↵
```

```
run <time period> ↵
```

 To add all signals in your testbench hierarchy, use the command:

```
"add wave *"
```

For example, to run the simulation for 100 ps, use the command:  
“run 100 ps”

### Perform Gate-Level Simulation

Gate-level simulation is a very important step in ensuring that the FPGA device's functionality is still correct and meets all required timing requirements after the design was placed and routed. You can create the gate-level netlist in the Quartus II software and use the netlist to perform gate-level simulation with the ModelSim-Altera software.

The following sections help you perform a gate-level simulation for a VHDL design in the ModelSim-Altera software.



The ModelSim-Altera software comes with pre-compiled simulation libraries. Creating simulation libraries and compiling simulation models are not required.

#### Compile Testbench and VHDL Output File into the Work Library

Before running gate-level simulation, generate gate-level timing simulation netlist files. Refer to the instructions in “[Generate Gate-Level Timing Simulation Netlist Files](#)” on page 2-15.

The following instructions show how to compile your testbench and \*.vho file into the work library using Modelsim-Altera GUI.

Perform the following command to change to the simulation output directory:

```
cd <simulation_output_directory> ↵  
(for example, cd:/designs/modelsim/simulation)
```



This directory contains the \*.vho file, which is generated by the netlist writer.

Perform the following commands to create the work library:

```
vlib work ↵  
vmap work work ↵
```

Perform the following command to compile the testbench and \*.vho files into the work library:

```
vcom -work work <my_test_bench.vhd> <my_design_netlists.vho> ↵
```



Resolve compile-time errors before proceeding to the following section.

## Loading the Design

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> -sdftyp <design instance>= \  
<path to *.sdo file> work.<my_test_bench> ↵
```



The *<library1>* and *<library2>* are the required libraries to compile your testbench. Examples of pre-compiled libraries are **stratixiii**, **stratixii**, and **stratixiigx**. Gate-level libraries are usually required for performing gate-level timing simulation. If you have multiple libraries, use the **-L** option multiple times in the **vsim** command. For the complete set of libraries, refer to “[Pre-Compiled Simulation Libraries in Modelsim-Altera Software](#)” on page 2–5.



You do not need to set the value (Minimum, Average, Maximum) for the **\*.sdo** file because the Quartus II EDA Netlist Writer generates the **\*.sdo** file using the same value for the triplet (minimum, average, and maximum timing values).



If your design under test is instantiated in the testbench file under the **i1** label, then the *<design instance>* should be “*i1*” (for example, **/i1=<my design>.sdo**).

## Running the Simulation

Perform the following commands to run a simulation:

```
add wave <signal name> ↵
```

```
run <time period> ↵
```



To add all signals in your testbench hierarchy, use the command:

```
"add wave *"
```

For example, to run the simulation for 100 ps, use the command: “**run 100 ps**”

## Simulating the Verilog HDL Designs (Through Command-line)

Simulating Verilog HDL design using the Modelsim-Altera command-line gives you more flexibility and control to compile the libraries, and load and simulate the Verilog HDL design files. All these commands to perform simulation are Tcl commands which can be put into the Modelsim Macros file (**\*.do**). Using the **\*.do** file allows you to run simulation in batch mode. You only need to execute the **\*.do** file and the Modelsim-Altera tool automatically executes all the commands that are inside the **\*.do** script macro file.

You can go through the Modelsim-Altera command-line to perform the RTL functional simulation, post-synthesis simulation, and gate-level simulation. The following sections show how to perform simulation at various levels through the Modelsim-Altera command-line.

### Perform RTL Functional Simulation

RTL functional simulation is typically performed to verify the syntax of the code and to check the functionality of the design. The following sections show how to perform RTL functional simulation in ModelSim-Altera for Verilog HDL designs.

 The ModelSim-Altera software comes with pre-compiled simulation libraries. Creating simulation libraries and compiling simulation models are not required.

### Compile Testbench and Design Files into the Work Library

The following commands show how to compile your testbench and design files into the work library in the ModelSim-Altera command prompt.

Perform the following command to change to the design library:

```
cd <your_design_directory> ←  
(for example, cd:/designs)
```

Perform the following command to create the work library:

```
vlib work ←  
vmap work work ←
```

Perform the following command to compile the testbench and design files into the work library:

```
vlog -work work <my_test_bench.v> <my_design_files.v> ←
```

 Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> work.<my_test_bench> ←
```



The *<library1>* and *<library2>* are the required libraries to compile your testbench. If you have multiple libraries, use the **-L** option multiple times in the **vsim** command.



Examples of *<pre-compiled library>* are **altera\_mf\_ver** and **lpm\_ver**. The functional RTL simulation libraries are usually required for performing RTL functional simulation. For the complete set of libraries, refer to [“Pre-Compiled Simulation Libraries in Modelsim-Altera Software” on page 2–5](#).

### Running the Simulation

Perform the following commands to run a simulation:

```
add wave <signal name>
run <time period>
```



To add all signals in your testbench hierarchy, use the command:

```
"add wave *" ↵
```

For example, to run the simulation for 100 ps, use the command:  
 "run 100 ps" ↵

### Perform Post-Synthesis Simulation

Post-synthesis simulation can be done to verify that functionality of the design is not lost after synthesis. You can create the post-synthesis netlist in the Quartus II software and use the netlist to perform post-synthesis simulation with the ModelSim-Altera software.

The following sections help you perform a post-synthesis simulation for a Verilog HDL design in the ModelSim-Altera software.



The ModelSim-Altera software comes with pre-compiled simulation libraries. Creating simulation libraries and compiling simulation models are not required.

### Compile Testbench and Verilog Output File into the Work Library

Before running post-synthesis simulation, generate post-synthesis simulation netlist files. Refer to the instructions in [“Generate Post-Synthesis Simulation Netlist Files” on page 2–13](#).

The following instructions show how to compile your testbench and **\*.vo** file into the work library using Modelsim-Altera software.

Perform the following command to change to the simulation output directory:

```
cd <simulation_output_directory> ←  
(for example, cd:/designs/modelsim/simulation)
```

 This directory contains the **\*.vo** file, which is generated by the netlist writer.

Perform the following commands to create the work library:

```
vlib work ←  
vmap work work ←
```

Perform the following command to compile the testbench and **\*.v** files into the work library:

```
vlog -work work <my_test_bench.v> <my_design_netlists.vo> ←
```

 Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> work.<my_test_bench> ←
```

 The **<library1>** and **<library2>** are the required libraries to compile your testbench. Examples of **<pre-compiled library>** are **stratixiii\_ver**, **stratixii\_ver**, and **stratixiigx\_ver**. Gate-level libraries are usually required for performing post-synthesis simulation. If you have multiple libraries, use the **-L** option multiple times in the **vsim** command. For the complete set of libraries, refer to ["Pre-Compiled Simulation Libraries in Modelsim-Altera Software" on page 2-5](#).

### Running the Simulation

Perform the following commands to run a simulation:

```
add wave <signal name> ←  
run <time period> ←
```



To add all signals in your testbench hierarchy, use the command:

`"add wave *"`

For example, to run the simulation for 100 ps, use the command:  
`"run 100 ps"`

### *Perform Gate-Level Simulation*

Gate-level simulation is a very important step in ensuring that the FPGA device's functionality is still correct and meets all required timing requirements after the design was placed and routed. You can create the gate-level netlist in the Quartus II software and use the netlist to perform gate-level simulation with the ModelSim-Altera software.

The following sections help you perform a gate-level simulation for a Verilog HDL design in the ModelSim-Altera software.



The ModelSim-Altera software comes with pre-compiled simulation libraries. Creating simulation libraries and compiling simulation models are not required.

#### **Compile Testbench and Verilog Output File into the Work Library**

Before running gate-level simulation, generate gate-level timing simulation netlist files. Refer to the instructions in “[Generate Gate-Level Timing Simulation Netlist Files](#)” on page [2-15](#).

The following instructions show how to compile your testbench and `*.vo` file into the work library using Modelsim-Altera software.

Perform the following command to change to the simulation output directory:

```
cd <simulation_output_directory> ↵  
(for example, cd:/designs/modelsim/simulation)
```



This directory contains the `*.vho` file, which is generated by the netlist writer.

Perform the following commands to create the work library:

```
vlib work ↵  
vmap work work ↵
```

Perform the following command to compile the testbench and VHDL output (`*.vho`) files into the work library:

```
vlog -work work <my_test_bench.v> <my_design_netlists.vo> ↵
```



Resolve compile-time errors before proceeding to the following section.

### Loading the Design

When simulating in Verilog HDL, the **\*.sdo** file does not have to be manually specified because in the Quartus II-generated **\*.vo** file, there is a **\$sdf\_annotate** task that ModelSim uses to look into the current directory, from which VSIM was run and uses to look for the **\*.sdo** file. If your **\*.sdo** file is not in the same directory from which you ran VSIM, copy the **\*.sdo** file into your current directory.

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> work.<my_test_bench> ↵
```



The **<library1>** and **<library2>** are the required libraries to compile your testbench. Examples of pre-compiled libraries are **stratixiii\_ver**, **stratixii\_ver**, and **stratixiigx\_ver**. Gate-level libraries are usually required for performing gate-level timing simulation. If you have multiple libraries, use the **-L** option multiple times in the **vsim** command. For the complete set of libraries, refer to ["Pre-Compiled Simulation Libraries in Modelsim-Altera Software" on page 2-5](#).

### Running the Simulation

Perform the following commands to run a simulation:

```
add wave <signal name> ↵
```

```
run <time period> ↵
```



To add all signals in your testbench hierarchy, use the command:

```
"add wave *"
```

For example, to run the simulation for 100 ps, use the command:  
**"run 100 ps"**

## Perform Simulation Using Modelsim Software

Simulation of Verilog HDL or VHDL designs with Modelsim software can be done at various levels to verify designs from different aspects. It is divided into three categories: RTL functional simulation, post-synthesis simulation, and gate-level simulation. Simulation helps you verify your designs and debug them against any possible errors the designs may have.

You can perform the simulation through GUI or Command-line. The following sections provide step-by-step instructions to perform the simulation through the GUI and Command-line. You can proceed to the specific section that meets your needs.

## Simulating the VHDL Designs (Through GUI)

Simulating VHDL design using the Modelsim GUI is user friendly. You do not need to remember the commands to compile the libraries, or load and simulate the VHDL design files. You can go through the ModelSim GUI to perform RTL functional simulation, post-synthesis simulation, and gate-level timing simulation. The following sections show how to perform simulation at various levels through the ModelSim GUI.

### *Perform RTL Functional Simulation*

RTL functional simulation is typically performed to verify the syntax of the code and to check the functionality of the design. The following sections show how to perform RTL functional simulation in ModelSim for VHDL designs.

Use the following instructions to perform a RTL functional simulation for VHDL designs in the ModelSim software.

### **Create Simulation Libraries**

Simulation libraries are required to simulate a design that contains an Altera primitive, LPM function, or Altera megafunction. Depending on your design, you must create the required simulation libraries and link them to your design correctly.

Perform the following steps to change to the design directory:

1. In the Modelsim software, on the File Menu, click **Change Directory**. The **Choose Folder** dialog box appears.
2. Browse to the directory where your designs are located.
3. Click **OK**.

Perform the following steps to create the simulation library:

1. In the ModelSim software, on the File menu, point to **New** and click **Library**. The **Create a New Library** dialog box appears.
2. Select a new library and a logical mapping to it.

3. In the **Library Name** box, type the library name of the newly created library.



For example, the library name for Altera megafunctions is **altera\_mf**, and the library name for LPM is **lpm**. To see all the functional simulation library files, see “[RTL Functional Simulation Libraries](#)” on page 2–6.

4. Click **OK**.

### Compile Simulation Models into Simulation Libraries

Perform the following steps to compile simulation models into simulation libraries:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.
2. Select the library that you created (for example, **altera\_mf**, **lpm**).
3. Browse to the *<Quartus II installation directory>/eda/sim\_lib* and add the necessary simulation model files to your project. Select the simulation model files and click **Compile**.



The **altera\_mf\_components.vhd** and **altera\_mf.vhd** model files should be compiled into the **altera\_mf** library. The **220pack.vhd** and **220model.vhd** model files should be compiled into the **lpm** library.

4. Repeat step 2 and step 3 to compile other simulation models.
5. Click **Done**.

### Compile Testbench and Design Files into the Work Library

The following instructions show you how to compile your testbench and design files into the work library using the Modelsim GUI.

Perform the following steps to create the work library:

1. In the ModelSim software, on the File menu, point to **New** and click **Library**. The **Create a New Library** dialog box appears.
2. Select a new library and a logical mapping to it.
3. In the **Library Name** box, type the library name “**Work**” in the text box.
4. Click **OK**.

Perform the following steps to compile the testbench and design files into the work library:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.
2. Select the library **Work**. The design files and testbench file should be compiled into the **Work** library.
3. Select the design files and the testbench file, and click **Compile**.
4. Click **Done**.



Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following steps:

1. On the Simulate menu, click **Start Simulation**. The **Start Simulation** dialog box appears.
2. In the **Start Simulation** dialog box, click the **Design** tab. In the **Resolution** list, select **ps**.
3. In the **Library** list, select and expand the **Work** library.
4. Select the top-level design unit (your testbench).
5. In the **Resolution** list, select **ps**.
6. Click the **Libraries** tab.
7. In the **Search Libraries (-L)** text box, click the **add** button to browse to the required simulation library that you previously compiled (for example, **altera\_mf** or **lpm**, **altera**) and click **OK** to add them into the **Search Libraries (-L)** text box.
8. Click **OK**.

### Running the Simulation

Perform the following steps to run a simulation:

1. On the View menu, point to **Debug Windows** and click **Objects**. This command displays all objects in the current scope.
2. On the View menu, point to **Debug Windows** and click **Wave**.

3. Drag signals to monitor from the **Objects** window and drop them into the **Wave** window.
4. On the Simulating menu, point to **Run** and click **Run 100 ps** to run the simulation for 100 ps.

### *Perform Post-Synthesis Simulation*

Post-Synthesis simulation can be done to verify that functionality of the design is not lost after synthesis. You can create the post-synthesis netlist in the Quartus II software and use the netlist to perform post-synthesis simulation with the ModelSim software.

Before running post-synthesis simulation, generate post-synthesis simulation netlist files. Refer to the instructions in “[Generate Post-Synthesis Simulation Netlist Files](#)” on page 2–13.

The following sections help you perform a post-synthesis simulation for a VHDL design in the ModelSim software.

#### **Create Simulation Libraries**

Simulation libraries are required to simulate a design that is mapped to post-synthesis primitives. Depending on the device family you are using, you must create the required simulation libraries and link them to your design correctly.

Perform the following steps to change to the simulation output directory:

1. In the Modelsim software, on the File Menu, click **Change Directory**. The **Choose Folder** dialog box appears.
2. Browse to the directory where your testbench or **\*.vhd** file is located. By default, the **\*.vhd** file is located at *<project directory>/simulation/modelsim*.
3. Click **OK**.

Perform the following steps to create the simulation library:

1. In the ModelSim software, on the File menu, point to **New** and click **Library**. The **Create a New Library** dialog box appears.
2. Select a new library and a logical mapping to it.
3. In the **Library Name** box, type the library name of the newly created library.



For example, the library name for Stratix III family is **stratixiii**. To see all the gate-level timing simulation library files, refer to “Gate-Level Simulation Library Files” on page 2–10.

4. Click **OK**.

### Compile Simulation Models into Simulation Libraries

Perform the following steps to compile simulation models into simulation libraries:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.
2. Select the library that you created (for example, **stratixiii**).
3. Browse to the *<Quartus II installation directory>/eda/sim\_lib* and add the necessary simulation model files to your project. Select the simulation model files and click **Compile**.



The **stratixiii\_components.vhd** and **stratixiii.vhd** model files are compiled into the **stratixiii** library.

4. Repeat step 2 and step 3 to compile other simulation models.
5. Click **Done**.

### Compile Testbench and VHDL Output File into the Work Library

The following instructions show you how to compile your testbench and **\*.vho** file into the work library using the Modelsim GUI.

Perform the following steps to create the work library:

1. In the ModelSim software, on the File menu, point to **New** and click **Library**. The **Create a New Library** dialog box appears.
2. Select a new library and a logical mapping to it.
3. In the **Library Name** box, type the library name “**Work**” in the text box.
4. Click **OK**.

Perform the following steps to compile the testbench file and **\*.vho** file into the work library:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.

2. Select the library **Work**. The testbench and \*.vho file should be compiled into the **Work** library.
3. Select the testbench and \*.vho file design files, and click **Compile**.
4. Click **Done**.

### Loading the Design

To load a design, perform the following steps:

1. On the Simulate menu, click **Start Simulation**. The **Start Simulation** dialog box appears.
2. In the **Start Simulation** dialog box, click the **Design** tab. In the **Resolution** list, select **ps**.
3. In the **Library** list, select and expand the **Work** library.
4. Select the top-level design unit (your testbench).
5. In the **Resolution** list, select **ps**.
6. Click the **Libraries** tab.
7. In the **Search Libraries (-L)** text box, click the **add** button to browse to the required simulation library that you previously compiled (for example, **stratixiii** or **stratixiiigx**) and click **OK** to add them into the **Search Libraries (-L)** text box.
8. Click **OK**.

### Running the Simulation

Perform the following steps to run a simulation:

1. On the View menu, point to **Debug Windows** and click **Objects**. This command displays all objects in the current scope.
2. On the View menu, point to **Debug Windows** and click **Wave**.
3. Drag signals to monitor from the **Objects** window and drop them into the **Wave** window.
4. On the Simulating menu, point to **Run** and click **Run 100 ps** to run the simulation for 100 ps.

### Perform Gate-Level Simulation

Gate-level simulation is a very important step in ensuring that the FPGA device's functionality is still correct and meets all required timing requirements after the design was placed and routed. You can create the gate-level netlist in the Quartus II software and use the netlist to perform gate-level simulation with the ModelSim software.

Before running gate-level simulation, generate gate-level timing simulation netlist files. Refer to the instructions in [“Generate Gate-Level Timing Simulation Netlist Files” on page 2-15](#).

The following sections help you perform a gate-level simulation for a VHDL design in the ModelSim software.

#### Create Simulation Libraries

Simulation libraries are required to simulate a design that is mapped to post-synthesis primitives. Depending on the device family you are using, you must create the required simulation libraries and link them to your design correctly.

Perform the following steps to change to the simulation output directory:

1. In the Modelsim software, on the File Menu, click **Change Directory**. The **Choose Folder** dialog box appears.
2. Browse to the directory where your testbench or **\*.vhd** file is located. By default, the **\*.vhd** file is located at *<project directory>/simulation/modelsim*.
3. Click **OK**.

Perform the following steps to create the simulation library:

1. In the ModelSim software, on the File menu, point to **New** and click **Library**. The **Create a New Library** dialog box appears.
2. Select a new library and a logical mapping to it.
3. In the **Library Name** box, type the library name of the newly created library.



For example, the library name for Stratix III family is **stratixiii**. To see all the gate-level timing simulation library files, refer to [“Gate-Level Simulation Libraries” on page 2-7](#).

4. Click **OK**.

## Compile Simulation Models into Simulation Libraries

Perform the following steps to compile simulation models into simulation libraries:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.
2. Select the library that you created (for example, **stratixiii**).
3. Browse to the *<Quartus II installation directory>/eda/sim\_lib* and add the necessary simulation model files to your project. Select the simulation model files and click **Compile**.



The **stratixiii\_components.vhd** and **stratixiii.vhd** model files should be compiled into the **stratixiii** library.

4. Repeat step 2 and step 3 to compile other simulation models.
5. Click **Done**.

## Compile Testbench and Design Files into the Work Library

The following instructions show you how to compile your testbench and **\*.vhd** file into the work library using the Modelsim GUI.

Perform the following steps to create the work library:

1. In the ModelSim software, on the File menu, point to **New** and click **Library**. The **Create a New Library** dialog box appears.
2. Select a new library and a logical mapping to it.
3. In the **Library Name** box, type the library name “**Work**” in the text box.
4. Click **OK**.

Perform the following steps to compile the testbench file and **\*.vhd** file into the work library:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.
2. Select the library **Work**. The testbench and **\*.vhd** file should be compiled into the **Work** library.
3. Select the testbench and **\*.vhd** design files, and click **Compile**.

4. Click **Done**.

### Loading the Design

To load a design, perform the following steps:

1. On the Simulate menu, click **Start Simulation**. The **Start Simulation** dialog box appears.
2. Click the **SDF** tab and click **Add**.
3. In the **Add SDF Entry** dialog box, click **Browse** and select the **\*.sdo** file. By default, the **\*.sdo** file is located at *<project directory>/simulation/modelsim*.
4. In the **Apply to Region** dialog box, type in the instance path to which the **\*.sdo** file is to be applied. For example, if you are using a testbench exported into the Quartus II software from a Vector Waveform File, the instance path is set to **/i1**.

 You do not have to choose from the **Delay** list because the Quartus II EDA Netlist Writer generates the **\*.sdo** file using the same value for the triplet (minimum, typical, and maximum timing values).

5. Click **OK**.
6. Click the **Design** tab. In the **Resolution** list, select **ps**.
7. In the **Library** list, select the **Work** library.
8. In the **Start Simulation** dialog box, expand the **Work** library.
9. Select the top-level design unit (your testbench).
10. In the **Resolution** list, select **ps**.
11. Click the **Libraries** tab.
12. In the **Search Libraries (-L)** text box, click the **add** button to browse to the required simulation library that you previously compiled (for example, **stratixiii** or **stratixiiigx**) and click **OK** to add them into the **Search Libraries (-L)** text box.
13. Click **OK**.

### Running the Simulation

Perform the following steps to run a simulation:

1. On the View menu, point to **Debug Windows** and click **Objects**. This command displays all objects in the current scope.
2. On the View menu, point to **Debug Windows** and click **Wave**.
3. Drag signals to monitor from the **Objects** window and drop them into the **Wave** window.
4. On the Simulating menu, point to **Run** and click **Run 100 ps** to run the simulation for 100 ps.

## Simulating the Verilog HDL Designs (Through GUI)

Simulating Verilog HDL design using the Modelsim GUI is user friendly. You do not need to remember the commands to compile the libraries, or load and simulate the Verilog HDL design files. You can go through the ModelSim GUI to perform RTL functional simulation, post-synthesis simulation, and gate-level timing simulation. The following sections show how to perform simulation at various levels through the ModelSim GUI.

### *Perform RTL Functional Simulation*

RTL functional simulation is typically performed to verify the syntax of the code and to check the functionality of the design. The following sections show how to perform RTL functional simulation in ModelSim for Verilog HDL designs.

Use the following instructions to perform a RTL functional simulation for Verilog HDL designs in the ModelSim software.

### Create Simulation Libraries

Simulation libraries are required to simulate a design that contains an Altera primitive, LPM function, or Altera megafunction. Depending on your design, you must create the required simulation libraries and link them to your design correctly.

Perform the following steps to change to the design directory:

1. In the Modelsim software, on the File Menu, click **Change Directory**. The **Choose Folder** dialog box appears.
2. Browse to the directory where your designs are located.

3. Click **OK**.

Perform the following steps to create the simulation library:

1. In the ModelSim software, on the File menu, point to **New** and click **Library**. The **Create a New Library** dialog box appears.
2. Select a new library and a logical mapping to it.
3. In the **Library Name** box, type the library name of the newly created library.

 For example, the library name for Altera megafunctions is **altera\_mf\_ver**, and the library name for LPM is **lpm\_ver**. To see all the functional simulation library files, refer to “[RTL Functional Simulation Libraries](#)” on page 2–6.

4. Click **OK**.

### Compile Simulation Models into Simulation Libraries

Perform the following steps to compile simulation models into simulation libraries:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.
2. Select the library that you created (for example, **altera\_mf\_ver** or **lpm\_ver**).
3. Browse to the *<Quartus II installation directory>/eda/sim\_lib* and add the necessary simulation model files to your project. Select the simulation model files and click **Compile**.

 The **altera\_mf.v** model files should be compiled into the **altera\_mf\_ver** library. The **220model.v** model files should be compiled into the **lpm\_ver** library.

4. Repeat step 2 and step 3 to compile other simulation models.
5. Click **Done**.

### Compile Testbench and Design Files into the Work Library

The following instructions show you how to compile your testbench and design files into the work library using the Modelsim GUI.

Perform the following steps to change to the design directory:

1. In the Modelsim software, on the File menu, click **Change Directory**. The **Choose Folder** dialog box appears.
2. Browse to the directory where your designs are located.
3. Click **OK**.

Perform the following steps to compile the testbench and design files into the work library:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.
2. Select the library **Work**. The design files and testbench file should be compiled into the **Work** library.
3. Select the design files and the testbench file, and click **Compile**.
4. Click **Done**.



Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following steps:

1. On the Simulate menu, click **Start Simulation**. The **Start Simulation** dialog box appears.
2. Click the **Design** tab. In the **Resolution** list, select **ps**.
3. In the **Library** list, select and expand the **Work** library.
4. Select the top-level design unit (your testbench).
5. In the **Resolution** list, select **ps**.
6. Click the **Libraries** tab.

7. In the **Search Libraries** (-L) text box, click the **add** button to browse to the required simulation library that you previously compiled (for example, **altera\_mf\_ver**, **lpm\_ver**, or **altera\_ver**) and click **OK** to add them into the **Search Libraries** (-L) text box.
8. Click **OK**.

### Running the Simulation

Perform the following steps to run a simulation:

1. On the View menu, point to **Debug Windows** and click **Objects**. This command displays all objects in the current scope.
2. On the View menu, point to **Debug Windows** and click **Wave**.
3. Drag signals to monitor from the **Objects** window and drop them into the **Wave** window.
4. On the Simulating menu, point to **Run** and click **Run 100 ps** to run the simulation for 100 ps.

### *Perform Post-Synthesis Simulation*

Post-synthesis simulation can be done to verify that functionality of the design is not lost after synthesis. You can create the post-synthesis netlist in the Quartus II software and use the netlist to perform post-synthesis simulation with the ModelSim software.

Before running post-synthesis simulation, generate post-synthesis simulation netlist files. Refer to the instructions in [“Generate Post-Synthesis Simulation Netlist Files” on page 2–13](#).

The following sections help you perform a post-synthesis simulation for a Verilog HDL design in the ModelSim software.

### Create Simulation Libraries

Simulation libraries are required to simulate a design that is mapped to post-synthesis primitives. Depending on the device family you are using, you must create the required simulation libraries and link them to your design correctly.

Perform the following steps to change to the simulation output directory:

1. In the Modelsim software, on the File Menu, click **Change Directory**. The **Choose Folder** dialog box appears.

2. Browse to the directory where your testbench or \*.vo file is located. By default, the \*.vo file is located at *<project directory>/simulation/modelsim*.
3. Click **OK**.

Perform the following steps to create the simulation library:

1. In the ModelSim software, on the File menu, point to **New** and click **Library**. The **Create a New Library** dialog box appears.
2. Select a new library and a logical mapping to it.
3. In the **Library Name** box, type the library name of the newly created library.

 For example, the library name for Stratix III family is **stratixiii**. To see all the gate-level timing simulation library files, refer to “[Gate-Level Simulation Library Files](#)” on page 2–10.

4. Click **OK**.

#### Compile Simulation Models into Simulation Libraries

Perform the following steps to compile simulation models into simulation libraries:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.
2. Select the library that you created (for example, **stratixiii\_ver**).
3. Browse to the *<Quartus II installation directory>/eda/sim\_lib* and add the necessary simulation model files to your project. Select the simulation model files and click **Compile**.

 The **stratixiii\_atoms.v** model files should be compiled into the **stratixiii\_ver** library.

4. Repeat step 2 and step 3 to compile other simulation models, if needed.
5. Click **Done**.

### Compile Testbench and Verilog Output File into the Work Library

The following instructions show you how to compile your testbench and **\*.vo** into the work library using the Modelsim GUI.

Perform the following steps to create the work library:

1. In the ModelSim software, on the File menu, point to **New** and click **Library**. The **Create a New Library** dialog box appears.
2. Select a new library and a logical mapping to it.
3. In the **Library Name** box, type the library name “**Work**” in the text box.
4. Click **OK**.

Perform the following steps to compile the testbench file and **\*.vo** file into the work library:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.
2. Select the library **Work**. The testbench and **\*.vo** file should be compiled into the **Work** library.
3. Select the testbench and **\*.vo** design files, and click **Compile**.
4. Click **Done**.

### Loading the Design

To load a design, perform the following steps:

1. On the Simulate menu, click **Start Simulation**. The **Start Simulation** dialog box appears.
2. Click the **Design** tab. In the **Resolution** list, select **ps**.
3. In the **Library** list, select the **Work** library.
4. In the **Start Simulation** dialog box, expand the **Work** library.
5. Select the top-level design unit (your testbench).
6. In the **Resolution** list, select **ps**.
7. Click the **Libraries** tab.

8. In the **Search Libraries** (-L) text box, click the **add** button to browse to the required simulation library that you previously compiled (for example, **stratixiii\_ver** or **stratixiiigx\_ver**) and click **OK** to add them into the **Search Libraries** (-L) text box.
9. Click **OK**.

### Running the Simulation

Perform the following steps to run a simulation:

1. On the View menu, point to **Debug Windows** and click **Objects**. This command displays all objects in the current scope.
2. On the View menu, point to **Debug Windows** and click **Wave**.
3. Drag signals to monitor from the **Objects** window and drop them into the **Wave** window.
4. On the Simulating menu, point to **Run** and click **Run 100 ps** to run the simulation for 100 ps.

### Perform Gate-Level Simulation

Gate-level simulation is a very important step in ensuring that the FPGA device's functionality is still correct and meets all required timing requirements after the design was placed and routed. You can create the gate-level netlist in the Quartus II software and use the netlist to perform gate-level simulation with the ModelSim software.

Before running gate-level simulation, generate gate-level timing simulation netlist files. Refer to the instructions in [“Generate Gate-Level Timing Simulation Netlist Files” on page 2–15](#).

The following sections help you perform a gate-level simulation for a Verilog HDL design in the ModelSim software.

### Create Simulation Libraries

Simulation libraries are required to simulate a design that contains an Altera primitive, LPM function, or Altera megafunction. Depending on your design, you must create the required simulation libraries and link them to your design correctly.

Perform the following steps to change to the design directory:

1. In the Modelsim software, on the File Menu, click **Change Directory**. The **Choose Folder** dialog box appears.

2. Browse to the directory where your designs are located.
3. Click **OK**.

Perform the following steps to change to the simulation output directory:

1. In the Modelsim software, on the File Menu, click **Change Directory**. The **Choose Folder** dialog box appears.
2. Browse to the directory where your testbench or \*.vo file is located. By default, the \*.vo file is located at *<project directory>/simulation/modelsim*.
3. Click **OK**.

Perform the following steps to create the simulation library:

1. In the ModelSim software, on the File menu, point to **New** and click **Library**. The **Create a New Library** dialog box appears.
2. Select a new library and a logical mapping to it.
3. In the **Library Name** box, type the library name of the newly created library.



For example, the library name for Stratix III family is **stratixiii**. To see all the gate-level timing simulation library files, refer to ["Gate-Level Simulation Library Files" on page 2-10](#).

4. Click **OK**.

#### Compile Simulation Models into Simulation Libraries

Perform the following steps to compile simulation models into simulation libraries:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.
2. Select the library that you created (for example, **stratixiii\_ver**).
3. Browse to the *<Quartus II installation directory>/eda/sim\_lib* and add the necessary simulation model files to your project. Select the simulation model files and click **Compile**.



The **stratixiii\_atoms.v** model files should be compiled into the **stratixiii\_ver** library.

4. Repeat step 2 and step 3 to compile other simulation models, if needed.
5. Click **Done**.

#### Compile Testbench and Verilog Output File into the Work Library

The following instructions show you how to compile your testbench and **\*.vo** file into the work library using the Modelsim GUI.

Perform the following steps to create the work library:

1. In the ModelSim software, on the File menu, point to **New** and click **Library**. The **Create a New Library** dialog box appears.
2. Select a new library and a logical mapping to it.
3. In the **Library Name** box, type the library name “**Work**” in the text box.
4. Click **OK**.

Perform the following steps to compile the testbench file and Verilog HDL output file (**\*.vo**) into the work library:

1. On the File menu, click **Compile**. The **Compile Source Files** dialog box appears.
2. Select the library **Work**. The testbench and **\*.vo** file should be compiled into the **Work** library.
3. Select the testbench and **\*.vo** design files, and click **Compile**.
4. Click **Done**.



Resolve compile-time errors before proceeding to the following section.

#### Loading the Design

When simulating in Verilog HDL, the **\*.sdo** file does not have to be manually specified because in the Quartus II-generated **\*.vo** file, there is a `$(sdf_annotate` task that ModelSim uses to look into the current directory, from which VSIM was run and uses to look for the **\*.sdo** file. If your **\*.sdo** file is not in the same directory from which you ran VSIM, copy the **\*.sdo** file into your current directory.

To load a design, perform the following steps:

1. On the Simulate menu, click **Start Simulation**. The **Start Simulation** dialog box appears.
2. Click the **Design** tab. In the **Resolution** list, select **ps**.
3. In the **Library** list, select and expand the **Work** library.
4. Select the top-level design unit (your testbench).
5. In the **Resolution** list, select **ps**.
6. Click the **Libraries** tab.
7. In the **Search Libraries (-L)** text box, click the **add** button to browse to the required simulation library that you previously compiled (for example, **stratixiii\_ver** or **stratixiiigx\_ver**) and click **OK** to add them into the **Search Libraries (-L)** text box.
8. Click **OK**.

### Running the Simulation

Perform the following steps to run a simulation:

1. On the View menu, point to **Debug Windows** and click **Objects**. This command displays all objects in the current scope.
2. On the View menu, point to **Debug Windows** and click **Wave**.
3. Drag signals to monitor from the **Objects** window and drop them into the **Wave** window.
4. On the Simulating menu, point to **Run** and click **Run 100 ps** to run the simulation for 100 ps.

### Simulating the VHDL Designs (Through Command-line)

Simulating VHDL design using the Modelsim command-line gives you more flexibility and control to compile the libraries, and load and simulate the VHDL design files. All these commands to perform simulation are Tcl commands which can be put into the Modelsim Macros file (\*.do). Using the \*.do file allows you to run simulation in batch mode. You only need to execute the \*.do file and the Modelsim tool automatically executes all the commands that are inside the \*.do script macro file.

You can go through the Modelsim command-line to perform RTL functional simulation, post-synthesis simulation, and gate-level simulation. The following sections show how to perform simulation at various levels through the Modelsim command-line.

### Perform RTL Functional Simulation

RTL functional simulation is typically performed to verify the syntax of the code and to check the functionality of the design. The following sections will show how to perform RTL functional simulation in ModelSim for VHDL designs.

#### Create Simulation Libraries

Simulation libraries are required to simulate a design that contains an Altera primitive, LPM function, or Altera megafunction. Depending on your design, you must create the required simulation libraries and link them to your design correctly.

Perform the following command to change to the design library:

```
cd <your_design_directory> ←  
(for example, cd:/designs)
```

Perform the following commands to create the simulation libraries:

```
vlib <library_name> ←  
vmap <logical_library_name> <library_name> ←
```

 For example, the library name for Altera megafunction is **altera\_mf**, and the library name for LPM is **lpm**. To see all the functional simulation library files, refer to “[RTL Functional Simulation Library Files](#)” on page 2–9.

For example, to create simulation libraries for **altera\_mf**, **lpm**, and **altera**:

```
vlib altera_mf ←  
vmap altera_mf altera_mf ←  
vlib lpm ←  
vmap lpm lpm ←  
vlib altera ←  
vmap altera altera ←
```

### Compile Simulation Models into Simulation Libraries

Perform the following commands to compile simulation models into simulation libraries:

```
vcom -work <simulation_library> <Quartus II installation directory> \
/eda/sim_lib/<simulation_library_files>
```

For example, the **altera\_mf\_components.vhd** and **altera\_mf.vhd** model files should be compiled into the **altera\_mf** library. The **220pack.vhd** and **220model.vhd** model files should be compiled into the **lpm** library.

Use Example 2-1 to compile the simulation model files to the simulation libraries for **altera\_mf**, **lpm**, and **altera**.

---

#### Example 2-1.

```
vcom -work altera_mf <Quartus II installation directory> \
/eda/sim_lib/altera_mf_components.v <Quartus II installation directory> \
/eda/sim_lib/altera_mf.vhd ↵
```

```
vcom -work lpm <Quartus II installation directory>/eda/sim_lib/220model.vhd \
<Quartus II installation directory>/eda/sim_lib/220model.vhd ↵
```

```
vcom -work altera <Quartus II installation directory> \
/eda/sim_lib/altera_primitives_components.vhd \
<Quartus II installation directory>/eda/sim_lib/altera_primitives.vhd ↵
```

---

### Compile Testbench and Design Files into the Work Library

The following commands show how to compile your testbench and design files into the work library using the ModelSim software.

Perform the following steps to create the work library:

```
vlib work ↵
vmap work work ↵
```

Perform the following command to compile the testbench and design files into the work library:

```
vcom -work work <my_test_bench.vhd> <my_design_files.vhd> ↵
```



Resolve compile-time errors before proceeding to the following section.

## Loading the Design

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> work.<my_test_bench> ↵
```

 The `<library1>` and `<library2>` are the required libraries to compile your testbench. If you have multiple libraries, use the `-L` option multiple times in the `vsim` command.

## Running the Simulation

Perform the following commands to run a simulation:

```
add wave <signal name> ↵
```

```
run <time period> ↵
```

 To add all signals in your testbench hierarchy, use the command:

```
"add wave *"
```

For example, to run the simulation for 100 ps, use the command:  
`"run 100 ps"`

## Perform Post-Synthesis Simulation

Post-synthesis simulation can be done to verify that functionality of the design is not lost after synthesis. You can create the post-synthesis netlist in the Quartus II software and use the netlist to perform Post-Synthesis simulation with the ModelSim software.

Before running post-synthesis simulation, generate post-synthesis simulation netlist files. Refer to the instructions in [“Generate Post-Synthesis Simulation Netlist Files” on page 2–13](#).

The following sections help you perform a post-synthesis simulation for a VHDL design in the ModelSim software.

### Create Simulation Libraries

Simulation libraries are required to simulate a design that is mapped to post-synthesis primitives. Depending on the device family you are using, you must create the required simulation libraries and link them to your design correctly.

Perform the following command to change to the simulation output directory:

```
cd <simulation_output_directory> ↵
(for example, cd:/designs/modelsim/simulation)
```

Perform the following commands to create the simulation libraries:

```
vlib <library_name> ↵
vmap <logical_library_name> <library_name> ↵
```

 For example, the library name for the Stratix III family is **stratixiii**. To see all the gate-level timing simulation library files, refer to “[Gate-Level Simulation Libraries](#)” on page 2–7.

For example, to create simulation libraries for **stratixiii**:

```
vlib stratixiii ↵
vmap stratixiii stratixiii ↵
```

#### Compile Simulation Models into Simulation Libraries

Perform the following commands to compile simulation models into simulation libraries:

```
vcom -work <simulation_library> <Quartus II installation directory> \
/eda/sim_lib/<simulation_library_files>
```

For example, the **stratixiii\_atoms\_components.vhd** and **stratixiii\_atoms.vhd** model files should be compiled into the **stratixiii** library.

Use the following example to compile the simulation model files to the simulation libraries for **stratixiii**:

```
vcom -work stratixiii <Quartus II installation directory> \
/eda/sim_lib/stratixiii_atoms_components.vhd <Quartus II installation directory> \
/eda/sim_lib/stratixiii_atoms.vhd ↵
```

#### Compile Testbench and VHDL Output Files into the Work Library

The following commands show how to compile your testbench and **\*.vhd** file into the work library using the ModelSim software.

Perform the following commands to create the work library:

```
vlib work ↵
vmap work work ↵
```

Perform the following command to compile the testbench and \*.vho file into the work library:

```
vcom -work work <my_test_bench.vhd> <my_design_files.vho> ↵
```

 Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> work.<my_test_bench> ↵
```

 The <library1> and <library2> are the libraries that you compiled previously (for example, **stratixiii** and **stratixiigx**) which are required to compile your testbench. The gate-level libraries are usually required for performing post-synthesis simulation. If you have multiple libraries, use the **-L** option multiple times in the **vsim** command.

### Running the Simulation

Perform the following commands to run a simulation:

```
add wave <signal name> ↵
```

```
run <time period> ↵
```

 To add all signals in your testbench hierarchy, use the command:  
 "add wave \*"  
 For example, to run the simulation for 100 ps, use the command:  
 "run 100 ps"

### Perform Gate-Level Simulation

Gate-level simulation is a very important step in ensuring that the FPGA device's functionality is still correct and meets all required timing requirements after the design was placed and routed. You can create the gate-level netlist in the Quartus II software and use the netlist to perform gate-level simulation with the ModelSim software.

Before running gate-level simulation, generate gate-level timing simulation netlist files. Refer to the instructions in ["Generate Gate-Level Timing Simulation Netlist Files" on page 2-15](#).

The following sections help you perform a gate-level simulation for a VHDL design in the ModelSim software.

### Create Simulation Libraries

Simulation libraries are required to simulate a design that is mapped to post-synthesis primitives. Depending on the device family that you are using, you must create the required simulation libraries and link them to your design correctly.

Perform the following command to change to the simulation output directory:

```
cd <simulation_output_directory> ↵  
(for example, cd:/designs/modelsim/simulation)
```

Perform the following commands to create the simulation libraries:

```
vlib <library_name> ↵  
vmap <logical_library_name> <library_name> ↵
```

 For example, the library name for the Stratix III family is **stratixiii**. To see all the gate-level timing simulation library files, refer to “[Gate-Level Simulation Libraries](#)” on page 2-7.

For example, to create simulation libraries for **stratixiii**:

```
vlib stratixiii ↵  
vmap stratixiii stratixiii ↵
```

### Compile Simulation Models into Simulation Libraries

Perform the following commands to compile simulation models into simulation libraries:

```
vcom -work <simulation_library> <Quartus II installation directory> \  
/eda/sim_lib/<simulation_library_files>
```

For example, the **stratixiii\_atoms\_components.vhd** and **stratixiii\_atoms.vhd** model files should be compiled into the **stratixiii** library.

Use Example 2-2 to compile the simulation model files to the simulation libraries for **stratixiii**.

---

#### **Example 2-2.**

```
vcom -work stratixiii <Quartus II installation directory> \  
/eda/sim_lib/stratixiii_atoms_components.vhd <Quartus II installation directory> \  
/eda/sim_lib/stratixiii_atoms.vhd ↵
```

---

**Compile Testbench and VHDL Output Files into the Work Library**

The following commands show how to compile your testbench and \*.vho file into the work library using the ModelSim GUI.

Perform the following commands to create the work library:

```
vlib work ↵
vmap work work ↵
```

Perform the following command to compile the testbench and \*.vho file into the work library:

```
vcom -work work <my_test_bench.vht> <my_design_files.vho> ↵
```

 Resolve compile-time errors before proceeding to the following section.

**Loading the Design**

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> -sdfotyp <design instance> = \
<path to *.sdo file> work.<my_test_bench> ↵
```

 The <library1> and <library2> are the libraries that you compiled previously (for example, **stratixiii** and **stratixiigx**), which are required to compile your testbench. The gate-level libraries are usually required for performing gate-level timing simulation. If you have multiple libraries, use the -L option multiple times in the vsim command.

 You do not need to set the value (Minimum, Average, Maximum) for the \*.sdo file because the Quartus II EDA Netlist Writer generates the \*.sdo file using the same value for the triplet (minimum, average, and maximum timing values).

 If your design under test is instantiated in the testbench file under the *i1* label, then the <design instance> should be "i1" (for example, /i1=<my design>.sdo).

**Running the Simulation**

Perform the following commands to run a simulation:

```
add wave <signal name> ↵
run <time period> ↵
```



To add all signals in your testbench hierarchy, use the command:

```
"add wave *"
```

For example, to run the simulation for 100 ps, use the command:  
"run 100 ps"

## Simulating the Verilog HDL Designs (Through Command-line)

Simulating Verilog HDL design using the Modelsim command-line gives you more flexibility and control to compile the libraries, and load and simulate the Verilog HDL design files. All these commands to perform simulation are Tcl commands which can be put into the **\*.do** file. Using the **\*.do** file allows you to run simulation in batch mode. You only need to execute the **\*.do** file and the Modelsim tool automatically executes all the commands that are inside the **\*.do** script macro file.

You can go through the Modelsim command-line to perform RTL functional simulation, post-synthesis simulation, and gate-level simulation. The following sections show how to perform simulation at various levels through the Modelsim command-line.

### *Perform RTL Functional Simulation*

RTL functional simulation is typically performed to verify the syntax of the code and to check the functionality of the design. The following sections show how to perform RTL functional simulation in ModelSim for Verilog HDL designs.

### **Create Simulation Libraries**

Simulation libraries are required to simulate a design that contains an Altera primitive, LPM function, or Altera megafunction. Depending on your design, you must create the required simulation libraries and link them to your design correctly.

Perform the following command to change to the design library:

```
cd <your_design_directory> ←  
(for example, cd:/designs)
```

Perform the following commands to create the simulation libraries:

```
vlib <library_name> ←  
vmap <logical_library_name> <library_name> ←
```



For example, the library name for Altera megafunction is **altera\_mf\_ver**, and the library name for LPM is **lpm\_ver**. To see all the functional simulation library files, refer to “[RTL Functional Simulation Library Files](#)” on page 2–9.

For example, to create simulation libraries for **altera\_mf**, **lpm\_ver**, and **altera\_ver**:

```
vlib altera_mf_ver ↵
vmap altera_mf altera_mf_ver ↵
vlib lpm_ver ↵
vmap lpm lpm_ver ↵
vlib altera_ver ↵
vmap altera altera_ver ↵
```

#### Compile Simulation Models into Simulation Libraries

Perform the following commands to compile simulation models into simulation libraries:

```
vlog -work <simulation_library> <Quartus II installation directory> \
/eda/sim_lib/<simulation_library_files>
```

For example, the **altera\_mf.v** model files should be compiled into the **altera\_mf\_ver** library. The **220model.v** model files should be compiled into the **lpm\_ver** library.

Use the following example to compile the simulation model files to the simulation libraries for **altera\_mf\_ver**, **lpm\_ver**, and **altera\_ver**:

```
vlog -work altera_mf_ver \
<Quartus II installation directory>/eda/sim_lib/altera_mf.v ↵
vlog -work lpm_ver <Quartus II installation directory>/eda/sim_lib/220model.v ↵
vlog -work altera_ver <Quartus II installation directory>/eda/sim_lib/altera \
_primitives.v ↵
```

#### Compile Testbench and Design Files into the Work Library

The following commands show how to compile your testbench and design files into the work library in the ModelSim command prompt.

Perform the following steps to create the work library:

```
vlib work ↵  
vmap work work ↵
```

Perform the following command to compile the testbench and design files into the work library:

```
vlog -work work <my_test_bench.v> <my_design_files.v> ↵
```

 Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> work.<my_test_bench> ↵
```

 The *<library1>* and *<library2>* are the required libraries to compile your testbench. If you have multiple libraries, use the *-L* option multiple times in the *vsim* command.

### Running the Simulation

Perform the following commands to run a simulation:

```
add wave <signal name> ↵  
run <time period> ↵
```

 To add all signals in your testbench hierarchy, use the command:  
"add wave \*"  
For example, to run the simulation for 100 ps, use the command:  
"run 100 ps"

### Perform Post-Synthesis Simulation

Post-synthesis simulation can be done to verify that functionality of the design is not lost after synthesis. You can create the post-synthesis netlist in the Quartus II software and use the netlist to perform post-synthesis simulation with the ModelSim software.

Before running post-synthesis simulation, generate post-synthesis simulation netlist files. Refer to the instructions in “[Generate Post-Synthesis Simulation Netlist Files](#)” on page 2–13.

The following sections help you perform a post-synthesis simulation for a Verilog HDL design in the ModelSim software.

### Create Simulation Libraries

Simulation libraries are required to simulate a design that is mapped to post-synthesis primitives. Depending on the device family you are using, you must create the required simulation libraries and link them to your design correctly.

Perform the following command to change to the simulation output directory:

```
cd <simulation_output_directory> ↵
(for example, cd:/designs/modelsim/simulation)
```

Perform the following commands to create the simulation libraries:

```
vlib <library_name> ↵
vmap <logical_library_name> <library_name> ↵
```

 For example, the library name for the Stratix III family is **stratixiii\_ver**. To see all the gate-level timing simulation library files, refer to “[Gate-Level Simulation Libraries](#)” on page 2-7.

For example, to create simulation libraries for **stratixiii\_ver**:

```
vlib stratixiii_ver ↵
vmap stratixiii_ver stratixiii_ver ↵
```

### Compile Simulation Models into Simulation Libraries

Perform the following commands to compile simulation models into simulation libraries:

```
vlog -work <simulation_library> <Quartus II installation directory> \
/eda/sim_lib/<simulation_library_files>
```

For example, the **stratixiii\_atoms.v** model files should be compiled into the **stratixiii\_ver** library.

Use the following example to compile the simulation model files to the simulation libraries for **stratixiii\_ver**:

```
vlog -work stratixiii_ver <Quartus II installation directory> /eda/sim_lib \
/stratixiii_atoms.v ↵
```

**Compile Testbench and Verilog Output Files into the Work Library**

The following commands show how to compile your testbench and \*.vo file into the work library using the ModelSim software.

Perform the following commands to create the work library:

```
vlib work ←  
vmap work work ←
```

Perform the following command to compile the testbench and \*.vo file into the work library:

```
vlog -work work <my_test_bench.vt> <my_design_netlists.vo> ←
```

 Resolve compile-time errors before proceeding to the following section.

**Loading the Design**

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> work.<my_test_bench> ←
```

 The <library1> and <library2> are the libraries that you compiled previously (for example, **stratixiii** or **stratixiigx**) which are required to compile your testbench. Gate-level libraries are usually required for performing post-synthesis simulation. If you have multiple libraries, use the -L option multiple times in the vsim command.

**Running the Simulation**

Perform the following commands to run a simulation:

```
add wave <signal name> ←
```

```
run <time period> ←
```

 To add all signals in your testbench hierarchy, use the command:

```
"add wave *"
```

For example, to run the simulation for 100 ps, use the command:  
"run 100 ps"

## Perform Gate-Level Simulation

Gate-level simulation is a very important step in ensuring that the FPGA device's functionality is still correct and meets all required timing requirements after the design was placed and routed. You can create the gate-level netlist in the Quartus II software and use the netlist to perform gate-level simulation with the ModelSim software.

Before running gate-level simulation, generate gate-level timing simulation netlist files. Refer to the instructions in [“Generate Gate-Level Timing Simulation Netlist Files” on page 2-15](#).

The following sections help you perform a gate-level simulation for a Verilog HDL design in the ModelSim software.

### Create Simulation Libraries

Simulation libraries are required to simulate a design that is mapped to post-synthesis primitives. Depending on the device family that you are using, you must create the required simulation libraries and link them to your design correctly.

Perform the following command to change to the simulation output directory:

```
cd <simulation_output_directory> ←  
(for example, cd:/designs/modelsim/simulation)
```



This directory contains the **\*.vo** file, which is generated by the netlist writer.

Perform the following commands to create the simulation libraries:

```
vlib <library_name> ←  
vmap <logical_library_name> <library_name> ←
```



For example, the library name for the Stratix III family is **stratixiii\_ver**. To see all the gate-level timing simulation library files, refer to [“Gate-Level Simulation Libraries” on page 2-7](#).

For example, to create simulation libraries for **stratixiii\_ver**:

```
vlib stratixiii_ver ←  
vmap stratixiii_ver stratixiii_ver ←
```

### Compile Simulation Models into Simulation Libraries

Perform the following commands to compile simulation models into simulation libraries:

```
vlog -work <simulation_library> <Quartus II installation directory> \
/eda/sim_lib/<simulation_library_files> ↵
```

For example, the **stratixiii\_atoms.v** model files should be compiled into the **stratixiii\_ver** library.

Use the following example to compile the simulation model files to the simulation libraries for **stratixiii\_ver**:

```
vlog -work stratixiii <Quartus II installation directory> \
/eda/sim_lib/stratixiii_atoms.v ↵
```

### Compile Testbench and Verilog Output Files into the Work Library

The following commands show how to compile your testbench and **\*.vo** file into the work library using the ModelSim command-line.

Perform the following commands to create the work library:

```
vlib work ↵
vmap work work ↵
```

Perform the following command to compile the testbench and **\*.vo** file files into the work library:

```
vlog -work work <my_test_bench.v> <my_design_netlists.vo> ↵
```



Resolve compile-time errors before proceeding to the following section.

### Loading the Design

When simulating in Verilog HDL, the **\*.sdo** file does not have to be manually specified because in the Quartus II-generated **\*.vo** file, there is a `$(sdf_annotate)` task that ModelSim uses to look into the current directory, from which VSIM was run and uses to look for the **\*.sdo** file. If your **\*.sdo** file is not in the same directory from which you ran VSIM, copy the **\*.sdo** file into your current directory.

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> work.<my_test_bench> ↵
```



The `<library1>` and `<library2>` are the libraries that you compiled previously (for example, `stratixiii_ver` or `stratixiigx_ver`) which is required to compile your testbench. Gate-level libraries are usually required for performing gate-level timing simulation. If you have multiple libraries, use the `-L` option multiple times in the `vsim` command.

### Running the Simulation

Perform the following commands to run a simulation:

```
add wave <signal name> ↵
```

```
run <time period> ↵
```



To add all signals in your testbench hierarchy, use the command:

```
"add wave *"
```

For example, to run the simulation for 100 ps, use the command:  
`"run 100 ps"`

## Simulating Designs that Include Transceivers

If your design includes a Stratix GX, Stratix II GX, Stratix IV, or Arria GX transceiver, you must compile additional library files to perform RTL functional or gate-level timing simulations. The following example shows how to perform simulation on designs that include transceivers in Stratix GX and Stratix II GX devices.

Performing simulation with transceivers in Arria GX and Stratix II GX are very similar. You only need to replace `stratixiigx_atoms` and `stratixiigx_hssi_atoms` model files with `arriagx_atoms` and `arriagx_hssi_atoms` model files.

### Stratix GX RTL Functional Simulation

To perform a RTL functional simulation of your design that instantiates the ALTGXBX megafunction which enables the gigabit transceiver block on Stratix GX devices, compile the `stratixgx_mf` model file into the `altgxb` library.



The `stratixiigx_mf` model file references the `lpm` and `sgate` libraries. If you are using ModelSim PE/SE, you must create these libraries to perform a simulation.

### Performing RTL Functional Simulation for Stratix GX in VHDL

If you are using ModelSim-Altera software, compiling the libraries is not necessary. You can simulate the design directly by typing the commands in Example 2–3.

---

#### **Example 2–3.**

```
vcom -work <my design>.vhd <my testbench>.vhd ↵
vsim -L lpm -L altera_mf -L sgate -L altgxb work.<my testbench> ↵
```

---

If you are using ModelSim SE/PE, you must compile the necessary libraries before you can simulate the designs. To compile and simulate the design, type the commands in Example 2–4 at the ModelSim command prompt.

---

#### **Example 2–4.**

```
vcom -work altera_mf altera_mf_components.vhd altera_mf.vhd ↵
vcom -work lpm 220pack.vhd 220model.vhd ↵
vcom -work sgate sgate_pack.vhd sgate.vhd ↵
vcom -work altgxb stratixgx_mf.vhd stratixgx_mf_components.vhd ↵
vcom -work <my design>.vhd <my testbench>.vhd ↵
vsim -L lpm -L altera_mf -L sgate -L altgxb work.<my testbench> ↵
```

---

### Performing RTL Functional Simulation for Stratix GX in Verilog HDL

If you are using ModelSim-Altera software, compiling the libraries is not necessary. You can simulate the design directly by typing the command in Example 2–5.

---

#### **Example 2–5.**

```
vlog -work <my design>.v <my testbench>.v
vsim -L lpm_ver -L altera_mf_ver -L sgate_ver -L altgxb work.<my testbench> ↵
```

---

If you are using ModelSim SE/PE, you must compile the necessary libraries before you can simulate the designs. To compile and simulate the design, type the commands in Example 2–6 at the ModelSim command prompt.

---

**Example 2–6.**

```
vlib work_ver ↵
vlib lpm_ver ↵
vlib altera_mf_ver ↵
vlib sgate_ver ↵
vlib altgxb_ver ↵
vlog -work lpm_ver 220model.v ↵
vlog -work altera_mf_ver altera_mf.v ↵
vlog -work sgate_ver sgate.v ↵
vlog -work altgxb_ver stratixgx_mf.v ↵
vlog -work <my design>.v <my testbench>.v
vsim -L lpm_ver -L sgate_ver -L altgxb_ver work.<my testbench> ↵
```

---

## Stratix GX Gate-Level Timing Simulation

Perform a gate-level timing simulation of your design that includes a Stratix GX transceiver by compiling the **stratixgx\_atoms** and **stratixgx\_hssi\_atoms** model files into the **stratixgx** and **stratixgx\_gxb** libraries, respectively.



The **stratixgx\_hssi\_atoms** model file references the **lpm** and **sgate** libraries. If you are using ModelSim PE/SE, you must create these libraries to perform a simulation.

### Performing Gate-Level Timing Simulation for Stratix GX in VHDL

If you are using ModelSim-Altera software, compiling the libraries is not necessary. You can simulate the design directly by typing the command in Example 2–7.

---

**Example 2–7.**

```
vcom -work <my design>.vho <my testbench>.vhd ↵
vsim -L lpm -L altera_mf -L sgate -L stratixgx -L stratixgx_gxb \
-sdftyp <design instance>=<path to SDO file>.sdo work.<my testbench> \
-t ps - +transport_int_delays+transport_path_delays ↵
```

---

If you are using ModelSim SE/PE, you must compile the necessary libraries before you can simulate the designs. To compile and simulate the design, type the commands in Example 2-8 at the ModelSim command prompt.

---

**Example 2-8.**

```
vcom -work lpm 220pack.vhd 220model.vhd ←
vcom -work altera_mf altera_mf_components.vhd altera_mf.vhd ←
vcom -work sgate sgate_pack.vhd sgate.vhd ←
vcom -work stratixgx stratixgx_atoms.vhd stratixgx_components.vhd ←
vcom -work stratixgx_gxb stratixgx_hssi_atoms.vhd \
stratixgx_hssi_components.vhd ←
vcom -work <my design>.vho <my testbench>.vhd ←
vsim -L lpm -L altera_mf -L sgate -L stratixgx -L stratixgx_gxb \
-sdftyp <design instance>=<path to SDO file>.sdo work.<my testbench> \
-t ps +transport_int_delays +transport_path_delays ←
```

---

**Performing Gate-Level Timing Simulation for Stratix GX in Verilog HDL**

If you are using ModelSim-Altera software, compiling the libraries is not necessary. You can simulate the design directly by typing the command in Example 2-9.

---

**Example 2-9.**

```
vlog -work <my design>.vo <my testbench>.v ←
vsim -L lpm_ver -L altera_mf_ver -L sgate_ver -L stratixgx_ver -L \
stratixgx_gxb_ver work.<my testbench> -t ps +transport_int_delays \
+transport_path_delays ←
```

---

If you are using ModelSim SE/PE, you must compile the necessary libraries before you can simulate the designs. To compile and simulate the design, type the commands in Example 2-10 at the ModelSim command prompt.

---

**Example 2-10.**

```
vlog -work lpm_ver 220model.v ←
vlog -work altera_mf_ver altera_mf.v ←
vlog -work sgate_ver sgate.v ←
vlog -work stratixgx_ver stratixgx_atoms.v ←
vlog -work stratixgx_gxb_ver stratixgx_hssi_atoms.v ←
vlog -work <my design>.vo <my testbench>.v ←
vsim -L lpm_ver -L altera_mf_ver -L sgate_ver -L stratixgx_ver \
-L stratixgx_gxb_ver work.<my testbench> -t ps +transport_int_delays \
+transport_path_delays ←
```

---

## Stratix II GX RTL Functional Simulation

Stratix II GX function simulation is similar to Arria GX functional simulation. The following example shows only the functional simulation for designs that include transceivers in Stratix II GX. To simulate transceiver in Arria GX, you only need to replace the **stratixiigx\_hssi** model file with the **ariagx\_hssi** model file.

To perform a functional simulation of your design that instantiates the ALT2GXB megafunction, which enables the gigabit transceiver block on Stratix II GX devices, compile the **stratixiigx\_hssi** model file into the **stratixiigx\_hssi** library.

 The **stratixiigx\_hssi\_atoms** model file references the **lpm** and **sgate** libraries. If you are using ModelSim PE/SE, you must create these libraries to perform a simulation.

Generate a functional simulation netlist by turning on **Generate Simulation Model** in the **Simulation Library** tab of the ALT2GXB MegaWizard Plug-In Manager (Figure 2–2). The *<alt2gxb entity name>.vho* or *<alt2gxb module name>.vo* is generated in the current project directory.

 The Quartus II-generated ALT2GXB functional simulation library file references **stratixiigx\_hssi** wysiwyg atoms.

Figure 2–2. ALT2GXB MegaWizard



### Performing RTL Functional Simulation for Stratix II GX in VHDL

If you are using ModelSim-Altera software, compiling the libraries is not necessary. You can simulate the design directly by typing the commands in Example 2–11.

#### Example 2–11.

```
vcom -work work <alt2gxb entity name>.vho ↵
vcom -work <my design>.vhd <my testbench>.vhd ↵
vsim -L lpm -L altera_mf -L sgate -L stratiixgx_hssi work.<my design> ↵
```

If you are using ModelSim SE/PE, you must compile the necessary libraries before you can simulate the designs. To compile and simulate the design, type the commands in Example 2–12 at the ModelSim command prompt.

---

**Example 2–12.**

```
vcom -work lpm 220pack.vhd 220model.vhd ↵
vcom -work altera_mf altera_mf_components.vhd altera_mf.vhd ↵
vcom -work sgate sgate_pack.vhd sgate.vhd ↵
vcom -work stratixiigx_hssi stratixiigx_hssi_components.vhd \
stratixiigx_hssi_atoms.vhd ↵
vcom -work work <alt2gxb entity name>.vho ↵
vcom -work <my design>.vhd <my testbench>.vhd ↵
vsim -L lpm -L altera_mf -L sgate -L stratixgx_hssi work.<my testbench> ↵
```

---

**Performing RTL Functional Simulation for Stratix II GX in Verilog HDL**

If you are using ModelSim-Altera software, compiling the libraries is not necessary. You can simulate the design directly by typing the command in Example 2–13.

---

**Example 2–13.**

```
vlog -work work <alt2gxb module name>.vo
vlog -work <my design>.v <my testbench>.v
vsim -L lpm_ver -L altera_mf_ver -L sgate_ver -L stratixgx_hssi_ver \
work.<my testbench> ↵
```

---

If you are using ModelSim SE/PE, you must compile the necessary libraries before you can simulate the designs. To compile and simulate the design, type the commands in Example 2–14 at the ModelSim command prompt.

---

**Example 2–14.**

```
vlog -work lpm_ver 220model.v ↵
vlog -work altera_mf_ver altera_mf.v ↵
vlog -work sgate_ver sgate.v ↵
vlog -work stratixiigx_hssi_ver stratixiigx_hssi_atoms.v ↵
vlog -work work <alt2gxb module name>.vo ↵
vlog -work <my design>.v <my testbench>.v ↵
vsim -L lpm_ver -L altera_mf_ver -L sgate_ver -L stratixgx_hssi_ver \
work.<my testbench> ↵
```

---

## Stratix II GX Gate-Level Timing Simulation

Stratix II GX gate-level timing simulation is similar to Arria GX gate-level timing simulation. The following example shows only the gate-level timing simulation for designs that include transceivers in Stratix II GX. To simulate transceiver in Arria GX, you only need to replace the **stratixiigx\_hssi** model file with the **arriagx\_hssi** model file.

To perform a gate-level timing simulation of your design that includes a Stratix II GX transceiver, compile **stratixiigx\_atoms** and **stratixiigx\_hssi\_atoms** into the **stratixiigx** and **stratixiigx\_hssi** libraries, respectively.



The **stratixiigx\_hssi\_atoms** model file references the **lpm** and **sgate** libraries. If you are using ModelSim PE/SE, you must create these libraries to perform a simulation.

### *Performing Gate-Level Timing Simulation for Stratix II GX in VHDL*

If you are using ModelSim-Altera software, compiling the libraries is not necessary. You can simulate the design directly by typing the command in Example 2-15.

---

#### **Example 2-15.**

```
vcom -work <my design>.vho <my testbench>.vhd
vsim -L lpm -L altera_mf -L sgate -L stratixiigx -L stratixiigx_hssi \
-sdftyp <design instance>=<path to SDO file>.sdo work.<my testbench> \
-t ps +transport_int_delays +transport_path_delays ↵
```

---

If you are using ModelSim SE/PE, you must compile the necessary libraries before you can simulate the designs. To compile and simulate the design, type the commands in Example 2-16 at the ModelSim command prompt.

---

#### **Example 2-16.**

```
vcom -work lpm 220pack.vhd 220model.vhd ↵
vcom -work altera_mf altera_mf_components.vhd altera_mf.vhd ↵
vcom -work sgate sgate_pack.vhd sgate.vhd ↵
vcom -work stratixiigx stratixiigx_atoms.vhd stratixiigx_components.vhd ↵
vcom -work stratixiigx_hssi stratixiigx_hssi_components.vhd \
stratixiigx_hssi_atoms.vhd ↵
vcom -work <my design>.vho <my testbench>.vhd ↵
vsim -L lpm -L altera_mf -L sgate -L stratixiigx -L stratixiigx_hssi \
-sdftyp <design instance>=<path to SDO file>.sdo work.<my testbench> \
-t ps +transport_int_delays +transport_path_delays ↵
```

---

## Performing Gate-Level Timing Simulation for Stratix II GX in Verilog HDL

If you are using ModelSim-Altera software, compiling the libraries is not necessary. You can simulate the design directly by typing the command in Example 2-17.

---

### Example 2-17.

```
vlog -work <my design>.vo <my testbench>.v
vsim -L lpm_ver -L altera_mf_ver -L sgate_ver -L stratixiigx_ver \
-L stratixiigx_hssi_ver work.<my testbench> -t ps +transport_int_delays \
+transport_path_delays ↵
```

---

If you are using ModelSim SE/PE, you must compile the necessary libraries before you can simulate the designs. To compile and simulate the design, type the commands in Example 2-18 at the ModelSim command prompt.

---

### Example 2-18.

```
vlog -work lpm_ver 220model.v ↵
vlog -work altera_mf_ver altera_mf.v ↵
vlog -work sgate_ver sgate.v ↵
vlog -work stratixiigx_ver stratixiigx_atoms.v ↵
vlog -work stratixiigx_hssi_ver stratixiigx_hssi_atoms.v ↵
vlog -work <my design>.vo <my testbench>.v ↵
vsim -L lpm_ver -L altera_mf_ver -L sgate_ver -L stratixiigx_ver \
-L stratixiigx_hssi_ver work.<my testbench> -t ps +transport_int_delays \
+transport_path_delays ↵
```

---

## Transport Delays

By default, the ModelSim software filters out all pulses that are shorter than the propagation delay between primitives. Turning on the transport delay options in the ModelSim software prevents the simulation tool from filtering out these pulses. Use the following options to ensure that all signal pulses are seen in the simulation results.

### *+transport\_path\_delays*

Use this option when the pulses in your simulation are shorter than the delay within a gate-level primitive.

### *+transport\_int\_delays*

Use this option when the pulses in your simulation are shorter than the interconnect delay between gate-level primitives.

The `+transport_path_delays` and `+transport_int_delays` options are also used by default in the NativeLink feature for gate-level timing simulation.



For more information about either of these options, refer to the ModelSim Altera Command Reference installed with the ModelSim software.

The following ModelSim software command shows the command-line syntax to perform a gate-level timing simulation with the device family library:

```
vsim -t 1ps -L stratiixii -sdfotyp /i1=filtref_vhd.sdo work.filtref_vhd_vec_tst \
+transport_int_delays +transport_path_delays
```

## Using the NativeLink Feature with ModelSim-Altera or ModelSim Software

The NativeLink feature in the Quartus II software facilitates the seamless transfer of information between the Quartus II software and EDA tools and allows you to run ModelSim within the Quartus II software.

### Setting Up NativeLink

To run ModelSim automatically from the Quartus II software using the NativeLink feature, you must specify the path to your simulation tool by performing the following steps:

1. On the Tools menu, click **Options**. The **Options** dialog box appears.
2. In the **Category** list, select **EDA Tool Options**.
3. Double-click the entry under **Location of executable** beside the name of your EDA Tool.
4. Type or browse to the directory containing the executables of your EDA tool.



For ModelSim-Altera software and ModelSim SE/PE, executable files are stored in the **win32aloem** and **win32** directories, respectively.

**c:\<ModelSim-Altera installation path>\win32aloem**

**c:\<ModelSim installation path>\win32**

5. Click **OK**.

You can also specify the path to the simulator's executables by using the `set_user_option` TCL command:

```
set_user_option -name EDA_TOOL_PATH_MODELSIM <path to executables>
set_user_option -name EDA_TOOL_PATH_MODELSIM_ALTERA <path to executables>
```

## Performing an RTL Simulation Using NativeLink

To run a RTL functional simulation with the ModelSim software in the Quartus II software, perform the following steps:

1. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
2. In the **Category** list, select **Simulation**. The **Simulation** page appears (Figure 2-3).

Figure 2-3. Simulation Page in the Settings Dialog Box



3. In the **Tool name** list, select one of the following options:

- **ModelSim**
- **ModelSim-Altera**

4. If your design is written entirely in Verilog HDL or VHDL, the NativeLink feature automatically chooses the correct language and Altera simulation libraries. If your design is written with mixed languages, the NativeLink feature uses the default language specified in the **Format for output netlist** list. To change the default language when there is a mixed language design, under **EDA Netlist Writer options**, in the **Format for output netlist** list, select **VHDL** or **Verilog**. **Table 2–12** shows the design languages for output netlists and simulation models.

**Table 2–12. NativeLink Design Languages**

| Design File | Format for Output Netlist | Simulation Models Used |
|-------------|---------------------------|------------------------|
| Verilog     | Any                       | Verilog                |
| VHDL        | Any                       | VHDL                   |
| Mixed       | Verilog                   | Verilog                |
| Mixed       | VHDL                      | VHDL                   |



For mixed language simulation, choose the same language that was used to generate your megafunctions to ensure correct parameter passing between the megafunctions and the Altera libraries. For example, if your ALTSYNCRAM megafunction was generated in VHDL, choose **VHDL** as the format for the output netlist.

When creating mixed language designs, it is important to be aware of the following:

- EDA simulation tools do not allow seamless passing of parameters when a VHDL entity is instantiated in Verilog designs.
- The ModelSim and ModelSim-Altera software does not allow the use of Verilog User Defined Primitives (UDPs) to be instantiated in VHDL designs.

5. If you have testbench files or macro scripts, enter the information under **NativeLink settings**.

For more information about setting up a testbench with NativeLink, refer to “[Setting Up a Testbench](#)” on page 2–90.

6. Click **OK**.

7. On the Processing menu, point to **Start** and click **Start Analysis and Elaboration** to perform an Analysis and Elaboration. This command collects all your file name information and builds your design hierarchy in preparation for simulation.
8. On the Tools menu, point to **Run EDA Simulation Tool** and click **EDA RTL Simulation** to automatically run ModelSim, compile all necessary design files, and complete a simulation.

## Performing a Gate-Level Simulation Using NativeLink

To run a gate-level timing simulation with the ModelSim software in the Quartus II software, perform the following steps:

1. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
2. In the **Category** list, select **Simulation**. The **Simulation** page appears (Figure 2-3 on page 2-87).
3. In the **Tool name** list, select one of the following options:
  - **ModelSim**
  - **ModelSim-Altera**
4. Under **EDA Netlist Writer options**, in the **Format for output netlist** list, choose **VHDL** or **Verilog**. You can also modify where you want the post-synthesis netlist generated by editing or browsing to a directory in the **Output directory** box.
5. To run a gate-level simulation after each full compilation, turn on **Run Gate Level Simulation automatically after compilation**.
6. If you have testbench files or macro scripts, enter the information under **NativeLink settings**.
7. Click **OK**.
8. On the Processing menu, point to **Start** and click **Start EDA Netlist Writer** to generate a simulation netlist of your design.



If you must run full compilation after you set the **EDA Tool Settings**, the **Start EDA Netlist Writer** command is not required.

9. On the Tools menu, point to **Run EDA Simulation Tool** and click **EDA Gate Level Simulation** to automatically run ModelSim, compile all necessary design files, and complete a simulation.



If multi-corner Timing Analysis is performed, a dialog appears asking you to select the timing corner to run simulation. Select the timing corner and click **Run**.



A **\*.do** file is generated in the `<project_directory>\simulation\modelsim` directory while running NativeLink. You can perform a simulation with the **\*.do** file directly from ModelSim when you rerun a simulation without using NativeLink. To perform the simulation directly without NativeLink, type the following command in the ModelSim console: `do <generated_do_file>.do`.

## Setting Up a Testbench

You can use NativeLink to compile your design files and testbench files, and run an EDA simulation tool to automatically perform a simulation.

To set up NativeLink for simulation, perform the following steps:

1. On the Assignments menu, click **Settings**. The **Settings** dialog box appears.
2. In the **Category** list, click the "+" icon to expand **EDA Tool Settings** and select **Simulation**. The **Simulation** page appears.
3. Under **NativeLink settings**, select **None**, **Compile test bench**, or **Script to compile test bench** (Table 2-13).

**Table 2-13. NativeLink Settings**

| Settings                     | Description                                                                                                                                                                                                                         |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| None                         | Compile simulation models and design files.                                                                                                                                                                                         |
| Compile test bench           | NativeLink compiles simulation models, design files, testbench files, and starts simulation.                                                                                                                                        |
| Script to compile test bench | NativeLink compiles the simulation models and design files. The script you provide is sourced after design files compile. Use this option when you want to create your own script to compile your testbench and perform simulation. |

4. If you select **Compile test bench**, select your test bench setup from the **Compile test bench** list. You can use different testbench setups to specify different test scenarios. If there are no testbench setups entered, create a testbench setup by performing the following steps:
  - a. Click **Test Benches**. The **Test Benches** dialog box appears.
  - b. Click **New**. The **New Test Bench Settings** dialog box appears.
  - c. In the **Test Bench name** box, type in the testbench setup name that identifies the different test bench setups.
  - d. In the **Test level module** box, type in the top-level testbench entity name. For example, for a Quartus II-generated VHDL testbench, type in *<Vector Waveform File name>\_vhd\_vec\_tst*.
  - e. In the **Instance** box, type in the full instance path to the top level of your FPGA design. For example, for a Quartus II-generated VHDL testbench, type in *i1*.
  - f. Under **Simulation period**, select **Run simulation until all vector stimuli are used** or specify the end time of the simulation.
  - g. Under **Test bench files**, browse and add all your testbench files in the **File name** box. Use the **Up** and **Down** button to reorder your files. The script used by NativeLink compiles the files in order from top to bottom.



You can also specify the library name and HDL version to compile the testbench file. Native link compiles the testbench to a library name using the specified HDL version.

- h. Click **OK**.
- i. In the **Test Benches** dialog box, click **OK**.
5. Under **NativeLink settings**, turn on **Use script to setup simulation** and browse to your script. Your script is executed to set up and run simulation after loading the design using the `vsim` command.
6. If you choose **Script to compile test bench**, browse to your script and click **OK**.

### *Creating a Testbench*

In the Quartus II software, you can create a Verilog HDL or VHDL testbench from a Vector Waveform File. The generated testbench includes the behavior of the input stimulus and applies it to your instantiated top-level FPGA design.

1. On the File menu, click **Open**. The **Open** dialog box appears.
2. Click the **Files of type** arrow and select **Waveform/Vector Files**. Select your Vector Waveform File.
3. Click **Open**.
4. On the File menu, click **Export**. The **Export** dialog box appears.
5. Click the **Save as type** arrow and select **VHDL Test Bench File (\*.vht)** or **Verilog Test Bench File (\*.vt)**.
6. Turn on **Add self-checking code to file** to check your simulation results against your Vector Waveform File.
7. Click **Export**. Your VHDL or Verilog testbench file is generated in your project directory.

## **Generating a Timing VCD File for PowerPlay**

To generate a timing Value Change Dump (\*.vcd) file for PowerPlay, you must first generate a \*.vcd script file in the Quartus II software and run the \*.vcd script file from the Modelsim or Modelsim-Altera software to generate a timing \*.vcd file. This timing \*.vcd file can then be used by PowerPlay for power estimation. The following instructions show you step-by-step how to generate a timing \*.vcd file.

Perform the following steps to generate timing VCD Scripts in the Quartus II software:

1. In the Quartus II software, on the Assignments menu, click **Settings**.
2. In the **Settings** dialog box, on the **Simulator Settings** page, choose the appropriate third-party simulation tool (Modelsim or Modelsim-Altera) in the **Tool Name** list, and turn on the **Generate Value Change Dump File Script** option.
3. To generate the \*.vcd script file, perform a full compilation.

Perform the following steps to generate a timing \*.vcd file in Modelsim-Altera or Modelsim software:

1. In Modelsim or Modelsim-Altera software, before simulating your design, source the `<revision_name>_dump_all_vcd_nodes.tcl` script. To source the Tcl script, run the following command before running the `vsim` command. For example:

```
source <revision_name>_dump_all_vcd_nodes.tcl
```

2. Continue to run the simulation as usual until the end of the simulation. Exit the Modelsim or Modelsim-Altera software. If you do not exit the software, the ModelSim software may end the writing process of the timing \*.vcd files improperly, resulting in a corrupted timing \*.vcd file.

Refer to the [PowerPlay Power Analysis](#) chapter in volume 3 of the *Quartus II Handbook* for more information about using the timing \*.vcd file for power estimation.

## Scripting Support

You can run procedures and create settings described in this chapter in a Tcl script. You can also run some procedures at the command line prompt.

For more information about Tcl scripting, refer to the [Tcl Scripting](#) chapter in volume 2 of the *Quartus II Handbook*.

For more information about command line scripting, refer to the [Command-Line Scripting](#) chapter in volume 2 of the *Quartus II Handbook*.

For detailed information about scripting command options, refer to the [Qhelp](#) command line and Tcl API help browser.

Type this command to start the Qhelp browser:

```
quartus_sh --qhelp
```

## Generating a Post-Synthesis Simulation Netlist for ModelSim

You can use the Quartus II software to generate a post-synthesis simulation netlist with Tcl commands or with a command at the command-line prompt. The following example assumes that you are selecting ModelSim (Verilog HDL output from the Quartus II software).

### *Tcl Commands*

Use the following Tcl commands to set the output format to Verilog HDL, the simulation tool to ModelSim for Verilog HDL, and to generate a functional netlist:

```
set_global_assignment -name EDA_SIMULATION_TOOL "ModelSim (Verilog)"  
set_global_assignment -name EDA_GENERATE_FUNCTIONAL_NETLIST ON
```

### *Command Prompt*

Use the following command to generate a simulation output file for the ModelSim simulator. Specify VHDL or Verilog HDL for the format:

```
quartus_eda <project name> --simulation=on --format=<format> --tool=ModelSim \  
--functional ↵
```

## **Generating a Gate-Level Timing Simulation Netlist for ModelSim**

Use the Quartus II software to generate a gate-level timing simulation netlist with Tcl commands or with a command at the command prompt.

### *Tcl Commands*

Use one of the following Tcl commands:

```
set_global_assignment -name EDA_SIMULATION_TOOL "ModelSim-Altera (Verilog)"  
set_global_assignment -name EDA_SIMULATION_TOOL "ModelSim-Altera (VHDL)"  
set_global_assignment -name EDA_SIMULATION_TOOL "ModelSim (Verilog)"  
set_global_assignment -name EDA_SIMULATION_TOOL "ModelSim (VHDL)"
```

### *Command Line*

Generate a simulation output file for the ModelSim simulator by specifying VHDL or Verilog HDL for the format by typing the following command at the command prompt:

```
quartus_eda <project name> --simulation=on --format=<format> --tool=ModelSim ↵
```

# Software Licensing and Licensing Setup in ModelSim-Altera

License the ModelSim-Altera software with a parallel port software guard (T-guard), USB guard, FIXEDPC license, or a network FLOATNET or FLOATPC license. Each Altera software subscription includes a license for either VHDL or Verilog HDL. Network licenses with multiple users may have their licenses split between VHDL and Verilog HDL in any ratio.

 The USB software guard is not supported by versions earlier than Mentor Graphics ModelSim software 5.8d.

Obtain a license for the ModelSim-Altera software from the Altera website at [www.altera.com](http://www.altera.com). Get licensing information for the Mentor Graphics ModelSim software directly from Mentor Graphics. Refer to [Figure 2-4](#) for the set-up process.

 For ModelSim-Altera software versions prior to 5.5b, use the PCLS utility included with the software to set up the license.

**Figure 2-4. ModelSim-Altera Software Licensing Set Up Process**



## LM\_LICENSE\_FILE Variable

Altera recommends setting the `LM_LICENSE_FILE` environment variable to the location of the license file. For example, the value for the `LM_LICENSE_FILE` environment variable should point to `<path to license file>\license.dat`.



For more information about setting up the license for ModelSim-Altera software, refer to [AN 340: Altera Software Licensing](#).

## Conclusion

Using the ModelSim and ModelSim-Altera simulation software within the Altera FPGA design flow enables Altera software users to easily and accurately perform RTL functional simulations, post-synthesis simulations, and gate-level simulations on their designs. Proper verification of designs at the functional, post-synthesis, and post place-and-route stages using the ModelSim and ModelSim-Altera software helps ensure design functionality and success and, ultimately, a quick time-to-market.

## Referenced Documents

This chapter references the following documents:

- *AN 340: Altera Software Licensing*
- *PowerPlay Power Analysis* chapter in volume 3 of the *Quartus II Handbook*
- *Quartus II Classic Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*
- *Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*
- *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*
- *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*

# Document Revision History

Table 2–14 shows the revision history for this chapter.

| <b>Table 2–14. Document Revision History (Part 1 of 2)</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                  |
|------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|
| <b>Date and Document Version</b>                           | <b>Changes Made</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <b>Summary of Changes</b>                        |
| May 2008<br>v8.0.0                                         | <ul style="list-style-type: none"> <li>Updated “Altera Design Flow with ModelSim-Altera or Modelsim Software” on page 2–3</li> <li>Updated “Simulation Libraries” on page 2–5</li> <li>Updated “Simulation Netlist Files” on page 2–13</li> <li>Updated “Perform Simulation Using ModelSim-Altera Software” on page 2–18</li> <li>Updated “Perform Simulation Using Modelsim Software” on page 2–43</li> <li>Updated “Simulating Designs that Include Transceivers” on page 2–77</li> <li>Updated “Using the NativeLink Feature with ModelSim-Altera or ModelSim Software” on page 2–86</li> <li>Updated “Generating a Timing VCD File for PowerPlay” on page 2–92</li> </ul> | Updated for the Quartus II software version 8.0. |
| October 2007<br>v7.2.0                                     | Updated Table 2–2.<br>Updated “Operating Condition Example: Generate All Timing Models for Stratix III Devices” on page 2–25.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Updated for the Quartus II software version 7.2. |
| May 2007<br>v7.1.0                                         | Updated “Functional RTL Simulation” on page 2–5.<br>Updated “Gate-Level Timing Simulation” on page 2–23.<br>Added “Perform Timing Simulation Using Post-synthesis Netlist” on page 2–26.<br>Updated examples in “Simulating Designs that Include Transceivers” on page 2–37.<br>Updated procedures in “Setting Up a Testbench” on page 2–48.<br>Added “Referenced Documents” on page 2–52.                                                                                                                                                                                                                                                                                    | Updated for the Quartus II software version 7.1. |
| March 2007<br>v7.0.0                                       | Updated Quartus II software 7.0 revision and date only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | —                                                |
| November 2006<br>v6.1.0                                    | <ul style="list-style-type: none"> <li>Added ModelSim-Altera Web Edition to Table 2–1.</li> <li>Added Stratix III library support to Table 2–8, 2–9, and 2–10.</li> <li>Other minor changes to chapter.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Updated for the Quartus II software version 6.1. |
| May 2006<br>v6.0.0                                         | Updated for the Quartus II software version 6.0.0: <ul style="list-style-type: none"> <li>Added a section on setting ModelSim as the Simulation Tool.</li> <li>Updated EDA Tools Settings in the GUI.</li> <li>Updated the Synopsys Design Constraints File information.</li> <li>Updated the device information.</li> <li>Added Quartus II-Generated Testbench information</li> <li>Updated megafunction information.</li> </ul>                                                                                                                                                                                                                                             | —                                                |
| October 2005<br>v5.1.0                                     | Updated for the Quartus II software version 5.1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | —                                                |

| <b>Table 2–14. Document Revision History (Part 2 of 2)</b> |                                                                                                                                                                                      |                           |
|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
| <b>Date and Document Version</b>                           | <b>Changes Made</b>                                                                                                                                                                  | <b>Summary of Changes</b> |
| May 2005<br>v5.0.0                                         | <ul style="list-style-type: none"><li>Updates to tables, figures.</li><li>Updated information.</li><li>New functionality for Quartus II software 5.0.</li></ul>                      | —                         |
| December 2004<br>v3.0                                      | <ul style="list-style-type: none"><li>Reorganized chapter, updated information.</li><li>Updates to tables, figures.</li><li>New functionality for Quartus II software 4.2.</li></ul> | —                         |
| June 2004<br>v2.0                                          | <ul style="list-style-type: none"><li>Updates to tables, figures.</li><li>New functionality for Quartus II software 4.1.</li></ul>                                                   | —                         |
| February 2004<br>v1.0                                      | Initial release.                                                                                                                                                                     | —                         |

## Introduction

This chapter is an overview about using the Synopsys VCS software to simulate designs that target Altera® FPGAs. It provides a step-by-step explanation of how to perform register transfer level (RTL) functional simulations, post-synthesis simulations, and gate-level timing simulations using the VCS software.

This chapter discusses the following topics:

- “Software Requirements”
- “Common VCS Software Compiler Options” on page 3-12
- “Using VirSim” on page 3-13
- “Debugging Support Command-Line Interface” on page 3-13
- “Simulating Designs that Include Transceivers” on page 3-14
- “Transport Delays” on page 3-17
- “Using NativeLink with the VCS Software” on page 3-18
- “Generating a Timing VCD File for PowerPlay” on page 3-23
- “Scripting Support” on page 3-24

## Software Requirements

To simulate your design using VCS, you must first set up the Altera libraries. These libraries are installed with the Quartus® II software.

Table 3-1 shows the compatibility between versions of the Quartus II software and the Synopsys VCS software.

**Table 3-1. Supported Quartus II and VCS Software Version Compatibility**

| Synopsys                           | Altera                                  |
|------------------------------------|-----------------------------------------|
| VCS software version Y-2006.06-SP1 | Quartus II software version 7.2 and 8.0 |
| VCS software version 2006.06       | Quartus II software version 7.1         |
| VCS software version 2005.06-SP2   | Quartus II software version 7.0 and 6.1 |
| VCS software version 2005.06-SP1   | Quartus II software version 6.0         |
| VCS software version 7.2           | Quartus II software version 5.1         |
| VCS software version 7.2           | Quartus II software version 5.0         |
| VCS software version 7.1.1         | Quartus II software version 4.2         |



For more information about installing the software and the directories created during the Quartus II software installation, refer to the *Quartus II Installation and Licensing for Windows* or the *Quartus II Installation and Licensing for UNIX and Linux Workstation* manuals.

## Using VCS in the Quartus II Design Flow

You can perform the following types of simulations using VCS:

- RTL Functional Simulation
- Post-synthesis Simulation
- Gate-level timing Simulation

Figure 3–1 shows the VCS and Quartus II software design flow.

**Figure 3–1. Altera Design Flow with the VCS and Quartus II Software**



**Notes to Figure 3–1:**

- (1) RTL functional simulation is performed before a gate-level timing simulation or post-synthesis simulation. RTL functional simulation verifies the functionality of the design before synthesis and place-and-route. If you are performing a functional simulation through NativeLink, you must complete analysis and elaboration first.
- (2) A post-synthesis simulation verifies the functionality of a design after synthesis has been performed.

- 
- (3) Gate-level timing simulation is a post place-and-route simulation to verify the operation of the design after the timing delays have been calculated.
  - (4) All these simulation libraries are located at *<quartus installation directory>\eda\sim\_lib*.
- 

## RTL Functional Simulations

RTL functional simulations verify the functionality of the design before synthesis, placement, and routing. These simulations are independent of any Altera FPGA architecture implementation. After the HDL designs are verified to be functionally correct, the next step is to synthesize the design and use the Quartus II software to place-and-route the design in an Altera device.

To functionally simulate an Altera FPGA design in the VCS software that uses Altera intellectual property (IP) megafunctions, or library of parameterized modules (LPM) functions, you must include certain libraries during the compilation. **Table 3–2** summarizes the Verilog HDL library files that are required to compile LPM functions and Altera megafunctions.

**Table 3–2. Altera Verilog HDL Functional/Behavioral Simulation Library Files**

| Library Name | Verilog HDL Libraries                                                  |
|--------------|------------------------------------------------------------------------|
| altgx        | <b>stratixiv_hssi_atoms.v</b>                                          |
| LPM          | <b>220model.v</b>                                                      |
| altera_mf    | <b>altera_mf.v</b>                                                     |
| altgxgb      | <b>stratixgx_mf.v (1)</b>                                              |
| alt2gxgb     | <b>stratixiigx_hssi_atoms.v (1)</b><br><b>arriagx_hssi_atoms.v (1)</b> |
| sgate        | <b>sgate.v</b>                                                         |
| altera       | <b>altera_primitives.v</b>                                             |

*Note to Table 3–2:*

- (1) The **stratixgx\_mf.v**, **stratixiigx\_hssi\_atoms.v**, **arriagx\_hssi\_atoms.v**, and **stratixiv\_hssi\_atoms.v** library files require the LPM and SGATE libraries.

The library files in **Table 3–2** are installed with the Quartus II software. These files are found in the *<path to Quartus II installation>\eda\sim\_lib* directory.

The following is a VCS command for performing an RTL functional simulation with one of the libraries in [Table 3–2](#):

```
vcs -R <testbench>.v <design name>.v -v <library file1>.v \
-v <library file 2>.v ↵
```

### *Megafunctions Requiring Atom Libraries*

The following Altera megafunctions require gate-level libraries to perform a functional simulation in a third-party simulator:

- ALTCLKBUF
- ALTCLKCTRL
- ALTDQ
- ALTDQS
- ALTDDIO\_IN
- ALTDDIO\_OUT
- ALTDDIO\_BIDIR
- ALTUFM\_NONE
- ALTUFM\_PARALLEL
- ALTUFM\_SPI
- ALTMEMMULT
- ALTREMOTE\_UPDATE

The gate-level library files are located in *<path to Quartus II installation>eda/sim\_lib* directory ([Table 3–3](#)).

### *RTL Functional Simulation with Altera Memory Blocks*

The VCS software supports functional simulation of complex Altera memory blocks such as lpm\_ram\_dp and altsyncram. You can create these memory blocks with the Quartus II MegaWizard® Plug-In Manager, which can be initialized with power-up data via a Hexadecimal (Intel-Format) File (.hex) or Memory Initialization File (.mif). The lpm\_file parameter included in the file generated by the MegaWizard Plug-In Manager points to the path of the .hex file or .mif file that is used to initialize the memory block. You can create a .hex file or .mif file with the Quartus II software.

## **Post-Synthesis Simulation**

A post-synthesis simulation verifies the functionality of a design after synthesis has been performed. You can create a post-synthesis netlist in the Quartus II software and use this netlist to perform a post-synthesis simulation in the VCS software. Once the post-synthesis version of the design has been verified, the next step is to place-and-route the design in the target architecture using the Quartus II software.

### *Generating a Post-Synthesis Simulation Netlist*

The following steps describe the process of generating a post-synthesis simulation netlist in the Quartus II software:

1. Perform Analysis and Synthesis. On the Processing menu, point to **Start** and click **Start Analysis & Synthesis**.
2. Turn on the **Generate Netlist for Functional Simulation Only** option by performing the following steps:
  - a. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
  - b. In the **Category** list, under **EDA Tool Settings** select **Simulation**. The **Simulation** dialog box appears.
  - c. In the **Tool name** list, select **VCS**.
  - d. You can modify where you want the post-synthesis netlist generated by editing or browsing to a directory in the **Output directory** box.
  - e. Click **More Settings**. The **More EDA Tools Simulation Settings** dialog box appears. In the **Existing options settings** list, click **Generate Netlist for Functional Simulation Only** and select **On** from the **Setting** list under **Option**.
  - f. Click **OK**.
  - g. In the **Settings** dialog box, click **OK**.
3. Run the EDA Netlist Writer. On the Processing menu, point to **Start** and click **Start EDA Netlist Writer**.

During the EDA Netlist Writer stage, the Quartus II software produces a Verilog Output File (.vo) that can be used for post-synthesis simulation in the VCS software. This netlist file is mapped to architecture-specific primitives. No timing information is included at this stage.

The resulting netlist is located in the output directory you specified in the **Settings** dialog box, which defaults to the `<project directory>/simulation/vcs` directory. This netlist, along with the device family library listed in [Table 3–3](#), can be used to perform a post-synthesis simulation in the VCS software.

**Table 3–3. Altera Gate-Level Timing Simulation Library Files**

| Library Files                                                                                                    | Description                                                     |
|------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|
| <code>arriagx_atoms.v</code><br><code>arriagx_hssi_atoms.v</code>                                                | Atom libraries for Arria™ GX designs                            |
| <code>stratixiv_atoms.v</code><br><code>stratixiv_hssi_atoms.v</code><br><code>stratixiv_pcie_hip_atoms.v</code> | Atom libraries for Stratix® IV designs                          |
| <code>stratixiii_atoms.v</code>                                                                                  | Atom libraries for Stratix III designs                          |
| <code>stratixii_atoms.v</code>                                                                                   | Atom libraries for Stratix II designs                           |
| <code>stratixiigx_atoms.v</code><br><code>stratixiigx_hssi_atoms.v</code>                                        | Atom libraries for Stratix II GX designs                        |
| <code>stratix_atoms.v</code>                                                                                     | Atom libraries for Stratix designs                              |
| <code>stratixgx_atoms.v</code><br><code>stratixgx_hssi_atoms.v</code>                                            | Atom libraries for Stratix GX designs                           |
| <code>hardcopyii_atoms.v</code>                                                                                  | Atom libraries for HardCopy® II designs                         |
| <code>hcstratix_atoms.v</code>                                                                                   | Atom libraries for HardCopy Stratix designs                     |
| <code>cycloneiii_atoms.v</code>                                                                                  | Atom libraries for Cyclone® III designs                         |
| <code>cycloneii_atoms.v</code>                                                                                   | Atom libraries for Cyclone II designs                           |
| <code>cyclone_atoms.v</code>                                                                                     | Atom libraries for Cyclone designs                              |
| <code>apexii_atoms.v</code>                                                                                      | Atom libraries for APEX™ II designs                             |
| <code>apex20ke_atoms.v</code>                                                                                    | Atom libraries for APEX 20KE, APEX 20KC, and Excalibur™ designs |
| <code>apex20k_atoms.v</code>                                                                                     | Atom libraries for APEX 20K designs                             |
| <code>flex10ke_atoms.v</code>                                                                                    | Atom libraries for FLEX® 10KE and ACEX® 1K designs              |
| <code>flex6000_atoms.v</code>                                                                                    | Atom libraries for FLEX 6000 designs                            |
| <code>maxii_atoms.v</code>                                                                                       | Atom libraries for MAX® II designs                              |
| <code>max_atoms.v</code>                                                                                         | Atom libraries for MAX 3000 and MAX 7000 designs                |

The following VCS software command shows the command-line syntax used to perform a post-synthesis simulation with the appropriate device family library listed in [Table 3–3](#):

```
vcs -R <testbench> <post synthesis netlist> -v <Altera device family library> ↵
```

## Gate-Level Timing Simulation

A gate-level timing simulation verifies the functionality of the design after place-and-route. You can create a post-fit netlist in the Quartus II software and use this netlist to perform a gate-level timing simulation in the VCS software.

### Generating a Gate-Level Timing Simulation Netlist

To perform gate-level timing simulation, the VCS software requires information about how the design was placed into device-specific architectural blocks. The Quartus II software provides this information in the form of a Verilog Output File for Verilog HDL designs. The accompanying timing information is stored in the Standard Delay Output File (**.sdo**), which annotates the delay for the elements found in the **.vo** file.

The following steps describe the process of generating a gate-level timing simulation netlist in the Quartus II software:

1. Perform a full compilation. On the Processing menu, click **Start Compilation**.
2. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
3. In the **Category** list, under **EDA Tool Settings**, select **Simulation**. The **Simulation** dialog box appears.
4. In the **Tool name** list, select **VCS**.
5. You can modify where you want the post-synthesis netlist generated by editing or browsing to a directory in the **Output directory** box.
6. Click **OK**.
7. In the **Settings** dialog box, click **OK**.
8. Run the EDA Netlist Writer. On the Processing menu, point to **Start** and click **Start EDA Netlist Writer**.

During the EDA Netlist Writer stage, the Quartus II software produces a **.vo** file that can be used for post-synthesis simulations in the VCS software. This netlist file is mapped to architecture-specific primitives.

No timing information is included at this stage. The resulting netlist is located in the output directory you specified in the **Settings** dialog box, which defaults to the `<project directory>/simulation/vcs` directory.

### *Generating a Timing Netlist with Different Timing Models*

In Stratix III and later devices (for example, Cyclone III and Stratix IV) you can specify different temperature and voltage parameters to generate the timing netlist. If you enable the Quartus II Classic Timing Analyzer or Quartus II TimeQuest Timing Analyzer when generating the simulation netlist files (`*.vo` or `*.vho` and `*.sdo`), different timing models for different operating conditions are used by default. The multi-corner timing analysis is run by default during the full compilation.

**Table 3-4** shows an example of default available operation conditions (model, voltage, and temperature) for Stratix III and Cyclone III devices.

| <b>Table 3-4. Default Available Operating Condition for Stratix III and Cyclone III Devices</b> |       |         |                 |
|-------------------------------------------------------------------------------------------------|-------|---------|-----------------|
| Device Family                                                                                   | Model | Voltage | Temperature (C) |
| Stratix III                                                                                     | Slow  | 1100 mV | 85°             |
|                                                                                                 | Slow  | 1100 mV | 0°              |
|                                                                                                 | Fast  | 1100 mV | 0°              |
| Cyclone III                                                                                     | Slow  | 1200 mV | 85°             |
|                                                                                                 | Slow  | 1200 mV | 0°              |
|                                                                                                 | Fast  | 1200 mV | 0°              |

If the multi-corner timing analysis is not run during full compilation, you should perform the following steps to manually generate the simulation netlist files (`*.vo` or `*.vho` and `*.sdo`) for the three different operating conditions listed in **Table 3-4**:

1. Generate all the available corner models at all operating conditions. Type the following command at a command prompt:

```
quartus_sta <project name> --multicorner ↵
```

2. Generate the simulation output files for all three corners specified in **Table 3-4**. Perform steps 2 through 8 in “[Generating a Gate-Level Timing Simulation Netlist](#)” on page 3-8. The output files are generated in the simulation output directory.

The following example shows all the generated simulation netlist files for the three operating conditions of the preceding steps, when **Verilog** is selected as the output netlist format:

**First slow corner (slow, 1100 mV, 85° C):**

VO file— *<revision name>.vo*

SDO file— *<revision name>\_v.sdo*

 The *<revision name>.vo* and *<revision name>\_v.sdo* are generated for backward compatibility in case there are existing scripts that still use them.

VO file— *<revision name>\_<speedgrade>\_1100mv\_85c\_slow.vo*

SDO file— *<revision name>\_<speedgrade>\_1100mv\_85c\_v\_slow.sdo*

**Second slow corner (slow, 1100 mV, 0° C):**

VO file— *<revision name>\_<speedgrade>\_1100mv\_0c\_slow.vo*

SDO file— *<revision name>\_<speedgrade>\_1100mv\_0c\_v\_slow.sdo*

**Fast corner (fast, 1100 mV, 0° C):**

VO file— *<revision name>\_min\_1100mv\_0c\_fast.vo*

SDO file— *<revision name>\_min\_1100mv\_0c\_v\_fast.sdo*

For all other older device families, (for example, Stratix II and Stratix) a slow-corner (worst case) timing model is used by default. There are only two timing models available, the slow-corner and fast-corner timing models. To generate the SDO file using a different timing model, you must run the Quartus II Classic Timing Analyzer or the Quartus II TimeQuest Timing Analyzer with a different timing model before you start the EDA Netlist Writer.

To run the Quartus II Classic Timing Analyzer with the best-case model, on the Processing menu, point to **Start** and click **Start Classic Timing Analyzer (Fast Timing Model)**. After the timing analysis is complete, the Compilation Report appears. You can also type the following command at a command prompt:

```
quartus_tan <project_name> --fast_model=on ↵
```

To run the Quartus II TimeQuest Timing Analyzer with a best-case model, use the **-fast\_model** option after you create the timing netlist. The following command enables the fast timing models:

```
create_timing_netlist --fast_model ↵
```

After you run the Quartus II Classic Timing Analyzer or Quartus II TimeQuest Timing Analyzer, you can perform steps 2 through 8 in “Generating a Gate-Level Timing Simulation Netlist” on page 3–8 to generate the \*.sdo file. For fast-corner timing models, the -fast post fix is added to the \*.vo or \*.vho and \*.sdo files (for example, **my\_project\_fast.vo** or **my\_project\_fast.vho** and **my\_project\_fast.sdo**).



For more information about generating the timing netlist with different timing models, refer to the *Quartus II Classic Timing Analyzer* or the *Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

## Disable Timing Violation on Registers

In certain situations, the timing violations can be ignored and you want to disable the timing violation on registers (for example, timing violations that occur in internal synchronization registers used for asynchronous clock-domain crossing).

By default, the **x\_onViolationOption** logic option is **On**, which means simulation will show “X” whenever a timing violation occurs. To disable showing the timing violation on certain registers, you can set the **x\_onViolationOption** logic option to **Off** for those registers. The following command is an example of the QSF file:

```
set_instance_assignment -name X_ON_VIOLATION_OPTION OFF -to <register_name>
```

## Perform Timing Simulation Using the Post-Synthesis Netlist

You can perform a timing simulation using the post-synthesis netlist instead of using a gate-level netlist, and you can generate a SDO without running the fitter. In this case, the SDO file includes all timing values for the device cells only. Interconnect delays are not included because fitting (placement and routing) has not been performed.

To generate the post-synthesis netlist and the SDO file, type the following command at a command prompt:

```
quartus_map <project name> -c <revision name> ↵
quartus_tan <project name> -c <revision name> --post_map --zero_ic_delays ↵
quartus_eda <project name> -c <revision name> --simulation \
--tool= <third-party EDA tool> --format=<HDL language> ↵
```

For more information about the `-format` and `-tool` options, type the following command: `quartus_eda -help=<options> command`

## Common VCS Software Compiler Options

The VCS software has options that help you simulate your design. [Table 3–5](#) lists some of the available options.

**Table 3–5. VCS Software Compiler Options**

| Library                                   | Description                                                                                                                                                                                                                                                                      |
|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-R</code>                           | Runs the executable file immediately.                                                                                                                                                                                                                                            |
| <code>-RI</code>                          | Once the compile has completed, instructs the VCS software to automatically launch VirSim.                                                                                                                                                                                       |
| <code>-v &lt;library filename&gt;</code>  | Specifies a Verilog HDL library file (for example, <code>220model.v</code> or <code>altera_mf.v</code> ). The VCS software looks in this file for module definitions that are found in the source code. Only the relevant library files are compiled based on the modules found. |
| <code>-y &lt;library directory&gt;</code> | Specifies a Verilog HDL library directory. The VCS software looks for library files in this folder that contain module definitions that are instantiated in the source code.                                                                                                     |
| <code>+compsdf</code>                     | Indicates that the VCS software compiler includes the back-annotated SDF file in the compilation.                                                                                                                                                                                |
| <code>+cli</code>                         | The VCS software enters Command-Line Interface (CLI) mode upon successful compilation completion.                                                                                                                                                                                |
| <code>+race</code>                        | Specifies that the VCS software generate a report that indicates all of the race conditions in the design. The default report name is <code>race.out</code> .                                                                                                                    |
| <code>-P</code>                           | Compiles user-defined Programming Language Interface (PLI) table files.                                                                                                                                                                                                          |
| <code>-q</code>                           | Indicates the VCS software runs in quiet mode. All messages are suppressed.                                                                                                                                                                                                      |



For more information about VCS software options, refer to the [VCS User Guide](#).

## Using VirSim

VirSim is the graphical debugging system for the VCS software. This tool is included with the VCS software and can be run by using the `-RI` compile-time compiler option when compiling a design. The following VCS software command shows the command-line syntax for compiling and loading a timing simulation in VirSim:

```
vcs -RI <testbench>.v <design name>.vo -v <path to Quartus II installation> \
\eda\sim_lib\<device family>_atoms.v +compsdf ↵
```



For more information about using VirSim, refer to the *VirSim User Guide* included in the VCS software installation.

## Debugging Support Command-Line Interface

The VCS software has an interactive non-graphical debugging capability that is very similar to other UNIX debuggers such as the GNU debugger (GDB). The VCS software CLI can be used to halt simulations at user-defined break points, force registers with values, and display register values.

Enable the non-graphical capability by using the `+cli` run-time option. Use the VCS software CLI to debug your Altera FPGA design by typing the following command:

```
vcs -R <testbench>.v <design name>.vo \
-v <path to Quartus II installation> \
\eda\sim_lib\<device family>_atoms.v +compsdf +cli ↵
```

The `+cli` command takes an optional number argument that specifies the level of debugging capability. As the optional debugging capability is increased, the overhead incurred by the simulation is increased, resulting in an increase in simulation time.



For more information about the `+cli` options, refer to the *VCS User Guide* included in the VCS software installation.

For the design examples to run gate-level timing simulation in VHDL or Verilog language, refer to [www.altera.com/support/examples/vcs/exm-vcs.html](http://www.altera.com/support/examples/vcs/exm-vcs.html).

## Simulating Designs that Include Transceivers

If your design includes a Stratix GX, Stratix II GX, Stratix IV, or Arria GX transceiver, you must compile additional library files to perform functional RTL or gate-level timing simulations.

### Stratix GX RTL Functional Simulation

To perform an RTL functional simulation of your design that instantiates the ALTGXBX megafunction, enabling the gigabit transceiver block gigabit transceiver block on Stratix GX devices, you should compile the **stratixgx\_mf** model file into the **altgxbx** library.

 The **stratixgx\_mf** model file references the **lpm** and **sgate** libraries; you must create these libraries to perform a simulation.

#### *Compiling Library Files for Functional Stratix GX Simulation in Verilog HDL*

To compile the libraries necessary for functional simulation of a Verilog HDL design targeting a Stratix GX device, type the command in Example 3-1 at the VCS command prompt.

---

#### **Example 3-1.**

```
vcs -R <testbench>.v <design files>.v -v stratixgx_mf.v -v sgate.v \
-v 220model.v -v altera_mf.v
```

---

### Stratix GX Gate-Level Timing Simulation

Perform a gate-level timing simulation of your design that includes a Stratix GX transceiver by compiling the **stratixgx\_atoms** and **stratixgx\_hssi\_atoms** model files into the **stratixgx** and **stratixgx\_gxb** libraries, respectively.

 The **stratixgx\_hssi\_atoms** model file references the **lpm** and **sgate** libraries; you must create these libraries to perform a simulation.

*Compiling Library Files for Timing Stratix GX Simulation in Verilog HDL*

To compile the libraries necessary for timing simulation of a Verilog HDL design targeting a Stratix GX device, type the command in Example 3–2 at the VCS command prompt.

**Example 3–2.**

```
vcs -R <testbench>.v <gate-level netlist>.vo -v stratixgx_atoms.v -v \
stratixgx_hssi_atoms.v -v \ sgate.v -v 220model.v -v altera_mf.v \
+transport_int_delays +pulse_int_e/0 +pulse_int_r/0 \
+transport_path_delays +pulse_e/0 +pulse_r/0
```

**Stratix II GX RTL Functional Simulation**

Stratix II GX RTL functional simulation is similar to Arria GX RTL functional simulation. The following example shows only the RTL functional simulation for designs that include transceivers in Stratix II GX. To simulate the transceiver in Arria GX, you only need to replace the **stratixiigx\_hssi** model file with the **arriagx\_hssi** model file.

To perform an RTL functional simulation of your design that instantiates the ALT2GXB megafunction, enabling the gigabit transceiver block gigabit transceiver block on Stratix II GX devices, you should compile the **stratixiigx\_hssi** model file into the **stratixiigx\_hssi** library.



The **stratixiigx\_hssi\_atoms** model file references the **lpm** and **sgate** libraries; you must create these libraries to perform a simulation.

Generate a functional simulation netlist by turning on **Generate Simulation Model in the Simulation Library** in the alt2gxb MegaWizard Plug-In Manager (Figure 3–2). The **<alt2gxb entity name>.vho** file or **<alt2gxb module name>.vo** file is generated in the current project directory.



The Quartus II-generated alt2gxb functional simulation library file references **stratixiigx\_hssi wysiwyg atoms**.

Figure 3-2. ALT2GXB MegaWizard



### Compiling Library Files for Stratix II GX RTL Functional Simulation in Verilog HDL

To compile the libraries necessary for functional simulation of a Verilog HDL design targeting a Stratix II GX device, type the command in Example 3-2 at the VCS command prompt.

#### Example 3-3.

```
vcs -R <testbench>.v <alt2gxb simulation netlist>.vo -v stratixgx_hssi_atoms.v \
-v sgate.v -v 220model.v -v altera_mf.v
```

## Stratix II GX Gate-Level Timing Simulation

Stratix II GX gate-level timing simulation is similar to Arria GX gate-level timing simulation. The following example shows only the gate-level timing simulation for designs that include transceivers in Stratix II GX. To simulate the transceiver in Arria GX, you only need to replace the **stratixiigx\_hssi** model file with the **arriagx\_hssi** model file.

To perform a gate-level timing simulation of your design that includes a Stratix II GX transceiver, compile **stratixiigx\_atoms** and **stratixiigx\_hssi\_atoms** into the **stratixiigx** and **stratixiigx\_hssi** libraries, respectively.



The **stratixiigx\_hssi\_atoms** model file references the **lpm** and **sgate** libraries; so you must create these libraries to perform a simulation.

### *Compiling Library Files for Stratix II GX Gate-Level Timing Simulation in Verilog HDL*

To compile the libraries necessary for timing simulation of a Verilog HDL design targeting a Stratix II GX device, type the command in Example 3-4 at the VCS command prompt.

---

#### **Example 3-4.**

```
vcs -R <testbench>.v <gate-level netlist>.vo -v stratixiigx_atoms.v -v \
stratixiigx_hssi_atoms.v -v sgate.v -v 220model.v -v altera_mf.v \
+transport_int_delays +pulse_int_e/0 +pulse_int_r/0 \
+transport_path_delays +pulse_e/0 +pulse_r/0
```

---

## Transport Delays

By default, the VCS software filters out all pulses that are shorter than the propagation delay between primitives. Turning on the transport delay options in the VCS software prevents the simulation tool from filtering out these pulses. Use the following options to ensure that all signal pulses are seen in the simulation results.

*+transport\_path\_delays*

Use this option when the pulses in your simulation may be shorter than the delay within a gate-level primitive. You must include the **+pulse\_e/number** and **+pulse\_r/number** options.

`+transport_int_delays`

Use this option when the pulses in your simulation may be shorter than the interconnect delay between gate-level primitives. You must include the `+pulse_int_e/number` and `+pulse_int_r/number` options. The `+transport_path_delays` and `+transport_int_delays` options are also used by default in the NativeLink feature for gate-level timing simulation.



For more information about either of these options, refer to the *VCS User Guide* installed with the VCS software.

The following VCS software command shows the command-line syntax to perform a post-synthesis simulation with the device family library:

```
vcs -R <testbench>.v <gate-level netlist>.v -v <Altera device family library>.v \
+transport_int_delays +pulse_int_e/0 +pulse_int_r/0 \
+transport_path_delays +pulse_e/0 +pulse_r/0 ↵
```

## Using NativeLink with the VCS Software

The NativeLink® feature in the Quartus II software facilitates the seamless transfer of information between the Quartus II software and EDA tools and allows you to run VCS within the Quartus II software.

### Setting Up NativeLink

To run VCS automatically from the Quartus II software using the NativeLink feature, you must specify the path to your simulation tool by performing the following steps:

1. On the Tools menu, click **Options**. The **Options** dialog box appears.
2. In the **Category** list, select **EDA Tool Options**. The **EDA Tool Options** dialog box appears.
3. Double-click the entry under the **Location of executable** column.
4. Type or browse to the directory containing the executables of your EDA tool.
5. Click **OK**.

You can also specify the path to the simulator's executables by using the `set_user_option` Tcl command:

```
set_user_option -name EDA_TOOL_PATH_VCS <path to executables> ↵
```

## Performing an RTL Simulation Using NativeLink

To run an RTL functional simulation automatically with the VCS software in the Quartus II software, perform the following steps:

1. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
2. In the **Category** list, select **Simulation**. The **Simulation** page appears (Figure 3–3).

**Figure 3–3. Simulation Page in the Settings Dialog Box**



3. In the **Tool name** list, select **VCS**. You can also modify where you want the post-synthesis netlist generated by editing or browsing to a directory in the **Output directory** box.

4. If you have testbench files or macro scripts, enter the information under **NativeLink settings**.

For more information about setting up a testbench with NativeLink, refer to “[Setting Up a Testbench](#)” on page 3–21.

5. Click **OK**.
6. On the Processing menu, point to **Start** and click **Start Analysis & Elaboration** to perform an analysis and elaboration. This command collects all your file name information and builds your design hierarchy in preparation for simulation.
7. On the Tools menu, point to **Run EDA Simulation Tool** and click **EDA RTL Simulation** to automatically launch VCS, compile all necessary design files, and complete a simulation.

## Performing a Gate-Level Timing Simulation Using NativeLink

To automatically run a gate-level timing simulation with the VCS software in the Quartus II software, perform the following steps:

1. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
2. In the **Category** list, select **Simulation**. The **Simulation** page appears ([Figure 3–3](#)).
3. In the **Tool name** list, select **VCS**.
4. You can modify where you want the post-synthesis netlist generated by editing or browsing to a directory in the **Output directory** box.
5. To perform a gate level simulation after each full compilation, turn on **Run Gate Level Simulation automatically after compilation**.
6. If you have testbench files or macro scripts, enter the information under **NativeLink settings**.
7. Click **OK**.
8. Perform a full compilation. On the Processing menu, click **Start Compilation**.
9. On the Processing menu, point to **Start** and click **Start EDA Netlist Writer** to generate a simulation netlist of your design.



If you have run full compilation after you set the EDA Tool settings, the **Start EDA Netlist Writer** step is not required.

10. On the Tools menu, point to **Run EDA Simulation Tool** and click **EDA Gate Level Simulation** to automatically launch VCS, compile all necessary design files, and complete a simulation.



If multi-corner Timing Analysis is performed, a dialog box appears, asking you to select the timing corner to run simulation. Select the timing corner and click **Run**.



A VCS file (\*.vcs) is generated in the `<project_directory>\simulation\vcs` directory while running the NativeLink. With this .vcs file, you can simulate the design using the following command without using NativeLink:

```
vcs -file <project_directory>\simulation\vcs\<generated_do_file>.vcs
```

## Setting Up a Testbench

You can automatically launch your EDA simulator tool, compile your design files and testbench files, and perform a simulation automatically using the NativeLink feature.

To setup NativeLink with a testbench, perform the following steps:

1. On the Assignments menu, click **Settings**. The **Settings** dialog box appears.
2. Click the "+" icon to expand **EDA Tool Settings** and select **Simulation**. The **Simulation** page appears.
3. Under **NativeLink settings**, select **None** or **Compile test bench**. See [Table 3-6](#).

**Table 3-6. NativeLink Settings**

| Settings          | Description                                                                                  |
|-------------------|----------------------------------------------------------------------------------------------|
| None              | Compile simulation models and design files.                                                  |
| Compile testbench | NativeLink compiles simulation models, design files, testbench files, and starts simulation. |

4. If you select **Compile test bench**, select your testbench setup from the **Compile test bench** list. You can use different testbench setups to specify different testbench files for different test scenarios. If there are no testbench setups entered, create a testbench setup by performing the following steps:
  - a. Click **Test Benches**. The **Test Benches** dialog box appears.
  - b. Click **New**. The **New Test Bench Settings** dialog box appears.
  - c. In the **Test bench name** box, type in the testbench setup name which is used to identify the different testbench setups.
  - d. In the **Top level module** box, type in the top-level entity name. For example, for a Quartus II generated Verilog testbench, type in `<Vector Waveform File name>_vlg_vec_tst`.
  - e. In the **Instance** box, type the full instance path to the top level of your FPGA design. For example, for a Quartus II generated Verilog testbench, type `i1`.
  - f. Under **Simulation period**, select **Run simulation until all vector stimuli are used**. If you select **End simulation at**, specify the simulation end time and the time unit.
  - g. Under **Test bench files**, browse and add all your testbench files in the **File name** box. Use the **Up** and **Down** buttons to reorder your files. The script used by NativeLink compiles the files in order from top to the bottom.



You can also specify the library name and the HDL version to compile the testbench file. NativeLink compiles the testbench to the library name of the HDL specified version.

- h. Click **OK**.
- i. In the **Test Benches** dialog box, click **OK**.

### *Creating a Testbench*

In the Quartus II software, you can create a Verilog HDL or VHDL testbench from a Vector Waveform File. The generated testbench includes the behavior of the input stimulus and applies it to your instantiated top-level FPGA design. To create a Verilog HDL or VHDL testbench, perform the following steps:

1. On the File menu, click **Open**. The **Open** dialog box appears.

2. Click the **Files of type** arrow and select **Waveform/Vector Files**. Select your file.
3. Click **Open**.
4. On the File menu, click **Export**. The **Export** dialog box appears.
5. Click the **Save as type** arrow and select **VHDL Test Bench File (\*.vht)** or **Verilog Test Bench File (\*.vt)**.
6. You can turn on **Add self-checking code to file** to check your simulation results against your Vector Waveform File.
7. Click **Export**.

## Generating a Timing VCD File for PowerPlay

To generate a timing Value Change Dump (\*.vcd) file for PowerPlay, you must first generate a VCD script in the Quartus II software, and then run the VCD script from the VCS software. This timing .vcd file can then be used by PowerPlay for power estimation.

Perform the following steps to generate timing VCD scripts in the Quartus II software:

1. In the Quartus II software, on the Assignments menu, click **Settings**.
2. In the **Settings** dialog box, on the **Simulator Settings** page, choose the appropriate 3rd Party Simulation Tool (for example, VCS) in the **Tool Name** list, and turn on the **Generate Value Change Dump File Script** option.
3. To generate the VCD script file, perform a full compilation.

Perform the following steps to generate a timing .vcd file in the VCS software:

1. In the VCS software, before compiling and simulating your design, include the script in your testbench file where the design under test (DUT) is instantiated:

```
include <revision_name>_dump_all_vcd_nodes.v
```



Include the script within the testbench module block. If you include the script outside of the testbench module block, syntax errors occur during compilation.

2. Run the simulation using the VCS command as usual. Exit the VCS software when the simulation is done and the *<revision\_name>.vcd* is generated in the simulation directory.



Refer to the *PowerPlay Power Analysis* chapter in volume 3 of the *Quartus\_II Handbook* for more detailed information about using the timing .vcd file for power estimation.

## Scripting Support



For more information about Tcl scripting, refer to the *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*.

For more information about command-line scripting, refer to the *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*.

For detailed information about scripting command options, refer to the **Qhelp** utility.

To start the **Qhelp** utility, type this command:

```
quartus_sh --qhelp ↵
```

## Generating a Post-Synthesis Simulation Netlist for VCS

You can use the Quartus II software to generate a post-synthesis simulation netlist with Tcl commands or with a command at a command prompt.

### Tcl Commands

Use the following Tcl commands to generate a post-synthesis simulation netlist:

```
set_global_assignment -name EDA_SIMULATION_TOOL "VCS" ↵
set_global_assignment -name EDA_GENERATE_FUNCTIONAL_NETLIST ON ↵
```

### Command Prompt

Use the following command to generate a simulation output file for the VCS software simulator; specify VHDL or Verilog HDL for the format:

```
quartus_eda <project name> --simulation=on --format=<format> --tool=vcs \
--functional ↵
```

## Generating a Gate-Level Timing Simulation Netlist for VCS

You can use the Quartus II software to generate a gate-level timing simulation netlist with Tcl commands or with a command at a command prompt.

### *Tcl Commands*

Use the following Tcl command to generate a gate-level timing simulation netlist:

```
set_global_assignment -name EDA_SIMULATION_TOOL "VCS" ↵
```

### *Command Prompt*

Use the following command to generate a simulation output file for the VCS software simulator. Specify VHDL or Verilog HDL for the format.

```
quartus_eda <project name> --simulation=on --format=<format> --tool=vcs ↵
```

## Conclusion

You can use the VCS software in your Altera FPGA design flow to easily and accurately perform RTL functional simulations, post-synthesis simulations, and gate-level functional timing simulations. The seamless integration of the Quartus II software and VCS software make this simulation flow an ideal method for fully verifying an FPGA design.

## Referenced Documents

This chapter references the following documents:

- *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*
- *PowerPlay Power Analysis* chapter in volume 3 of the *Quartus II Handbook*
- *Quartus II Classic Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*
- *Quartus II Installation and Licensing for UNIX and Linux Workstation Manual*
- *Quartus II Installation and Licensing for Windows Manual*
- *Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*
- *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*
- *VCS User Guide*
- *VirSim User Guide*

# Document Revision History

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

| <b>Table 3–7. Document Revision History (Part 1 of 2)</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                  |
|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|
| <b>Date and Document Version</b>                          | <b>Changes Made</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | <b>Summary of Changes</b>                        |
| May 2008<br>v8.0.0                                        | <ul style="list-style-type: none"> <li>● Updated Table 3–1.</li> <li>● Updated Figure 3–1.</li> <li>● Updated Table 3–3.</li> <li>● Updated “Generating a Timing Netlist with Different Timing Models” on page 3–9.</li> <li>● Added “Disable Timing Violation on Registers” on page 3–11.</li> <li>● Updated “Simulating Designs that Include Transceivers” on page 3–14.</li> <li>● Updated “Performing a Gate-Level Timing Simulation Using NativeLink” on page 3–20.</li> <li>● Added “Generating a Timing VCD File for PowerPlay” on page 3–23.</li> </ul> | Updated for the Quartus II software version 8.0. |
| October 2007<br>v7.2.0                                    | <ul style="list-style-type: none"> <li>● Updated Table 3–1.</li> <li>● Updated “Operating Condition Example: Generate All Timing Models for Stratix III Devices” on page 3–10.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                       | Updated for the Quartus II software version 7.2. |
| May 2007<br>v7.1.0                                        | <ul style="list-style-type: none"> <li>● Updated Tables 3–1, 3–2, and 3–3.</li> <li>● Updated “Generating a Gate-Level Timing Simulation Netlist” on page 3–8.</li> <li>● Added “Perform Timing Simulation Using Post-Synthesis Netlist” on page 3–11.</li> <li>● Updated “Performing a Gate-Level Timing Simulation Using NativeLink on page 3–20.</li> <li>● Updated procedures in “Setting Up a Testbench” on page 3–21.</li> </ul>                                                                                                                          | Updated for the Quartus II software version 7.1. |
| March 2007<br>v7.0.0                                      | Updated Quartus II software 7.0 revision and date only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | —                                                |
| November 2006<br>v6.1.0                                   | <ul style="list-style-type: none"> <li>● Updated for the Quartus II software version 6.1.</li> <li>● Added library for Stratix III support.</li> <li>● Minor updates to Table 3–1, 3–2, and 3–3.</li> </ul>                                                                                                                                                                                                                                                                                                                                                     | Updated for the Quartus II software version 6.1. |
| May 2006<br>v6.0.0                                        | Updated for the Quartus II software version 6.0.0: <ul style="list-style-type: none"> <li>● Added a section on setting VCS as the Simulation Tool</li> <li>● Updated EDA Tools Settings in the GUI.</li> <li>● Updated the Synopsys Design Constraints File information.</li> <li>● Added pulse_e and pulse_r information to simulation sections.</li> <li>● Added Quartus II-Generated Testbench information</li> <li>● Updated megafunction information.</li> </ul>                                                                                           | —                                                |
| October 2005<br>v5.1.0                                    | Updated for the Quartus II software version 5.1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | —                                                |

| <b>Table 3–7. Document Revision History (Part 2 of 2)</b> |                                                                                                                                                                                                                       |                           |
|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
| <b>Date and Document Version</b>                          | <b>Changes Made</b>                                                                                                                                                                                                   | <b>Summary of Changes</b> |
| May 2005<br>v5.0.0                                        | <ul style="list-style-type: none"><li>● Updated information.</li><li>● Updated tables.</li><li>● Added Using NativeLink® with VCS section.</li><li>● New functionality for Quartus II software version 5.0.</li></ul> |                           |
| December 2004<br>v2.1                                     | <ul style="list-style-type: none"><li>● Updates to tables, figures.</li><li>● New functionality for Quartus II software version 4.2.</li></ul>                                                                        |                           |
| June 2004<br>v2.0                                         | <ul style="list-style-type: none"><li>● Updates to tables and figures.</li><li>● New functionality for the Quartus II software version 4.1.</li></ul>                                                                 |                           |
| February 2004<br>v1.0                                     | <ul style="list-style-type: none"><li>● Initial release.</li></ul>                                                                                                                                                    |                           |

### Introduction

This chapter is a “getting started” guide to using the Cadence Incisive verification platform software in Altera® FPGA design flows. The Incisive verification platform software includes NC-Sim, NC-Verilog, NC-VHDL, Verilog, and VHDL desktop simulators. This chapter provides step-by-step explanations of the basic NC-Sim, NC-Verilog, and NC-VHDL functional, post-synthesis, and gate-level timing simulations. It also describes the location of the simulation libraries and how to automate simulations.

This chapter contains the following topics:

- “Software Requirements”
- “RTL Functional Simulation” on page 4–6
- “Post-Synthesis Simulation” on page 4–20
- “Gate-Level Timing Simulation” on page 4–23
- “Simulating Designs that Include Transceivers” on page 4–30
- “Using the NativeLink Feature with NC-Sim” on page 4–37
- “Generating a Timing VCD File for PowerPlay” on page 4–44
- “Scripting Support” on page 4–44

### Software Requirements

You must first install the Quartus® II software before using it with the Cadence Incisive verification platform software. The Cadence interface is installed automatically when you install the Quartus II software on your computer.

Table 4–1 shows the Cadence NC simulator versions compatible with specific Quartus II software versions.

| <b>Table 4–1. Compatibility Between Software Versions</b> |                              |                            |                               |
|-----------------------------------------------------------|------------------------------|----------------------------|-------------------------------|
| Quartus II Software                                       | Cadence NC Simulators (UNIX) | Cadence NC Simulators (PC) | Cadence NC Simulators (Linux) |
| Version 8.0                                               | Version 6.2                  | —                          | Version 6.2                   |
| Version 7.2                                               | Version 6.1 p001             | —                          | Version 6.1 p001              |
| Version 7.1                                               | Version 5.83 p003            | —                          | Version 5.83 p003             |
| Version 7.0                                               | Version 5.82 p001            | —                          | Version 5.82 p001             |
| Version 6.1                                               | Version 5.82 p001            | Version 5.4 s011           | Version 5.82 p001             |
| Version 6.0                                               | Version 5.5 s012             | Version 5.4 s011           | Version 5.5 s012              |
| Version 5.1                                               | Version 5.4 s011             | Version 5.4 s011           | Version 5.4 s011              |
| Version 5.0                                               | Version 5.4 s004             | Version 5.4 p001           | Version 5.4 s004              |
| Version 4.2                                               | Version 5.1 s017             | Version 5.1 s017           | Version 5.1 s017              |
| Version 4.1                                               | Version 5.1 s012             | Version 5.1 s010           | Version 5.0 p001              |
| Version 4.0                                               | Version 5.0 s005             | Version 5.0 s006           | Version 5.0 p001              |

## Simulation Flow Overview

The Incisive platform software supports the following simulation flows:

- RTL Functional Simulation
- Post-Synthesis Simulation
- Gate-Level Timing Simulation
- Using the NativeLink Feature with NC-Sim

Figure 4–1 shows the Quartus II software and Cadence design flow.

**Figure 4-1. Quartus II Software Design Flow with Cadence NC Simulators****Notes to Figure 4-1:**

- (1) RTL functional simulation is performed before a gate-level timing simulation or post-synthesis simulation. RTL functional simulation verifies the functionality of the design before synthesis and place-and-route. If you are performing a functional simulation with NativeLink, you must complete analysis and elaboration first.
- (2) A post-synthesis simulation verifies the functionality of a design after synthesis has been performed.
- (3) Gate-level timing simulation is a post place-and-route simulation to verify the operation of the design after the worst-case timing delays have been calculated.
- (4) All these simulation libraries are located at <quartus installation>

*directory>\eda\sim.lib.*

---

RTL functional simulation verifies the functionality of your design. When you perform a RTL functional simulation with Cadence Incisive simulators, you use your design files (Verilog HDL or VHDL) and the models provided with the Quartus II software. These Quartus II models are required if your design uses the library of parameterized modules (LPM) functions or Altera-specific megafunctions. Refer to [“RTL Functional Simulation” on page 4–6](#) for more information about how to perform this simulation.

A post-synthesis simulation verifies the functionality of a design after synthesis has been performed. You can create a post-synthesis netlist (**.vo** or **.vho**) in the Quartus II software and use this netlist to perform a post-synthesis simulation with the Incisive simulator. Refer to [“Post-Synthesis Simulation” on page 4–20](#) for more information about how to perform this simulation.

After performing place-and-route, the Quartus II software generates a Verilog Output File (**.vo**) or VHDL Output File (**.vho**) and a Standard Delay Output file (**.sdo**) for gate-level timing simulation. The netlist files map your design to architecture-specific primitives. The SDO file contains the delay information of each architecture primitive and routing element specific to your design. Together, these files provide an accurate simulation of your design with the selected Altera FPGA architecture. Refer to [“Gate-Level Timing Simulation” on page 4–23](#) for more information about how to perform this simulation.

## Operation Modes

In the NC simulators, you can use either the GUI mode or the command-line mode to simulate your design.

To start the Incisive simulators in GUI mode in a PC or a UNIX environment, at a command prompt, type the following:

`nclaunch ↵`

To simulate in command-line mode, use the programs shown in [Table 4–2](#).

| <b>Table 4–2. Command-Line Programs</b> |                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Program                                 | Function                                                                                                                                                                                                                                                                                                                                            |
| <b>ncvlog</b><br>or<br><b>ncvhdl</b>    | NC-Verilog ( <b>ncvlog</b> ) compiles your Verilog HDL code into a Verilog Syntax Tree ( <b>.vst</b> ) file. <b>ncvlog</b> also performs syntax and static semantics checks.<br><br>NC-VHDL ( <b>ncvhdl</b> ) compiles your VHDL code into a VHDL Syntax Tree ( <b>.ast</b> ) file. <b>ncvhdl</b> also performs syntax and static semantics checks. |
| <b>ncelab</b>                           | NC-Elab ( <b>ncelab</b> ) elaborates the design. <b>ncelab</b> constructs the design hierarchy and establishes signal connectivity. This program also generates a Signature File ( <b>.sig</b> ) and a Simulation SnapShot File ( <b>.sss</b> ).                                                                                                    |
| <b>ncsim</b>                            | NC-Sim ( <b>ncsim</b> ) performs mixed-language simulation. This program is the simulation kernel that performs event scheduling and executes the simulation code.                                                                                                                                                                                  |

## Quartus II Software and NC Simulation Flow Overview

This section provides an overview of the Quartus II software and Cadence NC simulation flow. More detailed information is provided in [“RTL Functional Simulation” on page 4–6](#), [“Post-Synthesis Simulation” on page 4–20](#), and [“Gate-Level Timing Simulation” on page 4–23](#).

1. Set up your working environment (UNIX only).

You must set several environment variables in UNIX to establish an environment that facilitates entering and processing designs.

2. Create user libraries.

Create a file that maps logical library names to their physical locations. These library mappings include your working directory and any design-specific libraries; for example, Altera LPM functions or megafunctions.

3. Compile source code and testbenches.

Compile your design files at the command-line using **ncvlog** (Verilog HDL files) or **ncvhdl** (VHDL files) or, on the Tools menu, click **Verilog Compiler** or **VHDL Compiler** in NCLaunch. During compilation, the NC software performs syntax and static semantic checks. If no errors are found, compilation produces an internal

representation for each HDL design unit in the source files. By default, these intermediate objects are stored in a single, packed, library database file in your working directory.

4. Elaborate your design.

Before you can simulate your model, you must define the design hierarchy in a process called elaboration. Use **ncelab** in command-line mode, or, on the Tools menu, click **Elaborator** in NCLaunch to elaborate the design.

5. Add signals to your waveform.

Before simulating, specify which signals to view in your waveform using a simulation history manager (SHM) database.

6. Simulate your design.

Run the simulator with the **ncsim** program (command-line mode) or by clicking **Run** in the SimVision Console window.

## RTL Functional Simulation

The following sections provide detailed instructions for performing RTL functional simulation using the Quartus II software and the Cadence Incisive platform software tools.

### Create Libraries

Before simulating with the Incisive simulator, you must set up libraries with a file named **cds.lib**. The **cds.lib** file is an ASCII text file that maps logical library names—for example, your working directory or the location of resource libraries such as models for LPM functions—to their physical directory paths. When you run the Incisive simulator, the tool reads **cds.lib** to determine which libraries are accessible and where they are located. There is also a default **cds.lib** file, which you can modify for your project settings.

You can use more than one **cds.lib** file. For example, you can have a project-wide **cds.lib** file that contains library settings specific to a project such as technology or cell libraries and a user **cds.lib** file.

The following sections describe how to create and edit a **cds.lib** file:

- “Basic Library Setup” on page 4–7
- “LPM Functions, Altera Megafunctions, and Altera Primitive Library Setup” on page 4–9

### Basic Library Setup

You can create a **cds.lib** file with any text editor. The following examples show how you use the **DEFINE** statement to bind a library name to its physical location. The logical and physical names can be the same or you can select different names. The **DEFINE** statement usage is:

```
DEFINE <library name> <physical directory path>
```

A simple **cds.lib** file for Verilog HDL contains the lines shown in Example 4-1.

---

#### Example 4-1.

```
DEFINE lib_std /usr1/libs/std_lib
DEFINE worklib ../worklib
```

---

### Using Multiple **cds.lib** Files

Use the **INCLUDE** or **SOFTINCLUDE** statement to reference another **cds.lib** file within a **cds.lib** file. The syntax is:

```
INCLUDE <path to another cds.lib>
```

or

```
SOFTINCLUDE <path to another cds.lib>
```



For the Windows operating system, enclose the path with quotation marks if there are spaces in the directory path.

For VHDL or mixed-language simulation, in addition to the **DEFINE** statements, you must include the default **cds.lib** file (included with NC-Sim). The syntax for including the default **cds.lib** file is:

```
INCLUDE <path to NC installation>/tools/inca/files/cds.lib
```

or

```
INCLUDE $CDS_INST_DIR/tools/inca/files/cds.lib
```

The default **cds.lib** file, provided with NC tools, contains a **SOFTINCLUDE** statement to include other **cds.lib** files, such as **cdsvhdl.lib** and **cdsvlog.lib**. These files contain library definitions for IEEE libraries and Synopsys libraries.

### Create a **cds.lib** File in Command-Line Mode

To create a **cds.lib** file at a the command prompt, perform the following steps:

1. Create a directory for the work library and any other libraries you need by typing the following command at a command prompt:

```
mkdir <library name> ↵
```

For example: `mkdir worklib ↵`

2. Using a text editor, create a **cds.lib** file and add the following line to it:

```
DEFINE <library name> <physical directory path>
```

For example: `DEFINE worklib ./worklib`

### Create a **cds.lib** File in GUI Mode

To create a **cds.lib** file using the GUI, perform the following steps:

1. To run the GUI, at the command line, type the following command:

```
nclaunch ↵
```

2. If the NCLaunch window is not in multiple step mode, on the File menu, click **Switch to Multiple Step**.
3. Change your design directory. On the File menu, click **Set Design Directory**. The **Set Design Directory** dialog box appears (Figure 4-2).

---

Figure 4–2. Creating a Work Directory in GUI Mode



4. To navigate to your design directory, click **Browse**.
5. Click **Create cds.lib File**. In the **New cds.lib File** dialog box, click **Save** and choose the libraries to include.
6. Under **Work Library**, click **New**.
7. Enter your new work library name; for example, **worklib**.
8. Click **OK**. The new library is displayed under **Work Library**. **Figure 4–2** shows an example using the directory name **worklib**.
9. Repeat steps **7** and **8** for each functional simulation library. For example, **lpm**, **altera\_mf**, and **altera**.
10. In the **Set Design Directory** dialog box, click **OK**.



You can edit your libraries by editing the **cds.lib** file. To edit the **cds.lib** file, in the right side of the window, right-click the **cds.lib** filename and choose **Edit**.

#### *LPM Functions, Altera Megafunctions, and Altera Primitive Library Setup*

Altera provides behavioral descriptions for LPM functions, Altera-specific megafunctions, and Altera primitives. You can implement the megafunctions in a design using the Quartus II MegaWizard® Plug-In Manager, or by instantiating them directly from your design file. If your

design uses LPM functions, Altera megafunctions, or Altera primitives, you must set up resource libraries so you can simulate your design in the Incisive simulator.



Many LPM functions and Altera megafunctions use memory files. You must convert the memory files into a format the Incisive tools can read before simulating. Follow the instructions in ["Compile Source Code and Testbenches" on page 4-12](#) to connect the memory files.

Altera provides megafunction behavioral descriptions in the files shown in [Table 4-3](#). These library files are located in the *<path to Quartus II installation>/eda/sim\_lib* directory.



For more information about LPM functions and Altera megafunctions, refer to the Quartus II Help.

**Table 4-3. Megafunction Behavioral Description Files**

| Library Description            | Verilog HDL                                                              | VHDL                                                                                                                                                        |
|--------------------------------|--------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LPM                            | <b>220model.v</b>                                                        | <b>220model.vhd (1)</b><br><b>220model_87.vhd (2)</b><br><b>220pack.vhd</b>                                                                                 |
| Altera megafunction            | <b>altera_mf.v</b>                                                       | <b>altera_mf.vhd (1)</b><br><b>altera_mf_87.vhd (2)</b><br><b>altera_components.vhd</b>                                                                     |
| Altera primitives              | <b>altera_primitives.v</b>                                               | <b>altera_primitives.vhd (1)</b><br><b>altera_primitives_components.vhd</b>                                                                                 |
| IP functional simulation model | <b>sgate.v</b>                                                           | <b>sgate.vhd</b><br><b>sgate_pack.vhd</b>                                                                                                                   |
| ALTGXBX                        | <b>stratixgx_mf.v (3)</b>                                                | <b>stratixgx_mf.vhd (3)</b><br><b>stratixgx_mf_components.vhd (3)</b>                                                                                       |
| ALT2GXBX                       | <b>stratixiigx_hssi_atoms.v</b> ,<br><b>arriagx_hssi_atoms.v(3), (4)</b> | <b>stratixiigx_hssi_atoms.vhd</b><br><b>stratixiigx_hssi_components.vhd</b><br><b>arriagx_hssi_atoms.vhd</b><br><b>arriagx_hssi_components.vhd (3), (4)</b> |
| ALTGX                          | <b>stratixiv_hssi_atoms.v</b>                                            | <b>stratixiv_hssi_atoms.vhd</b><br><b>stratixiv_hssi_components.vhd</b>                                                                                     |

**Notes to Table 4-3:**

- (1) Use this model with VHDL 93.
- (2) Use this model with VHDL 87.
- (3) The **alt2gxb** and **altgxb** library files require the **lpm** and **sgate** libraries.
- (4) You must generate a functional simulation netlist for simulation.

If an `lpm` library does not exist, set up a library for LPM functions. Create a new directory and add the following line to your `cds.lib` file:

```
DEFINE lpm <path>/<directory name>
```

If an `altera_mf` library does not exist, set up a library for Altera megafunctions. Add the following line to your `cds.lib` file:

```
DEFINE altera_mf <path>/<directory name>
```

### *Megafunctions Requiring Atom Libraries*

The following Altera megafunctions require device atom libraries to perform a functional simulation in a third-party simulator:

- `ALTCLKBUF`
- `ALTCLKCTRL`
- `ALTDQ`
- `ALTDQS`
- `ALTDDIO_IN`
- `ALTDDIO_OUT`
- `ALTDDIO_BIDIR`
- `ALTUFM_NONE`
- `ALTUFM_PARALLEL`
- `ALTUFM_SPI`
- `ALTMEMMULT`
- `ALTREMOTE_UPDATE`



For more information about these megafunctions, refer to the [Literature: Megafunctions](#) section of the Altera website ([www.altera.com](http://www.altera.com)).

The device atom library files are located in the following directory:

`<path to Quartus II installation>/eda/sim_lib`

## Compile Source Code and Testbenches

Compile your testbench and design files with **ncvlog** (for Verilog HDL files) and **ncvhdl** (for VHDL files). Both **ncvlog** and **ncvhdl** perform syntax checks and static semantic checks. A successful compilation produces an internal representation for each HDL design unit in the source files. By default, these intermediate objects are stored in a single, packed, library database file in your work library directory.

### *Compilation in Command-Line Mode*

To compile from the command line, use one of the following commands:

 You must create a work library before compiling.

- Verilog HDL:  
`ncvlog <options> -work <library name> <design files> ↵`
- VHDL:  
`ncvhdl <options> -work <library name> <design files> ↵`

If your design uses LPM, Altera megafunctions, or Altera primitives, you must also compile the Altera-provided functional models. The following commands show an example of each.

- Verilog HDL

---

#### **Example 4-2.**

```
ncvlog -WORK lpm 220model.v
ncvlog -WORK altera_mf altera_mf.v
ncvlog -WORK altera altera_primitives.v
```

---

- VHDL

---

#### **Example 4-3.**

```
ncvhdl -V93 -WORK lpm 220pack.vhd
ncvhdl -V93 -WORK lpm 220model.vhd
ncvhdl -V93 -WORK altera_mf altera_mf_components.vhd
ncvhdl -V93 -WORK altera_mf altera_mf.vhd
ncvhdl -V93 -WORK altera altera_primitives_components.vhd
ncvhdl -V93 -WORK altera altera_primitives.vhd
```

---

### Compilation in GUI Mode

To compile using the NCLaunch GUI, perform the following steps:

1. In the NCLaunch window, right-click a library filename and click NCVlog (Verilog HDL) or NCVhdl (VHDL).

Alternatively, on the Tools menu, click **Verilog Compiler** or **VHDL Compiler**. Figure 4-3 shows the **Compile Verilog** and **Compile VHDL** dialog boxes.

**Figure 4-3. Compiling Verilog HDL and VHDL Files**



2. To begin compilation, in the **Compile Verilog** or **Compile VHDL** dialog box, select the file. Click **OK**. The dialog box closes and returns you to **NCLaunch**.



The command-line equivalent argument is shown at the bottom of the **NCLaunch** window.

## Elaborate Your Design

Before you can simulate your design, you must define the design hierarchy in a process called elaboration. When you use the Incisive simulator, you use the language-independent **ncelab** program to elaborate your design. The **ncelab** program constructs a design hierarchy based on the design's instantiation and configuration information, establishes signal connectivity, and computes initial values for all objects in the design. The elaborated design hierarchy is stored in a simulation snapshot, which is the representation of your design that the simulator uses to run the simulation. The snapshot is stored in the library database file, along with the other intermediate objects generated by the compiler and elaborator.



If you are running the NC-Verilog simulator with the single-step invocation method (**ncverilog**), and want to compile your source files and elaborate the design with one command, use the **+elaborate** option to stop the simulator after elaboration; for example:

```
ncverilog +elaborate test.v ↵
```

### *Elaboration in Command-Line Mode*

To elaborate your Verilog HDL or VHDL design from the command line, use the following command:

```
ncelab [options] [<library>.] <cell> [ :<view>] ↵
```

You can set your simulation timescale using the **-TIMESCALE** *<arguments>* option. The following example elaborates a dual-port RAM with the time scale option:

```
ncelab -TIMESCALE 1ps/1ps worklib.lpm_ram_dp_test:entity ↵
```



If you specified a timescale of 1 ps in the Verilog HDL testbench, the **TIMESCALE** option is not necessary. Using a ps resolution ensures the correct simulation of your design.

If your design includes high speed signals, you may need to add the following pulse reject options with your **ncelab** command.

```
ncelab -TIMESCALE 1ps/1ps worklib.mydesign:entity -PULSE_R 0 -PULSE_INT_R 0 ↵
```



For more information about the pulse reject options, refer to the *SDF Annotate Guide* from Cadence.

To list the elements in your library and the available views, use the **ncls** program. The following command displays all of the cells and their views in your current **worklib** directory:

```
ncls -library worklib ↵
```



For more information about the **ncls** program, refer to the Cadence NC-Verilog Simulator Help or Cadence NC-VHDL Simulator Help.

### *Elaboration in GUI Mode*

To elaborate using the GUI, perform the following steps:

1. In the right side of the NCLaunch window, expand your current work library.
2. Select and (if necessary) expand the entity or module name you want to elaborate.
3. Right-click the view you want to display. Click **NCElab**. The **Elaborate** dialog box appears (Figure 4-4). Optionally, on the Tools menu, click **Elaborator**.
4. In the **Other Options** box, set the simulation timescale by typing the following command (Figure 4-4):

```
-TIMESCALE 1ps/1ps
```

**Figure 4-4. Elaborating the Design**

5. To begin elaboration, in the **Elaborate** dialog box, Click **OK**. The dialog box closes and returns you to **NCLaunch**.

## Add Signals to View

The SHM database is a Cadence proprietary waveform database that stores selected signals for viewing. To specify which signal to view, you must create a database. To create this database, add commands to your code, or create a Value Change Dump File (.vcd) file to store the simulation history.



For more information about using a .vcd file, refer to the *Cadence NC-Sim User Manual* from Cadence included with the installation.

### *Adding Signals in Command-Line Mode*

To create an SHM database, specify the system tasks described in [Table 4-4](#) in your Verilog HDL code.



For VHDL, you can use the Tcl command interface or C function calls to add signals to a database. Refer to the Cadence documentation included in the installation package for details.

**Table 4–4. SHM Database System Tasks**

| System Task                                       | Description                                                                                                                                                                                                                                                                                       |
|---------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>\$shm_open("&lt;filename&gt;.shm") ;</code> | Opens a database. If you do not specify a filename, the default <b>waves.shm</b> database opens. If a database with the specified name does not exist, it is created for you.                                                                                                                     |
| <code>\$shm_probe("[A S C]") ;</code>             | Probe signals. You can specify the signals to probe; if you do not specify signals, the default is all ports in the current scope.<br><br>A probes all nodes in the current scope.<br>S probes all nodes below the current scope.<br>C probes all nodes below the current scope and in libraries. |
| <code>\$shm_save ;</code>                         | Saves the database.                                                                                                                                                                                                                                                                               |
| <code>\$shm_close ;</code>                        | Closes the database.                                                                                                                                                                                                                                                                              |

The following sample shows a simple example of how to add signals to an SHM database.

**Example 4–4.**

```
initial
begin
    $shm_open ("waves.shm") ;
    $shm_probe ("AS") ;
end
```



You can insert this code sample into your Verilog HDL file. It is applicable only for Verilog HDL files. For more information about these system tasks, refer to the Cadence NC-Sim software user manual included in the installation.

*Adding Signals in GUI Mode*

To add signals in GUI mode, perform the following steps:

1. In the NC-Sim software, load the design.
  - a. In the NCLaunch window, click the "+" icon to expand the **Snapshots** directory.

- b. Right-click the **lib.cell:view** you want to simulate. Click **NCSim**.
- c. In the **Simulate** dialog box, click **OK**.

After you load the design, the SimVision Console and SimVision Design Browser windows appear. [Figure 4–5](#) shows the SimVision Design Browser window.

2. To display the signal names, in the **Design Browser** window, in the left side of the window select a module ([Figure 4–5](#)).

**Figure 4–5. SimVision Design Browser**



3. To send the selected signals to the Waveform Viewer, perform one of the following steps:

Select a group of signals from the right side of the **Design Browser** window. In the **Send To** toolbar (the upper-right area of the Design Browser window), click the **Send to Waveform Viewer** icon.

or

Right-click the signals and click **Send to Waveform Window** (Figure 4–6).

A waveform window showing all of your signals appears. You are now ready to simulate your testbench and design.

**Figure 4–6. Selecting Signals in the Design Browser Window**



## Simulate the Design

After you have compiled and elaborated your design, you can simulate it using **ncsim**. The **ncsim** program loads the file or snapshot generated by **ncelab** as its primary input. It then loads other intermediate objects referenced by the snapshot. If you enable interactive debugging, it may also load HDL source files and script files. The simulation output is controlled by the model or debugger. The output can include result files generated by the model, SHM database, or **.vcd** file.

*RTL Functional Simulation in Command-Line Mode*

To perform RTL functional simulation of your Verilog HDL or VHDL design at the command line, type the following command:

```
ncsim [options] [<library>.] <cell> [ :<view>] ↵
```

For example:

```
ncsim worklib.lpm_ram_dp:syn ↵
```

Table 4–5 shows some of the options you can use with **ncsim**.

**Table 4–5. ncsim Options**

| Options             | Description                                                            |
|---------------------|------------------------------------------------------------------------|
| <code>-gui</code>   | Launch GUI mode                                                        |
| <code>-batch</code> | Used for non-interactive mode                                          |
| <code>-tcl</code>   | Used for interactive mode (not required when using <code>-gui</code> ) |

*RTL Functional Simulation in GUI Mode*

You can run and step through simulation of your Verilog HDL or VHDL design in the GUI. In the Design Browser window, on the Simulation menu, click **Run** to begin the simulation.



You must load the design before simulating. If you have not done so, refer to step 1 in “[Adding Signals in GUI Mode](#)” on [page 4–17](#) for instructions.

## Post-Synthesis Simulation

The following sections provide detailed instructions for performing post-synthesis simulation using Quartus II output files, simulation libraries, and the Incisive platform software.

### Quartus II Simulation Output Files

After performing synthesis with either a third-party synthesis tool or with the Quartus II integrated synthesis, you must generate a simulation netlist for functional simulations. To generate a simulation netlist for functional simulation, perform the following steps in the Quartus II software:

1. Perform Analysis and Synthesis. On the Processing menu, point to **Start** and click **Start Analysis and Synthesis**.
2. To turn on the **Generate Netlist for Functional Simulation Only** option, perform the following steps:
  - a. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
  - b. In the **Category** list, select **Simulation**. The **Simulation** page appears.
  - c. In the **Tool name** list, select **NCSim**.
  - d. Under **EDA Netlist Writer options**, in the **Format for output netlist** list, select **VHDL** or **Verilog**. You can also modify where you want the post-synthesis netlist generated by editing or browsing to a directory in the **Output directory** box.
  - e. Click **More Settings**. The **More EDA Tools Simulation Settings** dialog box appears. In the **Existing options settings** list, click **Generate Netlist for Functional Simulation Only** and select **On** from the **Setting** list under **Option**.
  - f. Click **OK**.
  - g. In the **Settings** dialog box, click **OK**.
3. Run the EDA Netlist Writer. On the Processing menu, point to **Start** and click **Start EDA Netlist Writer**.



During the EDA Netlist Writer stage, the Quartus II software produces a **.vo** file or **.vho** file that can be used for post-synthesis simulations in the NC-Sim software. This netlist file is mapped to architecture-specific primitives. No timing information is included at this stage. The resulting netlist is located in the output directory you specified in the **Settings** dialog box, which defaults to the `<project directory>/simulation/NCSim` directory.

## Create Libraries

Create the following libraries for your simulation:

- Work library
- Device family library targeting your design targets using the following files in the *<path to Quartus II installation>/eda/sim\_lib* directory:
  - *<device\_family>\_atoms.v*
  - *<device\_family>\_atoms.vhd*
  - *<device\_family>\_components.vhd*

## Compile Project Files and Libraries

Compile the project files and libraries into your work directory using the **ncvlog** or **ncvhdl** programs or the GUI. Include the following files:

- Test bench file
- The Quartus II software functional output netlist file (Verilog Output File or VHDL Output File)
- Atom library file for the device family  
*<device family>\_atoms.<v | vhd>*
- For VHDL, *<device family>\_components.vhd*

Refer to the section “[Compile Source Code and Testbenches](#)” on [page 4-12](#) for instructions about compiling.

## Elaborate Your Design

Elaborate your design using the **ncelab** program as described in “[Elaboration in GUI Mode](#)” on [page 4-15](#).

## Add Signals to the View

Refer to the section “[Add Signals to View](#)” on [page 4-16](#) for information about adding signals to the view.

## Simulate Your Design

Simulate your design using the **ncsim** program as described in “[Simulate the Design](#)” on [page 4-19](#).

## Gate-Level Timing Simulation

The following sections provide detailed instructions for performing timing simulation using the Quartus II output files, simulation libraries, and Cadence NC tools.

### Generating a Gate-Level Timing Simulation Netlist

To perform gate-level timing simulation, the NC-Sim software requires information about how the design was placed into device-specific architectural blocks. The Quartus II software provides this information in the form of a Verilog Output File for Verilog HDL designs and a VHDL Output File for VHDL designs. The accompanying timing information is stored in the SDO file, which annotates the delay for the elements found in the Verilog Output File or VHDL Output File.

To generate the Verilog Output File or VHDL Output Files and the Standard Delay File, perform the following steps:

1. Perform a full compilation. On the Processing menu, click **Start Compilation**.
2. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
3. In the **Category** list, select **Simulation**. The **Simulation** page appears.
4. In the **Tool name** list, select **NCSim**.
5. Under **EDA Netlist Writer options**, in the **Format for output netlist** list, select **VHDL** or **Verilog**. You can also modify where you want the post-synthesis netlist generated by editing or browsing to a directory in the **Output directory** box.
6. Click **OK**.
7. Run the EDA Netlist Writer. On the Processing menu, point to **Start** and click **Start EDA Netlist Writer**.

During the EDA Netlist Writer stage, the Quartus II software produces a **.vo** file, **.vho** file, and a SDO file used for gate-level timing simulations in the NC-Sim software. This netlist file is mapped to architecture-specific primitives. The timing information for the netlist is included in the SDO file. The resulting netlist is located in the output directory you specified in the **Settings** dialog box, which defaults to the *<project directory>/simulation/ncsim* directory.

### Generating a Timing Netlist with Different Timing Models

To generate the timing netlist in Stratix III and later devices (for example, Cyclone III and Stratix IV), you can specify different temperature and voltage parameters. Using the Quartus II Classic or Quartus II TimeQuest Timing Analyzer when generating the simulation netlist files (\*.vo or \*.vho and \*.sdo), produces different timing models for different operating conditions. The multi-corner timing analysis is run by default during the full compilation.

**Table 4–6** shows the example of default available operation conditions (model, voltage, and temperature) for Stratix III and Cyclone III devices.

**Table 4–6. Default Available Operating Condition for Stratix III and Cyclone III Devices**

| Device Family | Model | Voltage | Temperature (C) |
|---------------|-------|---------|-----------------|
| Stratix III   | Slow  | 1100 mV | 85°             |
|               | Slow  | 1100 mV | 0°              |
|               | Fast  | 1100 mV | 0°              |
| Cyclone III   | Slow  | 1200 mV | 85°             |
|               | Slow  | 1200 mV | 0°              |
|               | Fast  | 1200 mV | 0°              |

If the multi-corner timing analysis is not run during full compilation, you should perform the following steps to manually generate the simulation netlist files (\*.vo or \*.vho and \*.sdo) for the three different operating conditions listed in [Table 4–6](#):

1. Generate all the available corner models at all operating conditions. Type the following command at a command prompt:

```
quartus_sta <project name> --multicorner ↵
```

2. Generate the simulation output files for all three corners specified in [Table 4–6](#). You can perform steps 2 through 7 in [“Generating a Gate-Level Timing Simulation Netlist” on page 4–23](#). The output files are generated in the simulation output directory.

The following example shows all the generated simulation netlist files for the three operating conditions of the preceding steps, when selecting **Verilog** as the output netlist format:

**First slow corner (slow, 1100 mV, 85° C)**

VO file— *<revision name>.vo*

SDO file— *<revision name>\_v.sdo*



The *<revision name>.vo* and *<revision name>\_v.sdo* are generated for backward compatibility in case there are existing scripts that still use them.

VO file— *<revision name>\_<speedgrade>\_1100mv\_85c\_slow.vo*

SDO file— *<revision name>\_<speedgrade>\_1100mv\_85c\_v\_slow.sdo*

**Second slow corner (slow, 1100 mV, 0° C)**

VO file— *<revision name>\_<speedgrade>\_1100mv\_0c\_slow.vo*

SDO file— *<revision name>\_<speedgrade>\_1100mv\_0c\_v\_slow.sdo*

**Fast corner (fast, 1100 mV, 0° C)**

VO file— *<revision name>\_min\_1100mv\_0c\_fast.vo*

SDO file— *<revision name>\_min\_1100mv\_0c\_v\_fast.sdo*

For all other older families, a slow-corner (worst case) timing model is used by default. There are only two timing models available, which are the slow-corner and fast-corner. To generate the SDO file using a different timing model, you must run the Quartus II Classic or the Quartus II TimeQuest Timing Analyzer with a different timing model before you start the EDA Netlist writer.

To run the Quartus II Classic Timing Analyzer with the best-case model, on the Processing menu, point to **Start** and click **Start Classic Timing Analyzer (Fast Timing Model)**. After the timing analysis is complete, the Compilation Report appears. You can also type the following command at a command prompt:

```
quartus_tan <project_name> --fast_model=on ↵
```

To run the Quartus II TimeQuest Timing Analyzer with a best-case model, use the **-fast\_model** option after you create the timing netlist. The following command enables the fast timing models:

```
create_timing_netlist --fast_model ↵
```

After you run the Quartus II Classic or Quartus II TimeQuest Timing Analyzer, you can perform steps 2 through 7 in “[Generating a Gate-Level Timing Simulation Netlist](#)” on page 4-23 to generate the **\*.sdo** file. For

fast corner timing models, the **-fast** post fix is added to the **\*.vo** or **\*.vho**, and **\*.sdo** file (for example, **my\_project\_fast.vo** or **my\_project\_fast.vho**, and **my\_project\_fast.sdo**).



For more information about generating a timing netlist with different timing models, refer to the *Quartus II Classic Timing Analyzer* or the *Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

## Disable Timing Violation on Registers

In certain situations, the timing violations can be ignored and you can disable the timing violation on registers. For example, timing violations that occur in internal synchronization registers used for asynchronous clock-domain crossing.

By default, the **x\_onViolationOption** logic option is **On**, which means the simulation shows "X" whenever a timing violation occurs. To disable showing the timing violation on certain registers, you can set the **x\_onViolationOption** logic option to **Off** for those registers. The following command is an example of the QSF file:

```
set_instance_assignment -name X_ON_VIOLATION_OPTION OFF -to <register_name>
```

## Perform Timing Simulation Using Post-Synthesis Netlist

You can perform a timing simulation using the post-synthesis netlist instead of using a gate-level netlist and you can generate a **.sdo** file without running the Fitter. In this case, the **.sdo** file includes all timing values for the device cells only. Interconnect delays are not included because fitting (placement and routing) has not been performed.

To generate the post-synthesis netlist and the SDO file, type the following at a command prompt:

```
quartus_map <project name> -c <revision name> ↵
quartus_tan <project name> -c <revision name> --post_map --zero_ic_delays ↵
quartus_eda <project name> -c <revision name> --simulation \
--tool=<3rd party EDA tool> --format=<HDL language> ↵
```

For more information about the `-format` and `-tool` options, type the following command at a command prompt:

```
quartus_eda -help=<options> command ↵
```

## Quartus II Timing Simulation Libraries

Altera device simulation library files are provided in the *<Quartus II installation>/eda/sim\_lib* directory. The Verilog Output File or VHDL Output File requires the library for the device your design targets. For example, the Stratix device family requires the following library files:

- **stratix\_atoms.v**
- **stratix\_atoms.vhd**
- **stratix\_components.vhd**

If your design targets a Stratix device, you must set up the appropriate mappings in your `cds.lib` file. Refer to “[Create Libraries](#)” for more information.

## Create Libraries

Create the following libraries for your simulation:

- Work library
- Device family libraries targeting using the following files in the *<path to Quartus II installation>/eda/sim\_lib* directory:
  - *<device\_family>\_atoms.v*
  - *<device\_family>\_atoms.vhd*
  - *<device\_family>\_components.vhd*

For step-by-step instructions on creating libraries, refer to “[Basic Library Setup](#)” on page 4-7 and “[LPM Functions, Altera Megafunctions, and Altera Primitive Library Setup](#)” on page 4-9.

## Compile the Project Files and Libraries

Compile the project files and libraries into your work directory using the `ncvlog` or `ncvhdl` programs or the GUI. Include the following files:

- Test bench file
- The Quartus II software functional output netlist file (Verilog Output File or VHDL Output File)
- Atom library file for the device family *<device family>\_atoms.<v | vhd>*
- For VHDL, *<device family>\_components.vhd*

For instructions on compiling, refer to “[Compile Source Code and Testbenches](#)” on page 4-12.

## Elaborate Your Design

When performing elaboration with the Quartus II-generated Verilog HDL netlist file, the Standard Delay Format Output File is read automatically. When you run **ncelab**, it recognizes the embedded system task `$sdf_annotate` and automatically compiles and annotates the Standard Delay Format Output File (runs **ncsdfc** automatically).



The Standard Delay Format Output File should be located in the same directory where you invoke an elaboration or simulation, because the `$sdf_annotate` task references the Standard Delay Format Output File without using a full path. If you are invoking an elaboration or simulation from a different directory, you can either comment out the `$sdf_annotate` and annotate the Standard Delay Format Output File with the GUI, or add the full path of the Standard Delay Format Output File.

Refer to “[Elaborate Your Design](#)” on page 4-14 for step-by-step instructions on elaboration.

For VHDL, the Quartus II software-generated VHDL netlist file does not contain system task calls to locate your SDF file; therefore, you must compile the Standard Delay Format Output File manually. For information about compiling the Standard Delay Format Output File, refer to “[Compiling the Standard Delay Output File \(VHDL Only\) in Command-Line Mode](#)” and “[Compiling the Standard Delay Output File \(VHDL Only\) in GUI Mode](#)”.

### *Compiling the Standard Delay Output File (VHDL Only) in Command-Line Mode*

To annotate the Standard Delay Format Output File timing data from the command line, perform the following steps:

1. Compile the Standard Delay Format Output File using the **ncsdfc** program by typing the following command at the command prompt:

```
ncsdfc <project name>_vhd.sdo -output <output name> ↵
```

The **ncsdfc** program generates an `<output name>.sdf.X` compiled SDO.



If you do not specify an output name, **ncsdfc** uses `<project name>.sdo.X`.

2. Specify the compiled Standard Delay Format Output File for the project by adding the following command to an ASCII SDF command file for the project:

```
COMPILED_SDF_FILE = "<project name>.sdf.X" SCOPE = <instance path>
```

Example 4-5 shows an example of an SDF command file:

---

**Example 4-5.**

```
// SDF command file sdf_file
COMPILED_SDF_FILE = "lpm_ram_dp_test_vhd.sdo.X",
SCOPE = :tb,
MTM_CONTROL = "TYPICAL",
SCALE_FACTORS = "1.0:1.0:1.0",
SCALE_TYPE = "FROM_MTM";
```

---

After you compile the Standard Delay Format Output File, run the following command to elaborate the design:

```
ncelab worklib.<project name>:entity -SDF_CMD_FILE <SDF Command File> ↵
```

*Compiling the Standard Delay Output File (VHDL Only) in GUI Mode*

To annotate the **.sdo** file timing data in the GUI, in the **NCLaunch** window, perform the following steps:

1. On the Tools menu, click **SDF Compiler**. The **Compile SDF** dialog box appears.
2. In the **SDF File** box, type in the name of the Standard Delay Format Output File (**.sdo**) for the project.
3. Click **OK**.

When the Standard Delay Format Output File compilation is complete, you can elaborate the design. Refer to “[Elaboration in GUI Mode](#)” on page 4-15 for step-by-step instructions.



If you perform a VHDL gate-level timing simulation, you must create an SDF command file before you begin elaboration. To create the SDF command file, perform steps 5 through 11.

4. On the Tools menu, click **Elaborator**. The **Elaborate** dialog box appears.
5. Click **Advanced Options**.
6. Click **Annotation**.
7. Turn on **Use SDF File**.
8. Click **Edit**.
9. Browse to the location of the SDF command file name.
10. Click **Add** and browse to the location of the Standard Delay Format Output File in the **Compiled SDF File** box and click **OK**.
11. Click **OK** to save and exit the **SDF Command File** dialog box.

### Add Signals to View

Refer to the section “[Add Signals to View](#)” on page [4-16](#) for information about adding signals to view.

### Simulate Your Design

Simulate your design using the **ncsim** program as described in “[Simulate the Design](#)” on page [4-19](#).



For the design examples to run gate-level timing simulation, refer to the [Cadence NC-Sim Simulation Design Example](#) web page.

## Simulating Designs that Include Transceivers

If your design includes a Stratix II GX, Stratix GX, Stratix IV, or Arria GX transceiver, you must compile additional library files to perform RTL functional or gate-level timing simulations.

### Stratix GX RTL Functional Simulation

To perform a RTL functional simulation of your design that instantiates the ALTGXBX megafunction, enabling the gigabit transceiver block (GXB) on Stratix GX devices, compile the **stratixgx\_mf** model file into the **altgxb** library.



The **stratixgx\_mf** model file references the **lpm** and **sgate** libraries, so you must create these libraries to perform a simulation.

*Compiling Library Files for Functional Stratix GX Simulation in VHDL*

To compile the libraries necessary for functional simulation of a VHDL design targeting a Stratix GX device, type the commands shown in Example 4-6 at the NC-Sim command prompt:

**Example 4-6.**

```
ncvhdl -work lpm 220pack.vhd 220model.vhd
ncvhdl -work altera_mf altera_mf_components.vhd altera_mf.vhd
ncvhdl -work sgate sgate_pack.vhd sgate.vhd
ncvhdl -work altgxb stratixgx_mf.vhd stratixgx_mf_components.vhd
ncsim work.<my design>
```

*Compiling Library Files for Functional Stratix GX Simulation in Verilog HDL*

To compile the libraries necessary for a functional simulation of a Verilog HDL design targeting a Stratix GX device, type the commands shown in Example 4-7 at the NC Sim command prompt.

**Example 4-7.**

```
ncvlog -work lpm 220model.v
ncvlog -work altera_mf altera_mf.v
ncvlog -work sgate sgate.v
ncvlog -work altgxb stratixgx_mf.v
ncsim work.<my design>
```

**Stratix GX Gate-Level Timing Simulation**

To perform a gate-level timing simulation of your design that includes a Stratix GX transceiver, compile the **stratixgx\_atoms** and **stratixgx\_hssi\_atoms** model files into the **stratixgx** and **stratixgx\_gxb** libraries, respectively.



You must create these libraries to perform a simulation because the **stratixgx\_hssi\_atoms** model file references the **lpm** and **sgate** libraries.

### *Compiling Library Files for Timing Stratix GX Simulation in VHDL*

To compile the libraries necessary for timing simulation of a VHDL design targeting a Stratix GX device, type the commands shown in Example 4-8 at the NC-Sim command prompt.

---

**Example 4-8.**

```
ncvhdl -work lpm 220pack.vhd 220model.vhd
ncvhdl -work altera_mf altera_mf_components.vhd altera_mf.vhd
ncvhdl -work sgate sgate_pack.vhd sgate.vhd
ncvhdl -work stratixgx stratixgx_atoms.vhd stratixgx_components.vhd
ncvhdl -work stratixgx_gxb stratixgx_hssi_atoms.vhd \
stratixgx_hssi_components.vhd
ncelab work.<my design> -TIMESCALE 1ps/1ps -PULSE_R 0 -PULSE_INT_R 0
```

---

### *Compiling Library Files for Timing Stratix GX Simulation in Verilog HDL*

To compile the libraries necessary to timing simulation of a Verilog HDL design targeting a Stratix GX device, type the commands shown in Example 4-9 at the NC-Sim command prompt.

---

**Example 4-9.**

```
ncvlog -work lpm 220model.v
ncvlog -work altera_mf altera_mf.v
ncvlog -work sgate sgate.v
ncvlog -work stratixgx stratixgx_atoms.v
ncvlog -work stratixgx_gxb stratixgx_hssi_atoms.v
ncelab work.<my design> -TIMESCALE 1ps/1ps -PULSE_R 0 -PULSE_INT_R 0
```

---

## **Stratix II GX RTL Functional Simulation**

Stratix II GX function simulation is similar to Arria GX functional simulation. Example 4-10 shows only the RTL functional simulation for designs that include transceivers in Stratix II GX. To simulate transceivers in Arria GX, replace the **stratixiigx\_hssi** model file with the **arriagx\_hssi** model file.

To perform a RTL functional simulation of your design that instantiates the ALT2GXB megafunction, edit your **cds.lib** file so all of the libraries point to the work library, and compile the **stratixiigx\_hssi** model file into the **stratixiigx\_hssi** library. When compiling the library files, you can safely ignore the following warning message:

"Multiple logical libraries mapped to a single location"

Example 4-10 shows the **cds.lib** file.

---

**Example 4-10.**

```
SOFTINCLUDE ${CDS_INST_DIR}/tools/inca/files/cdsvhdl.lib
SOFTINCLUDE ${CDS_INST_DIR}/tools/inca/files/cdsvlog.lib
DEFINE work ./ncsim_work
DEFINE stratixiigx_hssi ./ncsim_work
DEFINE stratixiigx ./ncsim_work
DEFINE lpm ./ncsim_work
DEFINE sgate ./ncsim_work
```

---



The **stratixiigx\_hssi\_atoms** model file references the **lpm** and **sgate** libraries, so you will need to create these libraries to perform a simulation.

Generate a functional simulation netlist by turning on **Create a simulation library for this design** in the last page of the ALT2GXB MegaWizard (Figure 4-7). The *<alt2gxb entity name>.vho* or *<alt2gxb module name>.vo* is generated in the current project directory.

**Figure 4–7. ALT2GXB MegaWizard**



The Quartus II generated alt2gxb functional simulation library file references **stratixgx\_hssi** wysiwyg atoms.

### *Compiling Library Files for Functional Stratix II GX Simulation in VHDL*

To compile the libraries necessary for functional simulation of a VHDL design targeting a Stratix II GX device, type the commands shown in Example 4-11 at the NC-Sim command prompt.

---

#### **Example 4-11.**

```
ncvhdl -work lpm 220pack.vhd 220model.vhd
ncvhdl -work altera_mf altera_mf_components.vhd altera_mf.vhd
ncvhdl -work sgate sgate_pack.vhd sgate.vhd
ncvhdl -work stratixiigx_hssi stratixiigx_hssi_components.vhd \
stratixiigx_hssi_atoms.vhd
ncvhdl -work work <alt2gxb entity name>.vho
ncelab work.<my design>
```

---

### *Compiling Library Files for Functional Stratix II GX Simulation in Verilog HDL*

To compile the libraries necessary to functional simulation of a Verilog HDL design targeting a Stratix II GX device, type the commands shown in Example 4-12 at the NC-Sim command prompt.

---

#### **Example 4-12.**

```
ncvlog -work lpm 220model.v
ncvlog -work altera_mf altera_mf.v
ncvlog -work sgate sgate.v
ncvlog -work stratixiigx_hssi stratixiigx_hssi_atoms.v
ncvlog -work work <alt2gxb module name>.vo
ncelab work.<my design>
```

---

## **Stratix II GX Gate-Level Timing Simulation**

Stratix II GX function simulation is similar to Arria GX functional simulation. The Example 4-13 shows only the gate-level timing simulation for designs that include transceivers in Stratix II GX. To simulate transceivers in Arria GX, replace the **stratixiigx\_hssi** model file with the **ariagx\_hssi** model file.

To perform a post-fit timing simulation of your design that includes the ALT2GXB megafunction, edit your **cds.lib** file so that all the libraries point to the work library and compile **stratixiigx\_atoms** and **stratixiigx\_hssi\_atoms** into the **stratixiigx** and **stratixiigx\_hssi** libraries, respectively. When compiling the library files, you can safely ignore the following warning message:

"Multiple logical libraries mapped to a single location"

For an example of a **cds.lib** file, refer to ["Stratix II GX RTL Functional Simulation" on page 4-32](#).



The **stratixiigx\_hssi\_atoms** model file references the **lpm** and **sgate** libraries, so you must create these libraries to perform a simulation.

#### *Compiling Library Files for Timing Stratix II GX Simulation in VHDL*

To compile the libraries necessary for timing simulation of a VHDL design targeting a Stratix II GX device, type the commands shown in Example 4-13 at the NC-Sim command prompt.

---

##### **Example 4-13.**

```
ncvhdl -work lpm 220pack.vhd 220model.vhd
ncvhdl -work altera_mf altera_mf_components.vhd altera_mf.vhd
ncvhdl -work sgate sgate_pack.vhd sgate.vhd
ncvhdl -work stratixiigx stratixiigx_atoms.vhd \
stratixiigx_components.vhd
ncvhdl -work stratixiigx_hssi stratixiigx_hssi_components.vhd \
stratixiigx_hssi_atoms.vhd
ncvhdl -work work <alt2gxb>.vho
ncelab work.<my design> -TIMESCALE 1ps/1ps -PULSE_R 0 -PULSE_INT_R 0
```

---

#### *Compiling Library Files for Timing Stratix II GX Simulation in Verilog HDL*

To compile the libraries necessary to timing simulation of a Verilog HDL design targeting a Stratix II GX device, type the commands shown in Example 4-14 at the NC-Sim command prompt.

---

##### **Example 4-14.**

```
ncvlog -work lpm 220model.v
ncvlog -work altera_mf altera_mf.v
ncvlog -work sgate sgate.v
ncvlog -work stratixiigx stratixiigx_atoms.v
ncvlog -work stratixiigx_hssi stratixiigx_hssi_atoms.v
ncelab work.<my design> -TIMESCALE 1ps/1ps -PULSE_R 0 -PULSE_INT_R 0
```

---

## Pulse Reject Delays

By default, the NCSim software filters out all pulses that are shorter than the propagation delay between primitives. Setting the pulse reject delays (similar to transport delays) options in the NC-Sim software prevents the simulation tool from filtering out these pulses. Use the following options to ensure that all signal pulses are seen in the simulation results.

### *-PULSE\_R*

Use this option when the pulses in your simulation are shorter than the delay within a gate-level primitive. The argument is the percentage of delay for pulse reject limit for the path.

### *-PULSE\_INT\_R*

Use this option when the pulses in your simulation are shorter than the interconnect delay between gate-level primitives. The argument is the percentage of delay for pulse reject limit for the path. The *-PULSE\_R* and *-PULSE\_INT\_R* options are also used by default in the NativeLink feature for gate-level timing simulation.

The following NC-Sim software command describes the command-line syntax to perform a gate-level timing simulation with the device family library:

```
ncelab worklib.<project name>:entity -SDF_CMD_FILE <SDF Command File> \
-TIMESCALE 1ps/1ps -PULSE_R 0 -PULSE_INT_R 0
```

## Using the NativeLink Feature with NC-Sim

The NativeLink feature in the Quartus II software facilitates the seamless transfer of information between the Quartus II software and EDA tools and allows you to run NC-Sim within the Quartus II software.

### Setting Up NativeLink

To run NC-Sim automatically from the Quartus II software using the NativeLink feature, you must specify the path to your simulation tool by performing the following steps:

1. On the Tools menu, click **Options**. The **Options** dialog box appears.
2. In the **Category** list, select **EDA Tool Options**. The **EDA Tool Options** page is shown.
3. Double-click the entry under the **Location of executable** column beside the name of your **EDA Tool**, and type or browse to the directory containing the executables of your EDA tool.

4. Click **OK**.

You can also specify the path to the simulator's executables by using the `set_user_option` TCL command:

```
set_user_option -name EDA_TOOL_PATH_NCSIM <path to executables>
```

## Performing an RTL Simulation Using NativeLink

To run a RTL functional simulation with the NC-Sim software automatically in the Quartus II software, perform the following steps:

1. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
2. In the **Category** list, select **Simulation**. The **Simulation** page appears (Figure 4-8).

**Figure 4-8. Simulation Page in the Settings Dialog Box**

3. In the **Tool name** drop-down list, select **NCSim**.
4. If your design is written entirely in Verilog HDL or in VHDL, the NativeLink feature automatically chooses the correct language and Altera simulation libraries. If your design is written with mixed languages, the NativeLink feature uses the default language specified in the **Format for output netlist** list. To change the default

language when there is a mixed language design, under **EDA Netlist Writer options**, in the **Format for output netlist** list, select **VHDL** or **Verilog**. Table 4-7 shows the design languages for output netlists and simulation models.

**Table 4-7. NativeLink Design Languages**

| Design File | Format for Output Netlist | Simulation Models Used |
|-------------|---------------------------|------------------------|
| Verilog     | Any                       | Verilog                |
| VHDL        | Any                       | VHDL                   |
| Mixed       | Verilog                   | Verilog                |
| Mixed       | VHDL                      | VHDL                   |



For mixed-language simulation, choose the same language that was used to generate the megafunctions to ensure correct parameter passing between the megafunctions and the Altera libraries. For example, if your ALTSYNCRAM megafunction was generated in VHDL, choose VHDL as the format for output netlist.

For mixed-language simulations, it is important to be aware of the following conditions:

- VHDL designs instantiating Verilog user-defined primitives (UDPs) are not supported.
- Parameters cannot be passed in Verilog modules that instantiate VHDL components.

5. If you have testbench files or macro scripts, enter the information under **NativeLink settings**.

For more information about setting up a testbench with NativeLink, refer to the section “[Setting Up a Testbench](#)” on page 4-42.

6. Click **OK**.
7. On the Processing menu, point to Start and click **Start Analysis and Elaboration** to perform an analysis and elaboration. This command collects all your file name information and builds your design hierarchy in preparation for simulation.
8. To automatically run NC-Sim, compile all necessary design files, and complete a simulation, on the Tools menu, point to **Run EDA Simulation Tool** and click **EDA RTL Simulation**.

## Performing a Gate Level Simulation Using NativeLink

To run a gate-level timing simulation with the NC-Sim software in the Quartus II software, perform the following steps:

1. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
2. In the **Category** list, select **Simulation**. The **Simulation** appears (Figure 4-8 on page 4-39).
3. In the **Tool name** list, select **NCSim**.
4. Under **EDA Netlist Writer options**, in the **Format for output netlist** list, choose **VHDL** or **Verilog**. You can also modify where you want the post-synthesis netlist generated by editing or browsing to a directory in the **Output directory** box.
5. To perform a gate level simulation after each full compilation, turn on **Run Gate Level Simulation automatically after compilation**.
6. If you have testbench files or macro scripts, enter the information under **NativeLink settings**.
7. Click **OK**.
8. On the Processing menu, point to **Start** and click **Start EDA Netlist Writer** to generate a simulation netlist of your design.



If you have run full compilation after you set the **EDA Tool Settings**, the **Start EDA Netlist Writer** step is not required.

9. To automatically run NC-Sim, compile all necessary design files, and complete a simulation, on the Tools menu, point to **Run EDA Simulation Tool** and click **EDA Gate Level Simulation**.



If multi-corner Timing Analysis is performed, a dialog box appears asking you to select the timing corner to run simulation. Select the timing corner and click **Run**.



A Tcl File (\*.tcl) is generated in the `<project_directory>\simulation\ncsim` directory when you run NativeLink. This TCL File enables you to simulate the design without using NativeLink, using the following command:

```
quartus_sh -t <project_directory>\simulation\ncsim\<generated_do_file>.tcl
```

## Setting Up a Testbench

You can compile your design files and testbench files, and run EDA simulation tools to perform a simulation automatically using the NativeLink feature.

To setup NativeLink with a testbench, perform the following steps:

1. On the Assignments menu, click **Settings**. The **Settings** dialog box appears.
2. In the **Category** list, select **Simulation**. The **Simulation** page appears.
3. Under **NativeLink settings**, select **None** or **Compile test bench** (Table 4-8).

| <b>Table 4-8. NativeLink Settings</b> |                                                                                              |
|---------------------------------------|----------------------------------------------------------------------------------------------|
| <b>Settings</b>                       | <b>Description</b>                                                                           |
| None                                  | Compile simulation models and design files.                                                  |
| Compile test bench                    | NativeLink compiles simulation models, design files, testbench files, and starts simulation. |

4. If you select **Compile test bench**, select your testbench setup from the **Compile test bench** list. You can use different testbench setups to specify different testbench files for different test scenarios. If there are no testbench setups entered, create a testbench setup by performing the following steps:
  - a. Click **Test Benches**. The **Test Benches** dialog box appears.
  - b. Click **New**. The **New Test Bench Settings** dialog box appears.
  - c. In the **Test Bench name** box, type in the testbench setup name which is used to identify the different testbench setups.
  - d. In the **Test level module** box, type in the top-level entity name. For example, for a Quartus II generated VHDL testbench, type `filtref_vhd_vec_tst`.
  - e. In the **Instance** box, type in the full instance path to the top level of your FPGA design. For example, for a Quartus II generated VHDL testbench, type `i1`.

- f. Under **Simulation period**, select **Run simulation until all vector stimuli are used**. If you select **End simulation at**, specify the simulation end time and the time unit.

- g. Under **Test bench files**, browse and add all your testbench files in the **File name** box. Use the **Up** and **Down** button to reorder your files. The script used by NativeLink compiles the files in the order from top to the bottom.



You can also specify the library name and the HDL version to compile the testbench file. NativeLink compiles the testbench to the library name of the HDL specified version.

- h. Click **OK**.
- i. In the **Test Benches** dialog box, click **OK**.
5. Under **NativeLink settings**, you can turn on **Use script to setup simulation** and browse to your script. You can write a script to setup your waveforms before running the simulation.



The script should be a valid NC-Sim tcl script. NativeLink passes the script to ncsim command with command-line arguments to set up and run simulation.

### *Creating a Testbench*

In the Quartus II software, you can create a Verilog HDL or VHDL testbench from a Vector Waveform File. The generated testbench includes the behavior of the input stimulus and applies it to your instantiated top-level FPGA design.

1. On the File menu, click **Open**. The **Open** dialog box appears.
2. Click the **Files of type** arrow and select **Waveform/Vector Files**. Select your file.
3. Click **Open**.
4. On the File menu, click **Export**. The **Export** dialog box.
5. Click the **Save as type** arrow and select **VHDL Test Bench File (\*.vht)** or **Verilog Test Bench File (\*.vt)**.
6. You can turn on **Add self-checking code to file** to check your simulation results against your Vector Waveform File.

7. Click **Export**.

## Generating a Timing VCD File for PowerPlay

To generate a timing **.vcd** file for PowerPlay, you must first generate a VCD script in the Quartus II software, and run the VCD script from the NC Sim software to generate a timing **.vcd** file. This timing **.vcd** file can then be used by PowerPlay for power estimation. The following step-by-instructions show you how to generate a timing **.vcd** file.

Perform the following steps to generate timing VCD scripts in the Quartus II software:

1. In the Quartus II software, on the Assignments menu, click **Settings**.
2. In the **Settings** dialog box, on the **Simulator Settings** page, choose the appropriate 3rd Party Simulation Tool (for example, Modelsim or Modelsim-Altera) in the **Tool Name** list, and turn on the **Generate Value Change Dump File Script** option.
3. To generate the VCD script file, perform a full compilation.

Perform the following steps to generate a timing **.vcd** file in NC Sim:

1. In the NC Sim software, before simulating your design, source the `<revision_name>_dump_all_vcd_nodes.tcl` script. To source the TCL script, you should use the **-input** switch while running the **nssim** command. For example:

```
ncsim -input <revision_name>_dump_all_vcd_nodes.tcl <my design>
```

2. Continue to run the simulation as usual until the end of the simulation. Exit the **ncsim** and the `<revision_name>.vcd` is generated in the simulation directory.

 Refer to the *PowerPlay Power Analysis* chapter in volume 3 of the *Quartus II Handbook* for more detailed information about using the timing **.vcd** file for power estimation.

## Scripting Support

 You can run procedures and make settings described in this chapter in a Tcl script. You can also run some procedures at a command prompt.

 For detailed information about scripting command options, refer to the Quartus II Command-Line and Tcl API Help browser.

To run the Help browser, type the following command at the command prompt:

```
quartus_sh --qhelp ↵
```

The *Scripting Reference Manual* includes the same information in PDF format.



For more information about Tcl scripting, refer to the *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*. Refer to the *Quartus II Settings File Manual* for information about all settings and constraints in the Quartus II software. For more information about command-line scripting, refer to the *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*.

## Generate NC-Sim Simulation Output Files

You can generate **.vo** files and **.sdo** simulation output files with Tcl commands or at a command prompt.

For more information about generating **.vo** simulation output files and **.sdo** file simulation output files, refer to “[Quartus II Simulation Output Files](#)” on page [4-20](#).

### *Tcl Commands:*

The following three assignments cause a Verilog HDL netlist to be written out when you run the Quartus II netlist writer. The netlist has a 1 ps timing resolution for the NC-Sim Simulation software.

```
set_global_assignment -name EDA_OUTPUT_DATA_FORMAT VERILOG -section_id eda_simulation
set_global_assignment -name EDA_TIME_SCALE "1 ps" -section_id eda_simulation
set_global_assignment -name EDA_SIMULATION_TOOL "NC-Verilog (Verilog)"
```

Use the following Tcl command to run the Quartus II netlist writer:

```
execute_module -tool eda
```

### *Command Prompt*

Use the following command to generate a simulation output file for the Cadence NC-Sim software simulator. Specify Verilog HDL or VHDL for the format.

```
quartus_eda <project name> --simulation --format=<verilog|vhdl> --tool=ncsim ↵
```

## Conclusion

The Cadence NC family of simulators work within an Altera FPGA design flow to perform RTL functional, post-synthesis, and gate-level timing simulation, easily and accurately.

Altera provides functional models of LPM and Altera-specific megafunctions that you can compile with your testbench or design. For timing simulation, use the atom netlist file generated by Quartus II compilation.

The seamless integration of the Quartus II software and Cadence NC tools make this simulation flow an ideal method for fully verifying an FPGA design.

## Referenced Documents

This chapter references the following documents:

- *Cadence NC-Sim Simulation Design Example*
- *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*
- *PowerPlay Power Analysis* chapter in volume 3 of the *Quartus II Handbook*
- *Quartus II Classic Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*
- *Quartus II Settings File Manual*
- *Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*
- *SDF Annotate Guide* and *Cadence NC-Sim User Manual* from Cadence
- *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*

# Document Revision History

Table 4–9 shows the revision history for this chapter.

| <b>Table 4–9. Document Revision History (Part 1 of 2)</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                          |
|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|
| <b>Date and Document Version</b>                          | <b>Changes Made</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <b>Summary of Changes</b>                                |
| May 2008<br>v8.0.0.0                                      | <ul style="list-style-type: none"> <li>Updated Table 4–1.</li> <li>Updated Figure 4–1.</li> <li>Updated “Compilation in Command-Line Mode” on page 4–12.</li> <li>Updated “Generating a Timing Netlist with Different Timing Models” on page 4–24.</li> <li>Added “Disable Timing Violation on Registers” on page 4–26.</li> <li>Updated “Simulating Designs that Include Transceivers” on page 4–30.</li> <li>Updated “Performing a Gate Level Simulation Using NativeLink” on page 4–41.</li> <li>Added “Generating a Timing VCD File for PowerPlay” on page 4–44.</li> <li>Added hyperlinks to referenced documents throughout the chapter.</li> <li>Minor editorial updates.</li> </ul> | Updated for the Quartus II software version 8.0 release. |
| October 2007<br>v7.2.0                                    | <ul style="list-style-type: none"> <li>Updated Table 4–1.</li> <li>Updated “Operating Condition Example: Generate All Timing Models for Stratix III and Cyclone III Devices” on page 4–26.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Updated for the Quartus II software version 7.2 release. |
| May 2007<br>v7.1.0                                        | <ul style="list-style-type: none"> <li>Updated “Software Requirements” on page 4–1.</li> <li>Updated “Generating a Gate-Level Timing Simulation Netlist” on page 4–24.</li> <li>Added “Perform Timing Simulation Using Post-Synthesis Netlist” on page 4–27.</li> <li>Updated “Pulse Reject Delays” on page 4–37.</li> <li>Updated “Performing a Gate Level Simulation Using NativeLink” on page 4–41.</li> <li>Updated procedure in “Setting Up a Testbench” on page 4–41.</li> <li>Added “Referenced Documents” on page 4–51.</li> </ul>                                                                                                                                                  | —                                                        |
| March 2007<br>v7.0.0                                      | Updated Quartus II software 7.0 revision and date only. No other changes made to chapter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | —                                                        |
| November 2006<br>v6.1.0                                   | <ul style="list-style-type: none"> <li>Added new software versions to Table 4–1.</li> <li>Several other minor changes.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Updated for the Quartus II software version 6.1 release. |

| <b>Table 4-9. Document Revision History (Part 2 of 2)</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                           |
|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
| <b>Date and Document Version</b>                          | <b>Changes Made</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                             | <b>Summary of Changes</b> |
| May 2006<br>v6.0.0                                        | <p>Updated for the Quartus II software version 6.0.0:</p> <ul style="list-style-type: none"> <li>● Added a section about setting VCS as the Simulation Tool</li> <li>● Updated EDA Tools Settings in the GUI.</li> <li>● Updated the Synopsys Design Constraints File information.</li> <li>● Added pulse_e and pulse_r information to simulation sections.</li> <li>● Added Quartus II-Generated Testbench information</li> <li>● Updated megafunction information.</li> </ul> | —                         |
| December 2005<br>v5.1.1                                   | <ul style="list-style-type: none"> <li>● Removed reference to convert_hex2ver.obj.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                   | —                         |
| October 2005<br>v5.1.0                                    | Updated for the Quartus II software version 5.1.                                                                                                                                                                                                                                                                                                                                                                                                                                | —                         |
| May 2005<br>v5.0.0                                        | <ul style="list-style-type: none"> <li>● Updated information.</li> <li>● Added Using NativeLink with NC-Sim section.</li> <li>● New functionality for Quartus II software 5.0.</li> </ul>                                                                                                                                                                                                                                                                                       | —                         |
| December 2004<br>v3.0                                     | Reorganized chapter and updated information.                                                                                                                                                                                                                                                                                                                                                                                                                                    | —                         |
| August 2004<br>v2.1                                       | <ul style="list-style-type: none"> <li>● New functionality for Quartus II software 4.1 SP1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                          | —                         |
| June 2004<br>v2.0                                         | <ul style="list-style-type: none"> <li>● Updates to tables and figures.</li> <li>● New functionality for Quartus II software 4.1.</li> </ul>                                                                                                                                                                                                                                                                                                                                    | —                         |
| February 2004<br>v1.0                                     | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                | —                         |

### Introduction

This chapter is an overview on using the Active-HDL software to simulate designs that target Altera® FPGAs. It provides a step-by-step explanation of how to perform register transfer level (RTL) functional simulations, post-synthesis simulations, and gate-level timing simulations for Verilog HDL or VHDL designs using Active-HDL software. This chapter also describes the location of the simulation library files, how to compile these library files, and how to load the design and testbench.

This chapter contains the following topics:

- “Software Compatibility”
- “Using Active-HDL Software in Quartus II Design Flows” on page 5–2
- “Simulation Libraries” on page 5–4
- “Simulation Netlist Files” on page 5–8
- “Perform Simulation Using the Active-HDL Software (GUI Mode)” on page 5–13
- “Perform Simulation Using the Active-HDL Software (Batch Mode)” on page 5–35
- “Simulating Designs that Include Transceivers” on page 5–51
- “Using the NativeLink Feature in Active-HDL Software” on page 5–62
- “Generating VCD Files for PowerPlay” on page 5–68
- “Scripting Support” on page 5–69

### Software Compatibility

To simulate your design using the Active-HDL software, you must first set up the Altera libraries. These libraries are installed with the Quartus® II software. **Table 5–1** shows the compatibility between versions of the Quartus II software and the Aldec Active-HDL software.

**Table 5–1. Supported Quartus II and Active-HDL Software Version Compatibility**

| Aldec                           | Altera                          |
|---------------------------------|---------------------------------|
| Active-HDL software version 7.3 | Quartus II software version 8.0 |
| Active-HDL software version 7.3 | Quartus II software version 7.2 |



For more information about installing the software and directories created during the Quartus II software installation, refer to the *Quartus II Installation and Licensing for Windows* manual or the *Quartus II Installation and Licensing for UNIX and Linux Workstations* manual.

## Using Active-HDL Software in Quartus II Design Flows

You can perform the following types of simulations using the Active-HDL software:

- RTL Functional Simulation
- Post-synthesis Simulation
- Gate-level Timing Simulation

Figure 5–1 illustrates the Active-HDL software used in the Altera Quartus II design flow.

**Figure 5–1. Using the Active-HDL Software in an Altera Quartus II Design****Notes to Figure 5–1:**

- (1) RTL functional simulation is performed before a gate-level timing simulation or post-synthesis simulation. RTL functional simulation verifies the functionality of the design before synthesis and place-and-route. If you are performing a RTL functional simulation through NativeLink, you must complete analysis and elaboration first.
- (2) A post-synthesis simulation verifies the functionality of a design after synthesis has been performed.
- (3) Gate-level timing simulation is a post place-and-route simulation to verify the operation of the design after the worst-case timing delays have been calculated.
- (4) In Active-HDL software, you need to compile the simulation library files to perform RTL functional, post-synthesis, and gate-level timing simulation. All these simulation libraries are located at `<quartus installation directory>\eda\sim_lib`. If you already have the precompiled simulation libraries that come with the Active-HDL software, compiling the simulation library files is not required.

## Simulation Libraries

Simulation model libraries are required to run a simulation whether you are running a RTL functional simulation, post-synthesis simulation, or gate-level timing simulation. In general, running a RTL functional simulation requires the RTL functional simulation model libraries and running a post-synthesis or gate-level timing simulation requires the gate-level timing simulation model libraries. You must compile the necessary library files before you can run the simulation.

However, there are few exceptions where you are also required to compile gate-level timing simulation library files to perform RTL functional simulation. For example, the following are some of the Altera megafunctions gate-level libraries required to perform a RTL functional simulation in third-party simulators:

- ALTCLKBUF
- ALTCLKCTRL
- ALTDQS
- ALTDQ
- ALTDDIO\_IN
- ALTDDIO\_OUT
- ALTDDIO\_BIDIR
- ALTUFM\_NONE
- ALTUFM\_PARALLEL
- ALTUFM\_SPI
- ALTMEMMULT
- ALTREMOTE\_UPDATE



To identify what type of simulation libraries are required to run the simulation for certain Altera megafunction, refer to the last page in the Altera Megafunction MegaWizard. It tells you what simulation library files are required to perform a RTL functional simulation for that particular megafunction.

Simulating the transceiver Megafunction (for example, ALT2GXB) is also another exception which requires the gate-level libraries to perform RTL functional simulation and vice-versa. For detailed, step-by-step instructions about how to simulate the transceiver Megafunction, refer to “[Simulating Designs that Include Transceivers](#)” on page [5-51](#).

### Simulation Library Files in the Quartus II Software

In Active-HDL software, you must compile the necessary libraries to perform RTL functional, post-synthesis functional, or gate-level timing simulation. The following sections show the location of these library files in the Quartus II directory structure. You can refer to these library files for any particular simulation model that you are looking for.

*RTL Functional Simulation Library Files*

Table 5–2 shows the VHDL RTL simulation model location in the Quartus II directory.

| <b>Table 5–2. RTL Functional Simulation Library Files in the Quartus II Software (VHDL)</b> |                                                                                                                                                                                                                   |
|---------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>RTL Simulation Model</b>                                                                 | <b>Location in Quartus II Directory Structure</b>                                                                                                                                                                 |
| LPM                                                                                         | <Quartus II installation directory>\eda\sim\lib\220\pack.vhd<br><Quartus II installation directory>\eda\sim\lib\220\model.vhd<br><Quartus II installation directory>\eda\sim\lib\220\model_87.vhd (1)             |
| Altera Megafunction                                                                         | <Quartus II installation directory>\eda\sim\lib\altera_mf_components.vhd<br><Quartus II installation directory>\eda\sim\lib\altera_mf.vhd<br><Quartus II installation directory>\eda\sim\lib\altera_mf_87.vhd (1) |
| Low-level Primitives                                                                        | <Quartus II installation directory>\eda\sim\lib\altera_primitives_components.vhd<br><Quartus II installation directory>\eda\sim\lib\altera_primitives.vhd                                                         |
| ALTGXBX<br>Megafunction<br>(Stratix GX)                                                     | <Quartus II installation directory>\eda\sim\lib\stratixgx_mf_components.vhd<br><Quartus II installation directory>\eda\sim\lib\stratixgx_mf.vhd                                                                   |

*Note to Table 5–2:*

(1) Simulating a design that uses VHDL-1987.

Table 5–3 shows the Verilog RTL simulation model location in the Quartus II directory.

| <b>Table 5–3. RTL Functional Simulation Library Files in the Quartus II Software (Verilog)</b> |                                                                     |
|------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|
| <b>RTL Simulation Model</b>                                                                    | <b>Location in Quartus II Directory Structure</b>                   |
| LPM                                                                                            | <Quartus II installation directory>\eda\sim\lib\220\model.v         |
| Altera Megafunction                                                                            | <Quartus II installation directory>\eda\sim\lib\altera_mf.v         |
| Low-level Primitives                                                                           | <Quartus II installation directory>\eda\sim\lib\altera_primitives.v |
| ALTGXBX<br>Megafunction<br>(Stratix GX)                                                        | <Quartus II installation directory>\eda\sim\lib\stratixgx_mf.v      |

*Gate-Level Timing Simulation Library Files*

Table 5-4 shows the VHDL gate-level timing simulation model location in the Quartus II directory.

| <b>Table 5-4. Gate-Level Timing Simulation Library Files in the Quartus II Software (VHDL) (Part 1 of 2)</b> |                                                                                                                                                                   |
|--------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Device Simulation Model</b>                                                                               | <b>Location in Quartus II Directory Structure</b>                                                                                                                 |
| Arria® GX (without transceiver block)                                                                        | <Quartus II installation directory>\ledasim_lib\arriagx_components.vhd<br><Quartus II installation directory>\ledasim_lib\arriagx_atoms.vhd                       |
| Arria GX (with transceiver block)                                                                            | <Quartus II installation directory>\ledasim_lib\arriagx_hssi_components.vhd<br><Quartus II installation directory>\ledasim_lib\arriagx_hssi_atoms.vhd             |
| Stratix® IV                                                                                                  | <Quartus II installation directory>\ledasim_lib\stratixiv_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixiv_atoms.vhd                   |
| Stratix IV (with transceiver block)                                                                          | <Quartus II installation directory>\ledasim_lib\stratixiv_hssi_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixiv_hssi_atoms.vhd         |
| Stratix IV (with PCI Express)                                                                                | <Quartus II installation directory>\ledasim_lib\stratixiv_pcie_hip_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixiv_pcie_hip_atoms.vhd |
| Stratix III                                                                                                  | <Quartus II installation directory>\ledasim_lib\stratixiii_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixiii_atoms.vhd                 |
| Stratix II                                                                                                   | <Quartus II installation directory>\ledasim_lib\stratixii_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixii_atoms.vhd                   |
| Stratix II GX (without transceiver block)                                                                    | <Quartus II installation directory>\ledasim_lib\stratixiigx_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixiigx_atoms.vhd               |
| Stratix II GX (with transceiver block)                                                                       | <Quartus II installation directory>\ledasim_lib\stratixiigx_hssi_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixiigx_hssi_atoms.vhd     |
| Stratix                                                                                                      | <Quartus II installation directory>\ledasim_lib\stratix_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratix_atoms.vhd                       |
| Stratix GX                                                                                                   | <Quartus II installation directory>\ledasim_lib\stratixgx_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixgx_atoms.vhd                   |
| Stratix GX (with transceiver block)                                                                          | <Quartus II installation directory>\ledasim_lib\stratixgx_hssi_components.vhd<br><Quartus II installation directory>\ledasim_lib\stratixgx_hssi_atoms.vhd         |
| Cyclone® II                                                                                                  | <Quartus II installation directory>\ledasim_lib\cycloneii_components.vhd<br><Quartus II installation directory>\ledasim_lib\cycloneii_atoms.vhd                   |
| Cyclone                                                                                                      | <Quartus II installation directory>\ledasim_lib\cyclone.vhd<br><Quartus II installation directory>\ledasim_lib\cyclone_atoms.vhd                                  |
| MAX® II                                                                                                      | <Quartus II installation directory>\ledasim_lib\maxii_components.vhd<br><Quartus II installation directory>\ledasim_lib\maxii_atoms.vhd                           |
| MAX 7000 and MAX 3000                                                                                        | <Quartus II installation directory>\ledasim_lib\max_components.vhd<br><Quartus II installation directory>\ledasim_lib\max_atoms.vhd                               |
| APEX™ II                                                                                                     | <Quartus II installation directory>\ledasim_lib\apexii_components.vhd<br><Quartus II installation directory>\ledasim_lib\apexii_atoms.vhd                         |

**Table 5–4. Gate-Level Timing Simulation Library Files in the Quartus II Software (VHDL) (Part 2 of 2)**

| Device Simulation Model              | Location in Quartus II Directory Structure                                                                                                    |
|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| APEX 20K                             | <Quartus II installation directory>\eda\sim_lib\apex20k_components.vhd<br><Quartus II installation directory>\eda\sim_lib\apex20k_atoms.vhd   |
| APEX 20KC, APEX 20KE, and Excalibur™ | <Quartus II installation directory>\eda\sim_lib\apex20ke_components.vhd<br><Quartus II installation directory>\eda\sim_lib\apex20ke_atoms.vhd |
| FLEX® 10KE and ACEX® 1K              | <Quartus II installation directory>\eda\sim_lib\flex10ke_components.vhd<br><Quartus II installation directory>\eda\sim_lib\flex10ke_atoms.vhd |

Table 5–5 shows the Verilog gate-level timing simulation model location in the Quartus II directory.

**Table 5–5. Gate-Level Timing Simulation Library Files in the Quartus II Software (Verilog) (Part 1 of 2)**

| Device Simulation Model                   | Location in Quartus II Directory Structure                                 |
|-------------------------------------------|----------------------------------------------------------------------------|
| Arria GX (without transceiver block)      | <Quartus II installation directory>\eda\sim_lib\arriagx_atoms.v            |
| Arria GX (with transceiver block)         | <Quartus II installation directory>\eda\sim_lib\arriagx_hssi_atoms.v       |
| Stratix IV                                | <Quartus II installation directory>\eda\sim_lib\stratixiv_atoms.v          |
| Stratix IV (with transceiver block)       | <Quartus II installation directory>\eda\sim_lib\stratixiv_hssi_atoms.v     |
| Stratix IV (with PCI Express)             | <Quartus II installation directory>\eda\sim_lib\stratixiv_pcie_hip_atoms.v |
| Stratix III                               | <Quartus II installation directory>\eda\sim_lib\stratixiii_atoms.v         |
| Stratix II                                | <Quartus II installation directory>\eda\sim_lib\stratixii_atoms.v          |
| Stratix II GX (without transceiver block) | <Quartus II installation directory>\eda\sim_lib\stratixiigx_atoms.v        |
| Stratix II GX (with transceiver block)    | <Quartus II installation directory>\eda\sim_lib\stratixiigx_hssi_atoms.v   |
| Stratix                                   | <Quartus II installation directory>\eda\sim_lib\stratix_atoms.v            |
| Stratix GX                                | <Quartus II installation directory>\eda\sim_lib\stratixgx_atoms.v          |
| Stratix GX (with transceiver block)       | <Quartus II installation directory>\eda\sim_lib\stratixgx_hssi_atoms.v     |
| Cyclone II                                | <Quartus II installation directory>\eda\sim_lib\cycloneii_atoms.v          |
| Cyclone                                   | <Quartus II installation directory>\eda\sim_lib\cyclone_atoms.v            |
| MAX II                                    | <Quartus II installation directory>\eda\sim_lib\maxii_atoms.v              |

**Table 5-5. Gate-Level Timing Simulation Library Files in the Quartus II Software (Verilog) (Part 2 of 2)**

| Device Simulation Model             | Location in Quartus II Directory Structure                       |
|-------------------------------------|------------------------------------------------------------------|
| MAX 7000 and MAX 3000               | <Quartus II installation directory>\eda\sim_lib\max_atoms.v      |
| APEX II                             | <Quartus II installation directory>\eda\sim_lib\apexii_atoms.v   |
| APEX 20K                            | <Quartus II installation directory>\eda\sim_lib\apex20k_atoms.v  |
| APEX 20KC, APEX 20KE, and Excalibur | <Quartus II installation directory>\eda\sim_lib\apex20ke_atoms.v |
| FLEX 10KE and ACEX 1K               | <Quartus II installation directory>\eda\sim_lib\flex10ke_atoms.v |

## Simulation Netlist Files

Simulation netlist files are required to perform post-synthesis simulation or gate-level timing simulation. These simulation netlist files are generated from the EDA Netlist Writer.

If you're performing post-synthesis simulation, the Verilog Output File (\*.vo) or VHDL Output File (\*.vho) is required. The section, ["Generate Post-Synthesis Simulation Netlist Files" on page 5-8](#) shows you the steps to generate post-synthesis simulation netlist files for \*.vo or \*.vho files.

If you're performing gate-level timing simulation, not only is the \*.vo file or \*.vho file required, but the Standard Delay Format Output File (\*.sdo) is also required. The .sdo file is used to annotate the delay for the elements found in the \*.vo or \*.vho file. The section, ["Generate Gate-Level Timing Simulation Netlist Files" on page 5-10](#) shows you the steps how to generate gate-level timing simulation netlist files (that is, \*.vo or \*.vho files and \*.sdo files).

### Generate Post-Synthesis Simulation Netlist Files

The following steps describe the process of generating a post-synthesis simulation netlist files in the Quartus II software:

1. Perform Analysis and Synthesis. On the Processing menu, point to **Start** and click **Start Analysis and Synthesis** (you can also perform this after step 2).
2. Turn on the **Generate Netlist for Functional Simulation Only** option by performing the following steps:
  - a. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.

- b. In the **Category** list, select **Simulation**. The **Simulation** page appears.
  - c. In the **Tool name** list, select **Active-HDL**.
  - d. Under **EDA Netlist Writer options**, in the **Format for output netlist** list, select **VHDL** or **Verilog**. You can also modify where you want the post-synthesis netlist generated by editing or browsing to a directory in the **Output directory** box.
  - e. Click **More Settings**. The **More EDA Tools Simulation Settings** dialog box appears. In the **Existing options settings** list, click **Generate Netlist for Functional Simulation Only** and select **On** from the **Setting** list under **Options**.
  - f. Click **OK**.
  - g. In the **Settings** dialog box, click **OK**.
3. Run the EDA Netlist Writer. On the Processing menu, point to **Start** and click **Start EDA Netlist Writer**.

During the EDA Netlist Writer stage, the Quartus II software produces a **.vo** or **.vho** file that can be used for post-synthesis simulations in the Active-HDL software. This netlist file is mapped to architecture-specific primitives. No timing information is included at this stage. The resulting netlist is located in the output directory you specified in the **Settings** dialog box, which defaults to the *<project directory>/simulation/activehdl* directory.

If you want to generate a post-synthesis simulation netlist with just the cell delays, you can generate **\*.sdo** file without running the fitter. In this case, the **\*.sdo** file includes all timing values for only the device cells. Interconnect delays are not included because fitting (placement and routing) has not been performed. To generate the post-synthesis netlist and **\*.sdo** file, type the following commands at a command prompt:

```
quartus_map <project name> -c <revision name> ↵
quartus_sta <project name> -c <revision name> --post_map \
--zero_ic_delays ↵
or
quartus_tan <project name> -c <revision name> --post_map \
--zero_ic_delays ↵
quartus_eda <project name> -c <revision name> --simulation \
--tool= <3rd party EDA tool> --format=<HDL language> ↵
```



For more information about the **-format** and **-tool** options, type the following command at a command prompt:

```
quartus_eda -help=<options> ↵
```

## Generate Gate-Level Timing Simulation Netlist Files

To perform gate-level timing simulation, the Active-HDL software requires information about how the design was placed into device-specific architectural blocks. The Quartus II software provides this information in the form of a **\*.vo** file for Verilog HDL designs and a **\*.vho** file for VHDL designs. The accompanying timing information is stored in the **.sdo** file, which annotates the delay for the elements found in the Verilog Output file or VHDL Output file.

The following steps describe the process of generating a gate-level timing simulation netlist file in the Quartus II software:

1. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
2. In the **Category** list, click the “+” icon to expand **EDA Tool Settings** and select **Simulation**. The **Simulation** page appears.
3. In the **Tool name** list, select **Active-HDL**.
4. Under **EDA Netlist Writer options**, in the **Format for output netlist** list, select **VHDL** or **Verilog**. You can also modify where you want the post-synthesis netlist generated by editing or browsing to a directory in the **Output directory** box.
5. Click **OK**.
6. In the **Settings** dialog box, click **OK**.
7. If you have not run a full compilation, perform a full compilation. On the Processing menu, click **Start Compilation**.
8. If you have already run a full compilation, run the EDA Netlist Writer. On the Processing menu, point to **Start** and click **Start EDA Netlist Writer**.

During the Full compilation or EDA Netlist Writer stage, the Quartus II software produces a **\*.vo** file, **\*.vho** file, and a **\*.sdo** file used for gate-level timing simulations in the Active-HDL software. This netlist file is mapped to architecture-specific primitives. The

timing information for the netlist is included in the **\*.sdo** file. The resulting netlist is located in the output directory you specified in the **Settings** dialog box, which defaults to `<project directory>/simulation/activehdl`.

### Generating Different Timing Models

In Stratix III and later devices (for example, Cyclone III and Stratix IV), you can specify different temperature and voltage parameters to generate the timing netlist. If you enable the Quartus II Classic or Quartus II TimeQuest Timing Analyzer when generating the simulation netlist files (**\*.vo** or **\*.vho** and **\*.sdo**), different timing models for different operating conditions are used by default. Multicorner timing analysis is run by default during the full compilation.

Table 5–6 shows an example of available default operation conditions (model, voltage, and temperature) for Stratix III and Cyclone III devices.

**Table 5–6. Default Available Operating Condition for Stratix III and Cyclone III Devices**

| Device Family | Model | Voltage | Temperature (C) |
|---------------|-------|---------|-----------------|
| Stratix III   | Slow  | 1100 mV | 85°             |
|               | Slow  | 1100 mV | 0°              |
|               | Fast  | 1100 mV | 0°              |
| Cyclone III   | Slow  | 1200 mV | 85°             |
|               | Slow  | 1200 mV | 0°              |
|               | Fast  | 1200 mV | 0°              |

If multicorner timing analysis is not run during full compilation, perform the following steps to manually generate the simulation netlist files (**\*.vo** or **\*.vho** and **\*.sdo**) for the three different operating conditions listed in Table 5–6:

1. Generate all the available corner models at all operating conditions. Type the following command at a command prompt:

```
quartus_sta <project name> --multicorner ↵
```

2. Generate the simulation output files for all three corners specified in Table 5–6. Perform steps 2 through 8 in “[Generate Gate-Level Timing Simulation Netlist Files](#) on page 5–10. The output files are generated in the simulation output directory.

The following examples show all the simulation netlist files generated for the three operating conditions of [Table 5–6](#), when **Verilog** is selected as the output netlist format:

**First slow corner (slow, 1100 mV, 85° C):**

VO file— *<revision name>.vo*

SDO file— *<revision name>\_v.sdo*



The *<revision name>.vo* and *<revision name>\_v.sdo* are generated for backward compatibility issues in case there are existing scripts that still use them.

VO file— *<revision name>\_<speedgrade>\_1100mv\_85c\_slow.vo*

SDO file— *<revision name>\_<speedgrade>\_1100mv\_85c\_v\_slow.sdo*

**Second slow corner (slow, 1100 mV, 0° C):**

VO file— *<revision name>\_<speedgrade>\_1100mv\_0c\_slow.vo*

SDO file— *<revision name>\_<speedgrade>\_1100mv\_0c\_v\_slow.sdo*

**Fast corner (fast, 1100 mV, 0° C):**

VO file— *<revision name>\_min\_1100mv\_0c\_fast.vo*

SDO file— *<revision name>\_min\_1100mv\_0c\_v\_fast.sdo*

For older devices, a slow-corner (worst case) timing model is used by default. There are only two timing models available, which are the slow-corner and fast-corner. To generate the **\*.sdo** file using a different timing model, you must run the Quartus II Classic or the Quartus II TimeQuest Timing Analyzer with a different timing model before you start the EDA Netlist writer.

To run the Quartus II Classic Timing Analyzer with the best-case model, on the Processing menu, point to **Start** and click **Start Classic Timing Analyzer (Fast Timing Model)**. After timing analysis is complete, the Compilation Report appears. You can also type the following command at a command prompt:

```
quartus_tan <project_name> --fast_model=on ↵
```

To run the Quartus II TimeQuest Timing Analyzer with a best-case model, use the **-fast\_model** option after you create the timing netlist. The following command enables fast timing models:

```
create_timing_netlist --fast_model ↵
```

After you run the Quartus II Classic or Quartus II TimeQuest Timing Analyzer, perform steps 2 through 8 in “[Generate Gate-Level Timing Simulation Netlist Files](#)” on page 5–10 to generate the \*.sdo file. For fast corner timing models, the **–fast** post fix is added to the \*.vo or \*.vho, and \*.sdo file (for example, **my\_project\_fast.vo** or **my\_project\_fast.vho**, and **my\_project\_fast.sdo**).



For more information about generating the timing netlist with a different timing model, refer to the *Quartus II Classic Timing Analyzer* or the *Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

### *Disable Timing Violation on Registers*

In certain situations, the timing violation can be ignored and you can disable the timing violation on registers; for example, timing violations that occur in internal synchronization registers used for asynchronous clock-domain crossing.

By default the **x\_onViolationOption** logic option is **On**, which means simulation will show “x” whenever a timing violation occurs. To disable showing the timing violation on certain registers, set the **x\_onViolationOption** logic option to **Off** on those registers. The following command is an example of the QSF file.

```
set_instance_assignment -name X_ON_VIOLATION_OPTION OFF -to <register_name>
```

## Perform Simulation Using the Active-HDL Software (GUI Mode)

Perform simulation of Verilog HDL or VHDL designs with Active-HDL software at various levels to verify designs from different aspects. It is divided into three categories: RTL functional simulation, post-synthesis simulation, and gate-level timing Simulation. Simulation helps you verify your designs and debug them against any possible errors the designs may have. The following sections provide step-by-step instructions to perform the simulation through a GUI.

Workspace creation is the first and mandatory step to start working in the Active-HDL GUI. You must create a new workspace to add the simulation model files, design files, and testbench file before you can compile them.

### **Simulating the VHDL Designs**

Simulation of a VHDL design using the Active-HDL GUI is user friendly. You do not need to remember the commands to compile the libraries or load and simulate the VHDL design files. You can go through the Active-HDL GUI to perform the RTL functional simulation,

post-synthesis simulation, and gate-level timing simulation. The following sections show you how to perform simulation at various levels through the Active-HDL GUI.

### *Perform RTL Functional Simulation*

RTL functional simulation is typically performed to verify the syntax of the code and to check the functionality of the design. The following sections show how to perform RTL functional simulation in the Active-HDL software for VHDL designs.



If your Active-HDL software comes with precompiled simulation libraries, creating or compiling simulation libraries is not required and you can skip the following Create and Compile Simulation Libraries section.

### **Create and Compile Simulation Libraries**

Simulation libraries are required to simulate a design that contains an Altera primitive, lpm function, or Altera megafunction. Different designs require different simulation libraries and you must create these required simulation libraries before you could run the simulation.

For example, the library name for Altera megafunctions should be **altera\_mf** and the library name for LPM should be **lpm**. To see all the functional simulation library files, refer to ["RTL Functional Simulation Library Files" on page 5-5](#).

Before you start creating simulation libraries (for example, **altera\_mf** and **lpm**) ensure that the library with the same name is not present in the Active-HDL software.

1. In the Active-HDL software, on the View menu, click **Library Manager**. The **Library Manager** window appears.
2. Check to see if the simulation libraries (for example, **altera\_mf** and **lpm**) that you are going to create are not already present.
3. If the simulation libraries are already present, you must detach them. To detach these simulation libraries, right click on the library and select **Detach** from the menu list.

To create and compile the simulation libraries, you must create a new workspace. Perform the following steps to create a new workspace, create a new library, compile the library, and register the library in the **Library Manager**.

1. In the Active-HDL software, on the File menu, point to **New** and click **Design**. The **New Design Wizard** appears.
2. Select **Create an Empty Design** and keep the **Create New Workspace** option selected.
3. Click **Next**. The **Property** page appears. In the **Property** page, click **Next** to proceed to the **Design name** and **Library name** fields.
4. Type the design name (for example, **altera\_mf** or **lpm**), select the location of your RTL design in the **Design folder** field and click **Next**. For simplicity, keep the design name and the library name the same (for example, **altera\_mf** or **lpm**).
5. Click **Finish** to complete the wizard.
6. Click on the Design menu and select **Add files to Design...**
7. Browse to the *<Quartus II installation directory>/eda/sim\_lib* and add the necessary simulation model files.

Compile the **altera\_mf\_components.vhd** and **altera\_mf.vhd** model files into the **altera\_mf** library. Compile the **220pack.vhd** and **220model.vhd** model files into the **lpm** library.

8. On the Design menu, click **Compile All** to compile all the files (for example, **altera\_mf\_components.vhd** and **altera\_mf.vhd**) to the design library.
9. On the File menu, click **Close Workspace**.
10. You must register the created library in the Active-HDL software. On the View menu, click **Library Manager**. The Library Manager window appears.
11. On the Library menu, click **Attach Library...**
12. Locate the **.lib** file (for example, **altera\_mf.lib** or **lpm.lib**) from the design directory that you created in the previous steps and click **Open**. This will attach the simulation library as a global library inside your library manager and make it visible for any design in Active-HDL.
13. Repeat step 1 to step 12 to create and compile another simulation library.

### Compile Testbench and Design Files into the Work Library

To compile design files and the Testbench into a Work Library, you must create a new workspace. Perform the following steps to create a new workspace and compile your testbench and design files into the work library.

1. In the Active-HDL software, on the File menu, point to **New** and click **Design**. The **New Design Wizard** appears.
2. Select **Create an Empty Design** and keep the **Create New Workspace** option selected.
3. Click **Next**. The **Property** page appears. In the **Property** page, click **Next** to reach the design name and library name options.
4. Type **work** for the design name and select the location of your RTL design. For simplicity, keep the design name and the library name the same.
5. Click **Finish** to complete the wizard.
6. Click on the Design menu and select **Add files to Design...**
7. Browse to the RTL design directory and add the testbench and RTL design files.
8. On the Design menu, click **Compile All** to compile the testbench and RTL design files.



Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following steps:

1. In the **Design Browser**, click the **Top-level Selection** drop-down menu. Select the top-level entity, which is your testbench with corresponding architecture.
2. Go to the Simulation menu and select **Initialize Simulation**. This loads the simulation.
3. The Design Browser automatically switches to the Structure tab and shows you the design tree.

## Running the Simulation

Perform the following steps to run a simulation:

1. On the File menu, point to **New** and click **Waveform**.
2. Drag signals of interest from the Design Browser (in the Structure tab) to the Waveform window.
3. On the Simulation menu, click **Run Until...** A pop-up window appears.
4. Specify how long you want your simulation to run (for example, 500 ns).

## Perform Post-Synthesis Simulation

Perform post-synthesis simulation to verify that functionality of the design is not lost after synthesis. You can create the post-synthesis netlist in the Quartus II software and use the netlist to perform post-synthesis simulation with the Active-HDL software.

Before you run post-synthesis simulation, generate post-synthesis simulation netlist files. Refer to the instructions in [“Generate Post-Synthesis Simulation Netlist Files” on page 5–8](#).

Use the instructions in the following section to perform a post-synthesis simulation for VHDL designs in the Active-HDL software.



If your Active-HDL software comes with precompiled simulation libraries, creating or compiling simulation libraries in this case is not required and you can skip the following Create and Compile Simulation Libraries section.

## Create and Compile Simulation Libraries

Simulation libraries are required to simulate a design that is mapped to post-synthesis primitives. Depending on the device family that you are using, you must create the required simulation libraries before running the simulation.

Performing post-synthesis simulation requires a gate-level timing simulation library. For example, the library name for the Stratix III family should be **stratixiii**. To see all the gate-level timing simulation library files, refer to [“Gate-Level Timing Simulation Library Files” on page 5–6](#).

Before you create simulation libraries (for example, **stratixiii**) ensure that a library with the same name is not present in the Active-HDL software. Do this by performing the following steps:

1. In the Active-HDL software, on the View menu, click **Library Manager**. The **Library Manager** window appears.
2. Check to see that the simulation libraries (for example, **stratixiii**) you are going to create are not already present.
3. If these simulation libraries are present, you must detach them. To detach these simulation libraries, right click on the library and select **Detach** from the menu list.

To create and compile the simulation libraries, you must create a new workspace. Perform the following steps to create a new workspace, create a new library, and compile and register the library in the **Library Manager**. Do this by performing the following steps:

1. In the Active-HDL software, on the File menu, point to **New** and click **Design**. The New Design Wizard appears.
2. Select **Create an Empty Design** and keep the **Create New Workspace** option selected.
3. Click **Next**. The **Property** page appears. In the **Property** page, click **Next** to reach the design name and library name options.
4. Type the design name (for example, **stratixiii**) and select the location of your RTL design. For simplicity, keep the design name and the library name the same.
5. Click **Finish** to complete the wizard.
6. Click on the Design menu and select **Add files to Design...**
7. Browse to the *<Quartus II installation directory>/eda/sim\_lib* and add the necessary simulation model files.



Compile the **stratixiii\_atoms\_components.vhd** and **stratixiii\_atoms.vhd** model files into the **stratixiii** library.

8. On the Design menu, click **Compile All** to compile all the files (for example, **altera\_mf\_components.vhd** and **altera\_mf.vhd**) to the design library.
9. On the File menu, click **Close Workspace**.

10. You must now register the created library in the Active-HDL software. On the View menu, click **Library Manager**. The Library Manager window appears.
11. On the Library menu, click **Attach Library...**
12. Locate the **.lib** file (for example, **stratixiii.lib**) from your design directory that you created in the previous steps and click **Open**. This attaches the simulation library as a global library inside your library manager and makes it visible for any design in the Active-HDL software.
13. Repeat step 1 to step 12 to create and compile another simulation library, if necessary.

#### Compile the Testbench and Design File into the Work Library

To compile design files and the Testbench into a Work Library, you must create a new workspace. Perform the following steps to create a new workspace, and compile your testbench and **\*.vho** file into the work library.

1. In the Active-HDL software, on the File menu, point to **New** and click **Design**. The New Design Wizard appears.
2. Select **Create an Empty Design** and keep the **Create New Workspace** option selected.
3. Click **Next**. The **Property** page appears. In the **Property** page, click **Next** to reach the design name and library name options.
4. Type **work** for the design name and select the location of your RTL design. For simplicity, keep the design name and the library name the same.
5. Click **Finish** to complete the wizard.
6. Click on the Design menu and select **Add files to Design...**
7. Browse to the VHDL output file directory (for example, *<project directory>/simulation/activehdl*) and add the VHDL output file (**\*.vho**). Browse to the testbench file directory and add the testbench file.
8. On the Design menu, click **Compile All** to compile the testbench and VHDL output netlist files.



Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following steps:

1. In the **Design Browser**, click the **Top-level Selection** list. Select the top-level entity, which is your testbench with corresponding architecture.
2. Go to the **Simulation** menu and select **Initialize Simulation**. This loads the simulation.
3. The Design Browser automatically switches to the **Structure** tab and displays the design tree.

### Running the Simulation

Perform the following steps to run the simulation:

1. On the **File** menu, point to **New** and click **Waveform**.
2. Drag signals of interest from the Design Browser (in the **Structure** tab) to the Waveform window.
3. On the **Simulation** menu, click **Run Until...**
4. In the pop-up window, specify how long you want your simulation to run (for example, 500 ns).

### *Perform Gate-Level Timing Simulation*

Gate-level timing simulation is a very important step in ensuring that the FPGA device's functionality is still correct and meets all the timing requirements after the design was placed and routed. You can create the gate-level netlist in the Quartus II software and use the netlist to perform gate-level simulation with the Active-HDL software.

Before you run gate-level timing simulation, generate gate-level timing simulation netlist files. Refer to the instructions in “[Generate Gate-Level Timing Simulation Netlist Files](#)” on page [5-10](#).

Use the following instructions to perform a gate-level timing simulation for VHDL designs in the Active-HDL software.



If your Active-HDL software comes with precompiled simulation libraries, creating or compiling simulation libraries in this case is not required and you can skip the following Create and Compile Simulation Libraries section.

### Create and Compile Simulation Libraries

Simulation libraries are required to simulate a design that is mapped to post-fitting primitives. Depending on the device family that you are using, you must create the required simulation libraries before running the simulation.

Performing gate-level timing simulation requires gate-level timing simulation library. For example, the library name for the Stratix III family should be **stratixiii**. To see all the gate-level timing simulation library files, refer to ["Gate-Level Timing Simulation Library Files" on page 5–6](#).

Before you create simulation libraries (for example, **stratixiii**) ensure that a library with the same name is not present in the Active-HDL software. Do this by performing the following steps:

1. In the Active-HDL software, on the **View** menu, Click **Library Manager**. The **Library Manager** window appears.
2. Check to see that the simulation libraries (for example, **stratixiii**) you are going to create are not already present.
3. If these simulation libraries are present, you must detach them. To detach these simulation libraries, right click on the library and select **Detach** from the menu list.

To create and compile simulation libraries, you must create a new workspace. Perform the following steps to create a new workspace, create a new library, and compile and register the library in the **Library Manager**. Do this by performing the following steps:

1. In the Active-HDL software, on the **File** menu, point to **New** and click **Design**. The New Design Wizard appears.
2. Select **Create an Empty Design** and keep the **Create New Workspace** option selected.
3. Click **Next**. The **Property** page appears. In the **Property** page, click **Next** to reach the design name and library name options.
4. Type the design name (for example, **stratixiii**) and select the location of your RTL design. For simplicity, keep the design name and the library name the same.

5. Click **Finish** to complete the wizard.
6. Click on the **Design** menu and select **Add files to Design...**
7. Browse to *<Quartus II installation directory>/eda/sim\_lib* and add the necessary simulation model files.

Compile the **stratixiii\_atoms\_components.vhd** and **stratixiii\_atoms.vhd** model files into the **stratixiii** library.

8. On the **Design** menu, click **Compile All** to compile all the files (for example, **altera\_mf\_components.vhd** and **altera\_mf.vhd**) to the design library.
9. On the **File** menu, click **Close Workspace**.
10. You must now register the created library in the Active-HDL software. On the **View** menu, click **Library Manager**. The Library Manager window appears.
11. On the **Library** menu, click **Attach Library...**
12. Locate the **.lib** file (for example, **stratixiii.lib**) from your design directory that you created in the previous steps and click **Open**. This attaches the simulation library as a global library inside your library manager and makes it visible for any design in the Active-HDL software.
13. Repeat step 1 to step 12 to create and compile another simulation library, if necessary.

#### Compile the Testbench and Design File into the Work Library

To compile design files and the testbench into a Work Library, you must create a new workspace. Perform the following steps to create a new workspace and compile your design files into the work library.

1. In the Active-HDL software, on the **File** menu, point to **New** and click **Design**. The New Design Wizard appears.
2. Select **Create an Empty Design** and keep the **Create New Workspace** option selected.
3. Click **Next**. The **Property** page appears. In the **Property** page, click **Next** to reach the design name and library name options.

4. Type **work** for the design name and select the location of your RTL design. For simplicity, keep the design name and the library name the same.
5. Click **Finish** to complete the wizard.
6. Click on the **Design** menu and select **Add files to Design...**
7. Browse to the VHDL output file directory (for example, *<project directory>/simulation/activehdl*) and add the VHDL output file (\*.vho) and standard output file (\*.sdo). Browse to the testbench file directory and add the testbench file.
8. On the Design menu, click **Compile All** to compile the testbench and VHDL output netlist files.



Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following steps:

1. On the Design menu, click **Settings...** The Design Settings window appears. Expand the **Simulation** category and click **SDF**.



If there are no **.sdo** files listed, no **.sdo** files have been added to the design. You must add the **.sdo** file before running the timing simulation.

2. In the **Files-Region** dialog box, select the level of the design hierarchy to which the **.sdo** file should be bonded to. For example, if your design under test is instantiated in the testbench file under the **i1** label, the region should be '**i1**'.
3. In the **SDF** settings box, set **Value** to **Average** and set **Load** to **Yes** so that the simulator loads this file upon simulation start.



You do not need to set the Value (Minimum, Average, Maximum) for the **\*.sdo** file because the Quartus II EDA Netlist Writer generates the **\*.sdo** file using the same value for the triplet (minimum, average, and maximum timing values).

4. Click **OK** to close the Design Settings window.
5. In the **Design Browser**, click the **Top-level Selection** list. Select the top-level entity, which is your testbench with corresponding architecture.

6. Go to the Simulation menu and select **Initialize Simulation**. This loads the simulation.
7. The Design Browser automatically switches to the Structure tab and shows you the design tree.

### Running the Simulation

Perform the following steps to run simulation:

1. On the File menu, point to **New** and click **Waveform**.
2. Drag signals of interest from the Design Browser (in the Structure tab) to the Waveform window.
3. On the Simulation menu, click **Run Until...**
4. In the pop-up window, specify how long you want your simulation to run (for example, 500 ns).

## Simulating Verilog HDL Designs

Simulation of Verilog HDL designs using the Active-HDL GUI is user friendly. You do not need to remember the commands to compile the libraries or to load and simulate the Verilog HDL design files. You can use the Active-HDL GUI to perform RTL functional simulation, post-synthesis simulation, and gate-level simulation. The following sections show you how to perform simulation at various levels through the Active-HDL GUI.

### *Perform RTL Functional Simulation*

RTL functional simulation is typically performed to verify the syntax of the code and to check the functionality of the design. The following sections show how to perform RTL functional simulation in the Active-HDL software for Verilog HDL designs.



If your Active-HDL software comes with precompiled simulation libraries, creating or compiling simulation libraries is not required and you can skip the following Create and Compile Simulation Libraries section.

### **Create and Compile Simulation Libraries**

Simulation libraries are required to simulate a design that contains an Altera primitive, LPM function, or Altera megafunction. Different designs require different simulation libraries and you must create these required simulation libraries before you could run the simulation.

For example, the library name for Altera megafunctions should be **altera\_mf\_ver** and the library name for LPM should be **lpm**. To see all the functional simulation library files, refer to [“RTL Functional Simulation Library Files” on page 5–5](#).

Before you start creating simulation libraries (for example, **altera\_mf\_ver** or **lpm\_ver**) you ensure that the library with the same name is not present in the Active-HDL software.

1. In the Active-HDL software, on the View menu, click **Library Manager**. The Library Manager window appears.
2. Check to see if the simulation libraries (for example, **altera\_mf\_ver** or **lpm\_ver**) that you are going to create are not already present.
3. If the simulation libraries are already present, you must detach them. To detach these simulation libraries, right click on the library and select **Detach** from the menu list.

To create and compile simulation libraries, you must create a new workspace. Perform the following steps to create a new workspace, create a new library, compile the library, and register the library in the **Library Manager**.

1. In the Active-HDL software, on the File menu, point to **New** and click **Design**. The New Design Wizard appears.
2. Select **Create an Empty Design** and keep the **Create New Workspace** option selected.
3. Click **Next**. The **Property** page appears. In the **Property** page, click **Next** to proceed to the **Design name** and **Library name** fields.
4. Type the design name (for example, **altera\_mf\_ver** or **lpm\_ver**), select the location of your RTL design in the **Design folder** field, and click **Next**. For simplicity, keep the design name and the library name the same.
5. Click **Finish** to complete the wizard.
6. Click on the Design menu and select **Add files to Design...**

7. Browse to the <Quartus II installation directory>/eda/sim\_lib and add the necessary simulation model files.

For example, compile the **altera\_mf.v** model files into the **altera\_mf\_ver** library, and compile the **220model.v** model files into the **lpm\_ver** library.

8. On the Design menu, click **Compile All** to compile all the files (for example, **altera\_mf.v**) to the design library.
9. On the File menu, click **Close Workspace**.
10. You must to register the created library in Active-HDL. On the View menu, click **Library Manager**. The Library Manager window appears.
11. On the Library menu, click **Attach Library...**
12. Locate the **.lib** file (for example, **altera\_mf\_ver.lib**) from the design directory that you created in the previous steps and click **Open**. This attaches the simulation library as a global library inside your library manager and makes it visible for any design in Active-HDL.
13. Repeat steps 1 to 12 to create and compile another simulation library.

#### Compile the Testbench and Design Files into the Work Library

To compile design files and the Testbench into the Work Library, you must create a new workspace. Perform the following steps to create a new workspace and compile your testbench and design files into the work library.

1. In the Active-HDL software, on the File Menu, point to **New** and click **Design**. The New Design Wizard appears.
2. Select **Create an Empty Design** and keep the **Create New Workspace** option selected.
3. Click **Next**. The **Property** page appears. In the **Property** page, click **Next** to reach the design name and library name options.
4. Type **work** for the design name and select the location of your RTL design. For simplicity, keep the design name and the library name the same.
5. Click **Finish** to complete the wizard.

6. Click on the Design menu and select **Add files to Design...**
7. Browse to the RTL design directory and add the testbench and RTL design files.
8. Your design may require simulation libraries that you created previously to compile successfully. For example, the **altera\_mf\_ver** library is required for compiling designs that use Altera Megafunctions. If your design requires these simulation libraries, perform the following steps:
  - a. On the Design Menu, click **Settings...** The Design Settings window appears. Expand the **Compilation** category and click **Verilog**.
  - b. To add the **Verilog Library** settings, click the **Add library** icon (upper-right icon) and click **OK** to insert the required Verilog simulation libraries.



These simulation libraries are the simulation libraries that you compiled or installed previously (for example, **altera\_mf\_ver** and **lpm\_ver**, **altera\_ver**).

9. On the Design menu, click **Compile All** to compile the testbench and RTL design files.



Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following steps:

1. In the **Design Browser**, click the **Top-level Selection** list. Select the top-level module, which is your testbench.
2. To add the required simulation library, on the Design menu, click **Settings...** The Design Settings window appears.
  - a. Expand the **Simulation** category and click **Verilog**.
  - b. In the **Verilog Libraries** window, click the **Add library** icon (top-right icon) and click **OK** to insert the required Verilog simulation libraries (for example, **altera\_mf\_ver**, **lpm\_ver** and **altera\_ver**).
3. On the Simulation menu, click **Initialize Simulation**. This loads the simulation.

4. The Design Browser automatically switches to the **Structure** tab and shows you the design tree.

### Running the Simulation

Perform the following steps to run the simulation:

1. On the File menu, point to **New** and click **Waveform**.
2. Drag signals of interest from the Design Browser (in the Structure tab) to the Waveform window.
3. On the Simulation menu, click **Run Until...**
4. In the pop-up window, specify how long you want your simulation to run (for example, 500 ns).

### Perform Post-Synthesis Simulation

Perform post-synthesis simulation to verify that functionality of the design is not lost after synthesis. You can create the post-synthesis netlist in the Quartus II software and use the netlist to perform post-synthesis simulation with the Active-HDL software.

Before you run post-synthesis simulation, generate post-synthesis simulation netlist files. Refer to the instructions in “[Generate Post-Synthesis Simulation Netlist Files](#)” on page 5–8.

Use the instructions in the following section to perform a post-synthesis simulation for Verilog designs in the Active-HDL software.



If your Active-HDL software comes with precompiled simulation libraries, creating or compiling simulation libraries is not required and you can skip the following Create and Compile Simulation Libraries section.

### Create and Compile Simulation Libraries

Simulation libraries are required to simulate a design that is mapped to post-synthesis primitives. Depending on the device family that you are using, you must create the required simulation libraries before running the simulation.

Performing post-synthesis simulation requires a gate-level timing simulation library. For example, the library name for the Stratix III family should be **stratixiii\_ver**. To see all the gate-level timing simulation library files, refer to “[Gate-Level Timing Simulation Library Files](#)” on page 5–6.

Before you create simulation libraries (for example, **stratixiii\_ver**) ensure that a library with the same name is not present in the Active-HDL software. Do this by performing the following steps:

1. In the Active-HDL software, on the View menu, click **Library Manager**. The Library Manager window appears.
2. Check to see that the simulation libraries (for example, **stratixiii\_ver**) you are going to create are not already present.
3. If these simulation libraries are present, you must detach them. To detach these simulation libraries, right click on the library and select **Detach** from the menu list.

To create and compile the simulation libraries, you must create a new workspace. Perform the following steps to create a new workspace, create a new library, and compile and register the library in the **Library Manager**. Do this by performing the following steps:

1. In the Active-HDL software, on the File menu, point to **New** and click **Design**. The **New Design Wizard** appears.
2. Select **Create an Empty Design** and keep the **Create New Workspace** option selected.
3. Click **Next**. The **Property** page appears. In the **Property** page, click **Next** to reach the design name and library name options.
4. Type the design name (for example, **stratixiii\_ver**) and select the location of your RTL design. For simplicity, keep the design name and the library name the same.
5. Click **Finish** to complete the wizard.
6. Click on the Design menu and select **Add files to Design...**
7. Browse to *<Quartus II installation directory>/eda/sim\_lib* and add the necessary simulation model files.

For example, compile the **stratixiii.v** model file into the **stratixiii\_ver** library.

8. On the Design menu, click **Compile All** to compile all the files (for example, **stratixiii.v**) to the design library.
9. On the File menu, click **Close Workspace**.

10. You must now register the created library in the Active-HDL software. On the View menu, click **Library Manager**. The Library Manager window appears.
11. On the Library menu, click **Attach Library...**
12. Locate the **.lib** file (for example, **stratixiii.lib**) from your design directory that you created in the previous steps and click **Open**. This attaches the simulation library as a global library inside your library manager and makes it visible for any design in the Active-HDL software.
13. Repeat steps 1 to 12 to create and compile another simulation library, if necessary.

#### Compile the Testbench and Design File into the Work Library

To compile design files and the testbench into a Work Library, you must create a new workspace. Perform the following steps to create a new workspace, and compile your testbench and **\*.vo** file into the work library.

1. In the Active-HDL software, on the File menu, point to **New** and click **Design**. The New Design Wizard appears.
2. Select **Create an Empty Design** and keep the **Create New Workspace** option selected.
3. Click **Next**. The **Property** page appears. In the **Property** page, click **Next** to reach the design name and library name options.
4. Type **work** for the design name and select the location of your RTL design. For simplicity, keep the design name and the library name the same.
5. Click **Finish** to complete the wizard.
6. Click on the Design menu and select **Add files to Design...**
7. Browse to the Verilog output file directory (for example, *<project directory>/simulation/activehdl*) and add the Verilog output file (**\*.vo**). Browse to the testbench file directory and add the testbench file.
8. Your design may require simulation libraries that you created previously to compile successfully. For example, the **stratixiii** library is required for compiling designs that use Stratix III devices. If your design requires these simulation libraries, perform the following steps:

- a. On the Design Menu, click **Settings...** The Design Settings window appears. Expand the **Compilation** category and click **Verilog**.
- b. To add the **Verilog Library** settings, click the **Add** library icon (upper-right icon), and click **OK** to insert the required Verilog simulation libraries.



These simulation libraries are the simulation libraries that you compiled or installed previously.

9. On the Design menu, click **Compile All** to compile the testbench and \*.vo files.



Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following steps:

1. In the **Design Browser**, click the **Top-level Selection** list. Select the top-level module, which is your testbench.
2. To add the required simulation library, on the Design Menu, click **Settings...** The Design Settings window appears.
  - a. Expand the **Simulation** category and click **Verilog**.
  - b. In the **Verilog Libraries** window, click the **Add** library icon (top-right icon) and click **OK** to insert the required Verilog simulation libraries (for example, **stratixiii\_ver**).
3. On the Simulation menu, click **Initialize Simulation**. This loads the simulation.
4. The Design Browser automatically switches to the **Structure** tab and shows you the design tree.

### Running the Simulation

Perform the following steps to run a simulation:

1. On the File menu, point to **New** and click **Waveform**.
2. Drag signals of interest from the **Design Browser** (in the **Structure** tab) to the **Waveform** window.
3. On the Simulation menu, click **Run Until...**
4. In the pop-up window, specify how long you want your simulation to run (for example, 500 ns).

### *Perform Gate-Level Timing Simulation*

Gate-level timing simulation is a very important step in ensuring that the FPGA device's functionality is still correct and meets all the timing requirements after the design was placed and routed. You can create the gate-level netlist in the Quartus II software and use the netlist to perform gate-level simulation with the Active-HDL software.

Before you run the gate-level timing simulation, generate gate-level timing simulation netlist files. Refer to the instructions in ["Generate Gate-Level Timing Simulation Netlist Files" on page 5-10](#).

Use the following instructions to perform a gate-level timing simulation for Verilog designs in the Active-HDL software.



If your Active-HDL software comes with precompiled simulation libraries, creating or compiling simulation libraries is not required and you can skip the following Create and Compile Simulation Libraries section.

### Create and Compile Simulation Libraries

Simulation libraries are required to simulate a design that is mapped to post-fitting primitives. Depending on the device family that you are using, you must create the required simulation libraries before running the simulation.

Performing gate-level timing simulation requires a gate-level timing simulation library. For example, the library name for the Stratix III family should be **stratixiii\_ver**. To see all the gate-level timing simulation library files, refer to ["Gate-Level Timing Simulation Library Files" on page 5-6](#).

Before you create simulation libraries (for example, **stratixiii\_ver**) ensure that a library with the same name is not present in the Active-HDL software. Do this by performing the following steps:

1. In the Active-HDL software, on the **View** Menu, Click **Library Manager**. The **Library Manager** window appears.
2. Check to see that the simulation libraries (for example, **stratixiii\_ver**) you are going to create are not already present.
3. If these simulation libraries are present, you must detach them. To detach these simulation libraries, right click on the library and select **Detach** from the menu list.

To create and compile simulation libraries, you must create a new workspace. Perform the following steps to create a new workspace, create a new library, and compile and register the library in the **Library Manager**. Do this by performing the following steps:

1. In the Active-HDL software, on the File menu, point to **New** and click **Design**. The New Design Wizard appears.
2. Select **Create an Empty Design** and keep the **Create New Workspace** option selected.
3. Click **Next**. The **Property** page appears. In the **Property** page, click **Next** to reach the design name and library name options.
4. Type the design name (for example, **stratixiii\_ver**) and select the location of your RTL design. For simplicity, keep the design name and the library name the same.
5. Click **Finish** to complete the wizard.
6. Click on the **Design** menu and select **Add files to Design...**
7. Browse to *<Quartus II installation directory>/eda/sim\_lib* and add the necessary simulation model files.

For example, compile the **stratixiii\_atoms.v** model files into the **stratixiii\_ver** library.

8. On the **Design** menu, click **Compile All** to compile all the files (for example, **stratixiii\_atoms.v**) to the design library.
9. On the File menu, click **Close Workspace**.

10. You must now register the created library in the Active-HDL software. On the **View** menu, click **Library Manager**. The Library Manager window appears.
11. On the Library menu, click **Attach Library...**
12. Locate the **.lib** file (for example, **stratixiii.lib**) from your design directory that you created in the previous steps and click **Open**. This attaches the simulation library as a global library inside your library manager and makes it visible for any design in the Active-HDL software.
13. Repeat step 1 to step 12 to create and compile another simulation library, if necessary.

#### Compile the Testbench and Design File into the Work Library

To compile design files and the testbench into a Work Library, you must create a new workspace. Perform the following steps to create a new workspace and compile your testbench and **\*.vo** file into the work library.

1. In the Active-HDL software, on the **File** menu, point to **New** and click **Design**. The New Design Wizard appears.
2. Select **Create an Empty Design** and keep the **Create New Workspace** option selected.
3. Click **Next**. The **Property** page appears. In the **Property** page, click **Next** to reach the design name and library name options.
4. Type **work** for the design name and select the location of your RTL design. For simplicity, keep the design name and the library name the same.
5. Click **Finish** to complete the wizard.
6. Click on the **Design** menu and select **Add files to Design...**
7. Browse to the Verilog output file directory (for example, *<project directory>/simulation/activehdl*) and add the **\*.vo** file and **\*.sdo** file. Browse to the testbench file directory and add the testbench file.
8. On the Design menu, click **Compile All** to compile the testbench and Verilog output netlist files.



Resolve compile-time errors before proceeding to the following section.

## Loading the Design

To load a design, perform the following steps:

1. In the **Design Browser**, click the **Top-level Selection** list. Select the top-level entity, which is your testbench with corresponding architecture.
2. Go to the **Simulation** menu and select **Initialize Simulation**. This loads the simulation.
3. The Design Browser automatically switches to the **Structure** tab and shows you the design tree.

## Running the Simulation

Perform the following steps to run the simulation:

1. On the File menu, point to **New** and click **Waveform**.
2. Drag signals of interest from the Design Browser (in the Structure tab) to the Waveform window.
3. On the Simulation menu, click **Run Until...**
4. In the pop-up window, specify how long you want your simulation to run (for example, 500 ns).

# Perform Simulation Using the Active-HDL Software (Batch Mode)

Perform simulation of Verilog HDL or VHDL designs with Active-HDL software at various levels to verify designs from different aspects. It is divided primarily into three categories: RTL functional simulation, post-synthesis simulation, and gate-level simulation. Simulation helps you verify your design and debug it against any possible errors in the design.

There are two modes in which the Active-HDL software can operate in the batch mode:

- Shell mode
- Command-line mode

In shell mode, all commands are executed in the Active-HDL shell that is started by **vsimsa.bat**. Commands can be grouped into macro files (**\*.do**) that are executed within the tool shell.

In command-line mode, standalone commands like `vlib`, `vcom`, and `vsim`, are executed in the system shell (for example, `cygwin`). These standalone commands can be grouped into script files (`tcl`, `perl`, `windows batch`) that are run from the system shell.

Before you start running Active-HDL in a standalone command, make sure that the *Active-HDL/bin* directory is located on PATH environment variables.

 If you are running the command from the Active-HDL GUI console, workspace creation is the first and mandatory step. The following are the commands to create the workspace and open the workspace.

```
createdesign <workspace name> <your design path>
opendesign -a <workspace name>.adf
```

## Simulating the VHDL Designs

The following sections show how to perform RTL functional, post-synthesis, and gate-level timing simulations in command-line mode or shell mode of the Active-HDL software.

### Perform RTL Functional Simulation

RTL functional simulation is typically performed to verify the syntax of the code and to check the functionality of the design. The following sections show how to perform RTL functional simulation in the Active-HDL software for VHDL designs.

 If your Active-HDL software comes with precompiled simulation libraries, creating or compiling simulation libraries is not required and you can skip the following Create and Compile Simulation Libraries section.

### Create Simulation Libraries

Simulation libraries are required to simulate a design that contains an Altera primitive, LPM function, or Altera megafunction. Depending on your design, you must create the required simulation libraries and link them to your design correctly.

Execute the following command to create simulation libraries:

```
vlib <library_name>
```



The library name for Altera megafunctions should be **altera\_mf** and the library name for LPM should be **lpm**. To see all the functional simulation library files, refer to [“RTL Functional Simulation Library Files” on page 5–5](#).

For example, to create simulation libraries for **altera\_mf**, **lpm**, and **altera**:

```
vlib altera_mf
vlib lpm
vlib altera
```

### Compile Simulation Models into Simulation Libraries

Perform the following command to compile simulation models into simulation libraries:

```
vcom -work <simulation_library> <Quartus II installation directory> /eda/sim_lib/<simulation_library_files>
```

For example, compile the **altera\_mf\_components.vhd** and **altera\_mf.vhd** model files into the **altera\_mf** library, and the **220pack.vhd** and **220model.vhd** model files into the LPM library.

Use Example 5–1 to compile the simulation model files to the simulation libraries for **altera\_mf**, **lpm**, and **altera**:

---

#### Example 5–1.

```
vcom -work altera_mf \
<Quartus II installation directory>/eda/sim_lib/altera_mf_components.v \
<Quartus II installation directory>/eda/sim_lib/altera_mf.vhd

vcom -work lpm \
<Quartus II installation directory>/eda/sim_lib/220model.vhd \
<Quartus II installation directory>/eda/sim_lib/220model.vhd

vcom -work altera \
<Quartus II installation directory>/eda/sim_lib/altera_primitives_components.vhd \
<Quartus II installation directory>/eda/sim_lib/altera_primitives.vhd
```

---

### Compile the Testbench and Design Files into the Work Library

The following commands show how to compile your testbench and design files to the work library in the Active-HDL software’s batch mode.

Perform the following command to create the work library:

```
vlib work
```

Perform the following command to compile the testbench and design files into work library:

```
vcom -work work <my_testbench>.vhd <my_design_files>.vhd
```

 Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> work.<my_testbench>
```

 The *<library1>* and *<library2>* are the required libraries to load the design. If you have multiple libraries, use the *-L* option multiple times in the *vsim* command.

### Running the Simulation

Perform the following commands to trace the signals and run the simulation:

```
trace <hierarchical signal name>
run <time period>
```

For example, the following commands trace the DUT/clk1 and DUT/U1/DATA signal and run the simulation for 100 ps.

```
trace DUT/clk1
trace DUT/U1/DATA
...
run 100 ps
```

When the simulation is finished, use the following command to end the simulation:

```
endsim
```

To view the simulation result in the GUI waveform, perform the following command to open the **wave.asdb**:

```
open -asdb {<your_design_path> \work\src\wave.asdb}
```

### Perform Post-Synthesis Simulation

Perform post-synthesis simulation to verify that functionality of the design is not lost after synthesis. You can create the post-synthesis netlist in the Quartus II software and use the netlist to perform Post-Synthesis simulation with the Active-HDL software.

Before you run post-synthesis simulation, generate post-synthesis simulation netlist files. Refer to the instructions in [“Generate Post-Synthesis Simulation Netlist Files” on page 5–8](#).

The following sections help you perform a post-synthesis simulation for a VHDL design in the Active-HDL software.



If your Active-HDL software comes with precompiled simulation libraries, creating or compiling simulation libraries is not required and you can skip the following Create Simulation Libraries and Compile Simulation Libraries section.

#### Create Simulation Libraries

Simulation libraries are required to simulate a design that is mapped to post-synthesis primitives. Depending on the device family that you are using, you must create the required simulation libraries and link them to your design correctly.

Execute the following commands to create simulation libraries:

```
vlib <library_name>
```

For example, the library name for the Stratix III family should be **Stratixiii**. To see all the gate-level timing simulation library files, refer to [“Gate-Level Timing Simulation Library Files” on page 5–6](#).

For example, to create simulation libraries for **stratixiii**, execute:

```
vlib stratixiii
```

#### Compile Simulation Models into Simulation Libraries

Perform the following commands to compile simulation models into simulation libraries:

```
vcom -work <simulation_library> \  
<Quartus II installation directory> /eda/sim_lib/<simulation_library_files>
```

For example, compile the **stratixiii\_atoms\_components.vhd** and **stratixiii\_atoms.vhd** model files into the **stratixiii** library.

Example 5-2 compiles simulation model files to the simulation libraries for **stratixiii**.

---

**Example 5-2.**

```
vcom -work stratixiii \
<Quartus II installation directory>/eda/sim_lib/stratixiii_atoms_components.vhd \
<Quartus II installation directory>/eda/sim_lib/stratixiii_atoms.vhd
```

---

**Compile the Testbench and VHDL Output File into the Work Library**

The following instructions show how you can compile your testbench \*.vho files into the work library using the Active-HDL GUI.

Perform the following command to create the work library:

```
vlib work
```

Perform the following command to compile the testbench and \*.vho files into the work library:

```
vcom -work work <my_testbench>.vhd <my_vhdl_netlists>.vho
```



Resolve compile-time errors before proceeding to the following section.

**Loading the Design**

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> work.<my_testbench>
```



The <library1> and <library2> are the libraries that you compiled previously (for example, **stratixiii** and **stratixiigx**), which are required to load your design. The gate-level libraries are usually required to perform post-synthesis simulation. If you have multiple libraries, use the -L option multiple times in the vsim command.

## Running the Simulation

Perform the following commands to trace the signals and run a simulation:

```
trace <hierarchical signal name>
run <time period>
```

For example, the following commands trace the DUT/clk1 and DUT/U1/DATA signal, and run the simulation for 100 ps.

```
trace DUT/clk1
trace DUT/U1/DATA
...
run 100 ps
```

When the simulation is finished, use the following command to end the simulation:

```
endsim
```

To view the simulation result in the GUI waveform, perform the following command to open the **wave.asdb**:

```
open -asdb {<your_design_path>} \work\src\wave.asdb
```

## Perform Gate-Level Timing Simulation

Gate-level simulation is a very important step in ensuring that the FPGA device's functionality is still correct and meets all required timing requirements after the design was placed and routed. You can create the gate-level netlist in the Quartus II software and use the netlist to perform gate-level timing simulation with the Active-HDL software.

Before you run gate-level timing simulation, generate gate-level timing simulation netlist files. Refer to the instructions in “[Generate Gate-Level Timing Simulation Netlist Files](#)” on page 5-10.

The following sections help you perform a gate-level timing simulation for a VHDL design in the Active-HDL software.



If your Active-HDL software comes with precompiled simulation libraries, creating or compiling simulation libraries is not required, and you can skip the following Create and Compile Simulation Libraries section.

### Create Simulation Libraries

Simulation libraries are required to simulate a design that is mapped to post-fitting primitives. Depending on the device family that you are using, you must create the required simulation libraries and link them to your design correctly.

Execute the following commands to create simulation libraries:

```
vlib <library_name>
```

For example, the library name for the Stratix III family should be **stratixiii**. To see all the gate-level timing simulation library files, refer to “[Gate-Level Timing Simulation Library Files](#)” on page 5–6.

As an example, to create simulation libraries for **stratixiii**, execute:

```
vlib stratixiii
```

### Compile Simulation Models into Simulation Libraries

Perform the following command to compile simulation models into simulation libraries:

```
vcom -work <simulation_library> \  
<Quartus II installation directory>/eda/sim_lib/<simulation_library_files>
```

For example, compile the **stratixiii\_atoms\_components.vhd** and **stratixiii\_atoms.vhd** model files into the **stratixiii** library.

Example 5–3 compiles the simulation model files to the simulation libraries for **stratixiii**.

---

#### **Example 5–3.**

```
vcom -work stratixiii \  
<Quartus II installation directory>/eda/sim_lib/stratixiii_atoms_components.vhd \  
<Quartus II installation directory>/eda/sim_lib/stratixiii_atoms.vhd
```

---

**Compile the Testbench and VHDL Output File into the Work Library**

The following instructions show how you can compile your testbench and **\*.vho** files into the work library using the Active-HDL software.

Perform the following command to create the work library:

```
vlib work
```

Perform the following command to compile the testbench and **\*.vho** files into the work library:

```
vcom -work work <my_testbench>.vhd <my_vhdl_netlists>.vho
```



Resolve compile-time errors before proceeding to the following section.

**Loading the Design**

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> \
-sdftyp <instance path to design>= <path to SDO file> work.<my_testbench> ↵
```



The **<library1>** and **<library2>** are the libraries that you compiled previously (for example, **stratixiii** and **stratixiigx**), which are required to load your design. The gate-level libraries are usually required to perform post-synthesis simulation. If you have multiple libraries, use the **-L** option multiple times in the **vsim** command.



You do not need to set the value (Minimum, Average, Maximum) for the **\*.sdo** file because the Quartus II EDA Netlist Writer generates the **\*.sdo** file using the same value for the triplet (Minimum, Average, and Maximum timing values).



If your design under test is instantiated in the testbench file under the **i1** label, then the **<design instance>** should be **"i1/"** (for example, **/i1=<my design>.sdo**).

**Running the Simulation**

Perform the following commands to trace the signals and run a simulation:

```
trace <hierarchical signal name>
run <time period>
```

For example, the following commands trace the DUT/clk1 and DUT/U1/DATA signal, and run the simulation for 100 ps.

```
trace DUT/clk1
trace DUT/U1/DATA
...
run 100 ps
```

When the simulation is finished, use the following command to end the simulation:

```
endsim
```

To view the simulation result in the GUI waveform, perform the following command to open the **wave.asdb**:

```
open -asdb {<your_design_path> \work\src\wave.asdb}
```

## Simulating the Verilog HDL Designs

The following sections show how to perform RTL functional post-synthesis and gate-level timing simulations in the command-line mode of the Active-HDL software.

### *Perform RTL Functional Simulation*

RTL functional simulation is typically performed to verify the syntax of the code and to check the functionality of the design. The following sections show how to perform RTL functional simulation in the Active-HDL software for Verilog HDL designs.



If your Active-HDL software comes with precompiled simulation libraries, creating or compiling simulation libraries is not required, and you can skip the following Create and Compile Simulation Libraries section.

### Create Simulation Libraries

Simulation libraries are required to simulate a design that contains an Altera primitive, LPM function, or Altera megafunction. Depending on your design, you must create the required simulation libraries and link them to your design correctly.

Execute the following command to create simulation libraries:

```
vlib <library_name>
```

The library name for Altera megafunctions should be **altera\_mf\_ver** and the library name for LPM should be **lpm\_ver**. To see all the functional simulation library files, refer to [“RTL Functional Simulation Library Files” on page 5–5](#).

To create simulation libraries for **altera\_mf**, **lpm**, and **altera**:

```
vlib altera_mf_ver
vlib lpm_ver
vlib altera_ver
```

### Compile Simulation Models into Simulation Libraries

Perform the following commands to compile simulation models into simulation libraries:

```
vlog -work <simulation_library> \
<Quartus II installation directory> /eda/sim_lib/<simulation_library_files>
```

For example, compile the **altera\_mf.v** model files into the **altera\_mf\_ver** library, and the **220model.v** model files into the **lpm\_ver** library.

Use Example 5–4 to compile the simulation model files to the simulation libraries for **altera\_mf\_ver**, **lpm\_ver**, and **altera\_ver**:

---

#### Example 5–4.

```
vlog -work altera_mf_ver <Quartus II installation directory>/eda/sim_lib/altera_mf.v

vlog -work lpm_ver <Quartus II installation directory>/eda/sim_lib/220model.v

vlog -work altera_ver \
<Quartus II installation directory> /eda/sim_lib/altera_primitives.v
```

---

### Compile the Testbench and Design Files into the Work Library

The following commands show how to compile your testbench and design files to the work library in the Active-HDL command-line.

Perform the following command to create the work library:

```
vlib work
```

Perform the following command to compile the testbench and design files into work library:

```
vlog -work work <my_testbench>.v <my_design_files>.v
```



Resolve compile-time errors before proceeding to the following section.

### Loading the Design

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> work .<my_testbench>.v
```



The *<library1>* and *<library2>* are the required libraries to load your design. If you have multiple libraries, use the *-L* option multiple times in the *vsim* command.

### Running the Simulation

Perform the following commands to trace the signals and run a simulation:

```
trace <hierarchical signal name>
run <time period>
```

For example, the following commands trace the DUT/clk1 and DUT/U1/DATA signal, and run the simulation for 100 ps.

```
trace DUT/clk1
trace DUT/U1/DATA
....
run 100 ps
```

When the simulation is finished, use the following command to end the simulation:

```
endsim
```

To view the simulation result in the GUI waveform, perform the following command to open the **wave.asdb**:

```
open -asdb {<your_design_path>}\work\src\wave.asdb}
```

### Perform Post-Synthesis Simulation

Perform post-synthesis simulation to verify that functionality of the design is not lost after synthesis. You can create the post-synthesis netlist in the Quartus II software and use the netlist to perform Post-Synthesis simulation with the Active-HDL software.

Before you run post-synthesis simulation, generate the post-synthesis simulation netlist files. Refer to “[Generate Post-Synthesis Simulation Netlist Files](#)” on page 5–8.

The following sections help you perform a post-synthesis simulation for a Verilog HDL design in the Active-HDL software.



If your Active-HDL software comes with precompiled simulation libraries, creating or compiling simulation libraries is not required, and you can skip the following Create Simulation Libraries and Compile Simulation Libraries section.

### Create Simulation Libraries

Simulation libraries are required to simulate a design that is mapped to post-synthesis primitives. Depending on the device family that you are using, you must create the required simulation libraries and link them to your design correctly.

Execute the following commands to create simulation libraries:

```
vlib <library_name>
```

For example, the library name for the Strati III family should be **stratixiii\_ver**. To see all the gate-level timing simulation library files, refer to “[Gate-Level Timing Simulation Library Files](#)” on page 5–6.

As an example, to create simulation libraries for **stratixiii\_ver**, execute:

```
vlib stratixiii_ver
```

### Compile Simulation Models into Simulation Libraries

Perform the following commands to compile simulation models into simulation libraries:

```
vlog -work <library_name> \
  <Quartus II installation directory> /eda/sim_lib/<simulation_library_files>
```



Compile the **stratixiii\_atoms.v** model files into the **stratixiii\_ver** library.

Example 5–5 compiles the simulation model files to the simulation libraries for **stratixiii**.

---

#### Example 5–5.

```
vlog -work stratixiii_ver \
  <Quartus II installation directory>/eda/sim_lib/stratixiii_atoms.v
```

---

**Compile the Testbench and Verilog Output File into the Work Library**

The following instructions show how you can compile your testbench and \*.vo files into the work library using the Active-HDL command-line.

Perform the following command to create the work library:

```
vlib work
```

Perform the following command to compile the testbench and \*.vo files into the work library:

```
vlog -work work <my_testbench>.v <design_netlists>.vo
```

 Resolve compile-time errors before proceeding to the following section.

**Loading the Design**

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> work.<my_testbench>.v
```

 The <library1> and <library2> take the libraries that you compiled previously (for example, **stratixiii\_ver** and **stratixiigx\_ver**), which are required to load the design. The gate-level libraries are usually required to perform post-synthesis simulation. If you have multiple libraries, use the -L option multiple times in the **vsim** command.

**Running the Simulation**

Perform the following commands to trace the signals and run a simulation:

```
trace <hierarchical signal name>
run <time period>
```

For example, the following commands trace the DUT/clk1 and DUT/U1/DATA signal, and run the simulation for 100 ps.

```
trace DUT/clk1
trace DUT/U1/DATA
....
run 100 ps
```

When the simulation is finished, you can use the following command to end the simulation:

```
endsim
```

To view the simulation result in the GUI waveform, perform the following command to open the **wave.asdb**:

```
open -asdb {<your_design_path> \work\src\wave.asdb}
```

### Perform Gate-Level Timing Simulation

Gate-Level timing simulation is a very important step in ensuring that the FPGA device's functionality is still correct and meets all the timing requirements after the design was placed and routed. You can create the gate-level netlist in the Quartus II software and use the netlist to perform gate-level simulation with the Active-HDL software.

Before you run gate-level timing simulation, generate gate-level timing simulation netlist files. Refer to ["Generate Gate-Level Timing Simulation Netlist Files" on page 5-10](#).

The following sections help you perform a gate-level timing simulation for a Verilog HDL design in the Active-HDL software.



If your Active-HDL software comes with precompiled simulation libraries, creating or compiling simulation libraries is not required, and you can skip the following Create Simulation Libraries and Compile Simulation Libraries sections.

#### Create Simulation Libraries

Simulation libraries are required to simulate a design that is mapped to post-fitting primitives. Depending on the device family that you are using, you must create the required simulation libraries and link them to your design correctly.

Execute the following commands to create simulation libraries:

```
vlib <library_name>
```

For example, the library name for the Stratix III family should be **stratixiii\_ver**. To see all the gate-level timing simulation library files, refer to ["Gate-Level Timing Simulation Library Files" on page 5-6](#).

As an example, to create simulation libraries for **stratixiii**, execute:

```
vlib stratixiii_ver
```

#### Compile Simulation Models into Simulation Libraries

Perform the following commands to compile simulation models into simulation libraries:

```
vlog -work <simulation_library> \
  <Quartus II installation directory>/eda/sim_lib/<simulation_library_files>
```

For example, compile the **stratixiii\_atoms.v** model files into the **stratixiii\_ver** library.

The following is an example to compile simulation model files to the simulation libraries for **stratixiii**:

```
vlog -work stratixiii_ver \
  <Quartus II installation directory>/eda/sim_lib/stratixiii_atoms.v
```

#### Compile the Testbench and Verilog Output File into the Work Library

The following instructions show how you can compile your testbench and **\*.vo** files into the work library using the Active-HDL Command line.

Perform the following command to create the work library:

```
vlib work
```

Perform the following command to compile the testbench and **\*.vo** files into the work library:

```
vlog -work work <my_testbench>.v <design_netlist>.vo
```



Resolve compile-time errors before proceeding to the following section.

#### Loading the Design

When simulating in Verilog HDL, the **.sdo** file does not have to be manually specified because the Quartus II software generates the **.vo** file with the **\$sdf\_annotate** task that tells Active-HDL how to load the **.sdo** file. Ensure that the **.sdo** file is located in the same simulation output directory.

To load a design, perform the following command:

```
vsim -t ps -L <library1> -L <library2> work.<my_testbench>.v
```

The **<library1>** and the **<library2>** are the libraries that you compiled previously (for example, **stratixiii\_ver** and **stratixiigx\_ver**) which are required to load the design. The gate-level libraries are usually required for performing gate-level simulation. If you have multiple libraries, use the **-L** option multiple times in the **vsim** command.

### Running the Simulation

Perform the following commands to trace the signals and run a simulation:

```
trace <hierarchical signal name>
run <time period>
```

For example, the following commands trace the DUT/clk1 and DUT/U1/DATA signal, and run the simulation for 100 ps.

```
trace DUT/clk1
trace DUT/U1/DATA
...
run 100 ps
```

When the simulation is finished, use the following command to end the simulation:

```
endsim
```

To view the simulation result in the GUI waveform, perform the following command to open the **wave.asdb**:

```
open -asdb {<your_design_path>} \work\src\wave.asdb
```

## Simulating Designs that Include Transceivers

If your design includes a Stratix GX, Stratix II GX, Stratix IV, or Arria GX transceiver, you must compile additional library files to perform RTL functional or gate-level timing simulations. The following example shows how to perform simulation on designs that include Stratix GX and Stratix II GX transceivers.

Performing simulation with transceivers in Arria GX or Stratix II GX is very similar. The only requirement is to replace the **stratixiigx\_atoms** and **stratixiigx\_hssi\_atoms** model files with the **arriagx\_atoms** and **arriagx\_hssi\_atoms** model files.

### Stratix GX RTL Functional Simulation

To perform a RTL functional simulation of your design that instantiates the altgxb megafunction, which enables the gigabit transceiver block on Stratix GX devices, compile the **stratixgx\_mf** model file into the **altgxb** library.



The **stratixgx\_mf** model file references the **lpm** and **sgate** libraries, so you will need to create these libraries to perform a simulation.

### Performing RTL Functional Simulation for Stratix GX in VHDL

If you are using Active-HDL software that comes with precompiled simulation libraries, compiling the libraries is not necessary. You can simulate the design directly by typing command in Example 5–6.

---

**Example 5–6.**

```
vcom -work <my design>.vhd <my testbench>.vhd  
vsim -L lpm -L altera_mf -L sgate -L altgxb work.<my testbench>
```

---

If you are using Active-HDL software without precompiled simulation libraries, you must compile the necessary libraries before you can simulate the designs. Type the commands in Example 5–7 to compile and simulate the design.

---

**Example 5–7.**

```
vcom -work altera_mf altera_mf_components.vhd altera_mf.vhd  
vcom -work lpm 220pack.vhd 220model.vhd  
vcom -work sgate sgate_pack.vhd sgate.vhd  
vcom -work altgxb stratixgx_mf.vhd stratixgx_mf_components.vhd  
vcom -work <my design>.vhd <my testbench>.vhd  
vcom -work <my design>.vhd <my testbench>.vhd  
vsim -L lpm -L altera_mf -L sgate -L altgxb work.<my testbench>
```

---

### Performing Functional Simulation for Stratix GX in Verilog HDL

If you are using Active-HDL software that comes with precompiled simulation libraries, compiling the libraries is not necessary. You can simulate the design directly by typing the command in Example 5–8.

---

**Example 5–8.**

```
vlog -work <my design>.v <my testbench>.v  
vsim -L lpm_ver -L altera_mf_ver -L sgate_ver -L altgxb_ver \  
work.<my testbench>
```

---

If you are using Active-HDL software without precompiled simulation libraries, you must compile the necessary libraries before you can simulate the designs. Type the commands in Example 5–9 to compile and simulate the design.

---

**Example 5–9.**

```
vlib work

vlib lpm_ver

vlib altera_mf_ver

vlib sgate_ver

vlib altgxb_ver

vlog -work lpm_ver 220model.v

vlog -work altera_mf_ver altera_mf.v

vlog -work sgate_ver sgate.v

vlog -work altgxb_ver stratixgx_mf.v

vlog -work <my design>.v <my testbench>.v

vsim -L lpm_ver -L altera_mf_ver -L sgate_ver -L altgxb_ver \
      work.<my testbench>
```

---

## Stratix GX Gate-Level Timing Simulation

Perform a gate-level timing simulation of your design that includes a Stratix GX transceiver by compiling the **stratixgx\_atoms** and **stratixgx\_hssi\_atoms** model files into the **stratixgx** and **stratixgx\_gxb** libraries, respectively.

### Performing Timing Simulation for Stratix GX in VHDL

If you are using Active-HDL software that comes with precompiled simulation libraries, compiling the libraries is not necessary. You can simulate the design directly by typing the command in Example 5–10.

---

#### Example 5–10.

```
vcom -work <my design>.vho <my testbench>.vhd  
  
vsim -L lpm -L altera_mf -L sgate -L stratixgx -L stratixgx_gxb \  
work.<my testbench> -t ps -sdftyp <design instance>=<path to SDO file>.sdo \  
+transport_int_delays+transport_path_delays
```

---

If you are using Active-HDL software without precompiled simulation libraries, you must compile the necessary libraries before you can simulate the designs. Type the commands in Example 5–11 to compile and simulate the design.

---

#### Example 5–11.

```
vcom -work lpm 220pack.vhd 220model.vhd  
  
vcom -work altera_mf altera_mf_components.vhd altera_mf.vhd  
  
vcom -work sgate sgate_pack.vhd sgate.vhd  
  
vcom -work stratixgx stratixgx_atoms.vhd stratixgx_components.vhd  
  
vcom -work stratixgx_gxb stratixgx_hssi_atoms.vhd \  
stratixgx_hssi_components.vhd  
  
vcom -work <my design>.vho <my testbench>.vhd  
  
vsim -L lpm -L altera_mf -L sgate -L stratixgx -L stratixgx_gxb work. \  
<my testbench> -t ps -sdftyp <design instance>=<path to SDO file>.sdo \  
+transport_int_delays +transport_path_delays
```

---

### Performing Gate-Level Timing Simulation for Stratix GX in Verilog HDL

If you are using Active-HDL software that comes with precompiled simulation libraries, compiling the libraries is not necessary. You can simulate the design directly by typing command in Example 5–12.

---

#### **Example 5–12.**

```
vlog -work <my design>.v <my testbench>.v

vsim -L lpm_ver -L altera_mf_ver -L sgate_ver -L stratixgx_ver \
-L stratixgx_gxb_ver work.<my testbench> -t ps +transport_int_delays \
+transport_path_delays
```

---

If you are using Active-HDL software without precompiled simulation libraries, you must compile the necessary libraries before you can simulate the designs. Type the commands in Example 5–13 to compile and simulate the design.

---

#### **Example 5–13.**

```
vlog -work lpm_ver 220model.v

vlog -work altera_mf_ver altera_mf.v

vlog -work sgate_ver sgate.v

vlog -work stratixgx_ver stratixgx_atoms.v

vlog -work stratixgx_gxb_ver stratixgx_hssi_atoms.v

vlog -work <my design>.vo <my testbench>.v

vsim -L lpm_ver -L altera_mf_ver -L sgate_ver -L stratixgx_ver \
-L stratixgx_gxb_ver work.<my testbench> -t ps +transport_int_delays \
+transport_path_delaysr
```

---

## Stratix II GX RTL Functional Simulation

Stratix II GX RTL functional simulation is similar to Arria GX functional simulation. The following example shows only the RTL functional simulation for designs that include transceivers in Stratix II GX. To simulate transceivers in Arria GX, replace the **stratixiigx\_hssi** model file with the **ariagx\_hssi** model file.

To perform a RTL functional simulation of your design that instantiates the ALT2GXB megafunction, which enables the gigabit transceiver blocks on Stratix II GX devices, you must generate a functional simulation netlist and compile the **stratixiigx\_hssi** model file into the **stratixiigx\_hssi** library.



The **stratixgx\_hssi\_atoms** model file references the **lpm** and **sgate** libraries, so you must create these libraries to perform a simulation.

In order to run the RTL functional simulation, you must generate a functional simulation netlist by turning on **Generate Simulation Model** in the **Simulation Libraries** tab of the ALT2GXB MegaWizard® Plug-In Manager (see [Figure 5-2](#)).

The *<alt2gxb entity name>.vho* or *<alt2gxb module name>.vo* is generated in the current project directory.



The Quartus II-generated ALT2GXB functional simulation library file references **stratixiigx\_hssi** wysiwyg atoms.

Figure 5–2. ALT2GXB MegaWizard



### Performing RTL Functional Simulation for Stratix II GX in VHDL

If you are using Active-HDL software that comes with precompiled simulation libraries, compiling the libraries is not necessary. You can simulate the design directly by typing the command in Example 5–14.

#### Example 5–14.

```
vcom -work work <alt2gxb entity name>.vho
vcom -work <my design>.vhd <my testbench>.vhd
vsim -L lpm -L altera_mf -L sgate -L stratixgx_hssi work.<my testbench>
```

If you are using Active-HDL software without precompiled simulation libraries, you must compile the necessary libraries before you can simulate the designs. Type the commands in Example 5-15 to compile and simulate the design.

---

**Example 5-15.**

```
vcom -work lpm 220pack.vhd 220model.vhd  
  
vcom -work altera_mf altera_mf_components.vhd altera_mf.vhd  
  
vcom -work sgate sgate_pack.vhd sgate.vhd  
  
vcom -work stratixiigx_hssi stratixiigx_hssi_components.vhd \  
stratixiigx_hssi_atoms.vhd  
  
vcom -work work <alt2gxb entity name>.vho  
  
vcom -work <my design>.vhd <my testbench>.vhd  
  
vsim -L lpm -L altera_mf -L sgate -L stratixgx_hssi work.<my testbench>
```

---

***Performing RTL Functional Simulation for Stratix II GX in Verilog HDL***

If you are using Active-HDL software that comes with precompiled simulation libraries, compiling the libraries is not necessary. You can simulate the design directly by typing the command in Example 5-16.

---

**Example 5-16.**

```
vlog -work work <alt2gxb module name>.vo  
  
vlog -work <my design>.v <my testbench>.v  
  
vsim -L lpm_ver -L altera_mf_ver -L sgate_ver -L stratixgx_hssi_ver \  
work.<my testbench>
```

---

If you are using Active-HDL software without precompiled simulation libraries, you must compile the necessary libraries before you can simulate the designs. Type the commands in Example 5-17 to compile and simulate the design.

---

**Example 5-17.**

```
vlog -work lpm_ver 220model.v  
  
vlog -work altera_mf_ver altera_mf.v
```

---

```
vlog -work sgate_ver sgate.v
vlog -work stratixiigx_hssi_ver stratixiigx_hssi_atoms.v
vlog -work work <alt2gxb module name>.vo
vlog -work <my design>.v <my testbench>.v
vsim -L lpm_ver -L altera_mf_ver -L sgate_ver -L stratixgx_hssi \
      work.<my testbench>
```

---

## Stratix II GX Gate-Level Timing Simulation

To perform a gate-level timing simulation of your design that includes a Stratix II GX transceiver, you must compile **stratixiigx\_atoms** and **stratixiigx\_hssi\_atoms** into the **stratixiigx** and **stratixiigx\_hssi** libraries, respectively.

### *Performing Timing Simulation for Stratix II GX in VHDL*

If you are using Active-HDL software that comes with precompiled simulation libraries, compiling the libraries is not necessary. You can simulate the design directly by typing the command in [Example 5-18](#).

---

#### **Example 5-18.**

```
vcom -work <my design>.vho <my testbench>.vhd
vsim -L lpm -L altera_mf -L sgate -L stratixiigx -L stratixiigx_hssi \
      work.<my testbench> -t ps -sdftyp <design instance>=<path to SDO file>.sdo \
      +transport_int_delays +transport_path_delays
```

---

If you are using Active-HDL software without precompiled simulation libraries, you must compile the necessary libraries before you can simulate the designs.

Type the commands in Example 5–19 to compile and simulate the design.

---

**Example 5–19.**

```
vcom -work lpm 220pack.vhd 220model.vhd  
vcom -work altera_mf altera_mf_components.vhd altera_mf.vhd  
vcom -work sgate sgate_pack.vhd sgate.vhd  
vcom -work stratixiigx stratixiigx_atoms.vhd stratixiigx_components.vhd  
vcom -work stratixiigx_hssi stratixiigx_hssi_components.vhd \  
stratixiigx_hssi_atoms.vhd  
vcom -work <my design>.vho <my testbench>.vhd  
vsim -L lpm -L altera_mf -L sgate -L stratixiigx -L stratixiigx_hssi \  
work.<my testbench> -t ps -sdftyp <design instance>=<path to SDO file>.sdo \  
+transport_int_delays +transport_path_delays
```

---

***Performing Timing Simulation for Stratix II GX in Verilog HDL***

If you are using Active-HDL software that comes with precompiled simulation libraries, compiling the libraries is not necessary. You can simulate the design directly by typing the command in Example 5–20.

---

**Example 5–20.**

```
vlog -work <my design>.vo <my testbench>.v  
vsim -L lpm_ver -L altera_mf_ver -L sgate_ver -L stratixiigx_ver -L \  
stratixiigx_hssi_ver work.<my design> -t ps +transport_int_delays \  
+transport_path_delays
```

---

If you are using Active-HDL software without precompiled simulation libraries, you must compile the necessary libraries before you can simulate the designs.

Type the commands in Example 5–21 to compile and simulate the design.

---

**Example 5–21.**

```
vlog -work lpm_ver 220model.v
vlog -work altera_mf_ver altera_mf.v
vlog -work sgate_ver sgate.v
vlog -work stratixiigx_ver stratixiigx_atoms.v
vlog -work stratixiigx_hssi_ver stratixiigx_hssi_atoms.v
vlog -work <my design>.vo <my testbench>.v
vsim -L lpm -L altera_mf_ver -L sgate_ver -L stratixiigx_ver -L \
stratixiigx_hssi_ver work.<my testbench> -t ps +transport_int_delays \
+transport_path_delays
```

---

## Transport Delays

By default, the Active-HDL software filters out all pulses that are shorter than the propagation delay between primitives. Turning on the **transport delay** options in the Active-HDL software prevents the simulation tool from filtering out these pulses. Use the following options to ensure that all signal pulses are seen in the simulation results.

### +transport\_path\_delays

Use this option when the pulses in your simulation may be shorter than the delay within a gate-level primitive.

### +transport\_int\_delays

Use this option when the pulses in your simulation may be shorter than the interconnect delay between gate-level primitives.

The **+transport\_path\_delays** and **+transport\_int\_delays** options are also used by default in the NativeLink feature for gate-level timing simulation.



For more information about either of these options, refer to the Active-HDL online documentation installed with the Active-HDL software.

Example 5-22 shows an Active-HDL software command in command-line syntax to perform a gate-level timing simulation with the device family library.

**Example 5-22.**

```
vsim -t 1ps -L stratixii -sdftyp /i1=filtref_vhd.sdo \
work.filtref_vhd_vec_tst +transport_int_delays +transport_path_delays
```

## Using the NativeLink Feature in Active-HDL Software

The NativeLink feature in the Quartus II software facilitates the seamless transfer of information between the Quartus II software and EDA tools and allows you to run Active-HDL within the Quartus II software.

### Setting Up NativeLink

To run the Active-HDL software automatically from the Quartus II software using the NativeLink feature, you must specify the path to your simulation tool by performing the following steps:

1. On the Tools menu, click **Options**. The **Options** dialog box appears.
2. In the **Category** list, select **EDA Tool Options**.
3. Double-click the entry under **Location of executable**, beside the name of your EDA Tool.
4. Type or browse to the directory containing the executables of your EDA tool.



For Active-HDL, the executable files are stored in the bin directory (for example, C:\Program Files\Aldec\Active-HDL X.X\BIN).

You can also specify the path to the simulator's executables by using the `set_user_option` TCL command:

```
set_user_option -name EDA_TOOL_PATH_ACTIVEHDL <path to executables>
```

### Performing an RTL Simulation Using NativeLink

To run a RTL functional simulation with the Active-HDL software in the Quartus II software, perform the following steps:

1. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.

2. In the **Category** list, select **Simulation**. The **Simulation** page appears (Figure 5-3).

**Figure 5-3. Simulation Page in the Settings Dialog Box**



3. In the **Tool name** list, select **Active-HDL**.
4. If your design is written entirely in Verilog HDL or VHDL, the NativeLink feature automatically chooses the correct language and Altera simulation libraries. If your design is written with mixed languages, the NativeLink feature uses the default language specified in the **Format for output netlist** list. To change the default

language when there is a mixed language design, under **EDA Netlist Writer options**, in the **Format for output netlist** list, select **VHDL** or **Verilog**. Table 5–7 shows the design languages for output netlists and simulation models.

**Table 5–7. NativeLink Design Languages**

| Device File | Format for Output Netlist | Simulation Models Used |
|-------------|---------------------------|------------------------|
| Verilog     | Any                       | Verilog                |
| VHDL        | Any                       | VHDL                   |
| Mixed       | Verilog                   | Verilog                |
| Mixed       | VHDL                      | VHDL                   |

For mixed language simulation, choose the same language that was used to generate your megafunctions to ensure correct parameter passing between the megafunctions and the Altera libraries. For example, if your altsyncram megafunction was generated in VHDL, choose VHDL as the format for the output netlist.

When creating mixed language designs, it is important to be aware of the following:

- Seamless passing of parameters when a VHDL entity is instantiated in Verilog designs is not allowed.
  - The use of Verilog User Defined Primitives (UDPs) to be instantiated in VHDL designs is not allowed.
5. If you have testbench files or macro scripts, enter the information under **NativeLink settings**.
 

 For more information about setting up a testbench with NativeLink, refer to “[Setting Up a Testbench](#)” on page 5–66.
  6. Click **OK**.
  7. On the Processing menu, point to **Start** and click **Start Analysis and Elaboration** to perform an analysis and elaboration. This command collects all your file name information and builds your design hierarchy in preparation for simulation.
  8. On the Tools menu, point to **Run EDA Simulation Tool** and click **EDA RTL Simulation** to automatically run the Active-HDL software, compile all necessary design files, and complete a simulation.

## Performing a Gate-Level Timing Simulation Using NativeLink

To run a gate-level timing simulation with the Active-HDL software in the Quartus II software, perform the following steps:

1. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
2. In the **Category** list, select **Simulation**. The **Simulation** page appears (see [Figure 5–3](#)).
3. In the **Tool name** list, select **Active-HDL**.
4. Under **EDA Netlist Writer options**, in the **Format for output netlist** list, choose **VHDL** or **Verilog**. You can also modify where you want the post-synthesis netlist generated, by editing or browsing to a directory in the **Output directory** box.
5. To run a gate-level timing simulation after each full compilation, turn on **Run Gate Level Simulation automatically after compilation**.
6. If you have testbench files or macro scripts, enter the information under **NativeLink settings**.
7. Click **OK**.
8. On the Processing menu, point to **Start** and click **Start EDA Netlist Writer** to generate a simulation netlist of your design.

 If you have run full compilation after you set the EDA Tool Settings, the Start EDA Netlist Writer is not required.

9. On the Tools menu, point to **Run EDA Simulation Tool** and click **EDA Gate Level Simulation** to automatically run Active-HDL, compile all necessary design files, and complete a simulation.

 If multi-corner Timing Analysis is performed, a dialog box appears to ask you to select the timing corner to run simulation. Select the timing corner and click **Run**.

 The Active-HDL Macro File (**\*.do**) is generated in the `<project_directory>\simulation\activehdl` directory while running NativeLink. You can perform a simulation with the **.do** file directly from Active-HDL when you rerun a simulation without using NativeLink. To perform the simulation directly without NativeLink, type the following command in the Active-HDL console: **do <generated\_do\_file>.do**.

## Setting Up a Testbench

You can use NativeLink to compile your design files and testbench files, and run an EDA simulation tool to automatically perform a simulation.

To set up NativeLink for simulation, perform the following steps:

1. On the Assignments menu, click **Settings**. The **Settings** dialog box appears.
2. In the **Category** list, click the “+” icon to expand **EDA Tool Settings** and select **Simulation**. The **Simulation** page appears.
3. Under **NativeLink settings**, select **None**, **Compile test bench**, or **Script to compile test bench** (see [Table 5–8](#)).

**Table 5–8. NativeLink Settings**

| Settings                    | Description                                                                                                                                                                                                                         |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| None                        | Compile simulation models and design files.                                                                                                                                                                                         |
| Compile testbench           | NativeLink compiles simulation models, design files, testbench files, and starts simulation.                                                                                                                                        |
| Script to compile testbench | NativeLink compiles the simulation models and design files. The script you provide is sourced after design files compile. Use this option when you want to create your own script to compile your testbench and perform simulation. |

4. If you select **Compile test bench**, select your testbench setup from the **Compile testbench** list. You can use different testbench setups to specify different test scenarios. If there are no testbench setups entered, create a testbench setup by performing the following steps:
  - a. Click **Test Benches**. The **Test Benches** dialog box appears.
  - b. Click **New**. The **New Test Bench Settings** dialog box appears.
  - c. In the **Test Bench name** dialog box, type in the testbench setup name that identifies the different testbench setups.
  - d. In the **Test level module** box, type in the top-level testbench entity name. For example, for a Quartus II generated VHDL testbench, type in *<Vector Waveform File name>\_vhdl\_vec\_tst*.
  - e. In the **Instance** box, type in the full instance path to the top level of your FPGA design. For example, for a Quartus II generated VHDL testbench, type in *i1*.

- f. Under **Simulation period**, select **Run simulation until all vector stimuli are used** or specify the end time of the simulation.
- g. Under **Test bench files**, browse and add all your testbench files in the **File name** box. Use the **Up** and **Down** button to reorder your files. The script used by NativeLink compiles the files in order from top to bottom.



You can also specify the library name and the HDL version to compile the testbench file. Native link compiles the testbench to a library name using the specified HDL version.

- h. Click **OK**.
- i. In the **Test Benches** dialog box, click **OK**.

## Creating a Testbench

In the Quartus II software, you can create a Verilog HDL or VHDL testbench from a Vector Waveform File. The generated testbench includes the behavior of the input stimulus and applies it to your instantiated top-level FPGA design.

To create a testbench, perform the following steps:

1. On the File menu, click **Open**. The **Open** dialog box appears.
2. Click the **Files of type** arrow and select **Waveform/Vector Files**. Select your Vector Waveform File.
3. Click **Open**.
4. On the File menu, click **Export**. The **Export** dialog box appears.
5. Click the **Save as type** arrow and select **VHDL Test Bench File (\*.vht)** or **Verilog Test Bench File (\*.vt)**.
6. You can turn on **Add self-checking code to file** to check your simulation results against your Vector Waveform File.
7. Click **Export**. Your VHDL or Verilog testbench file is generated in your project directory.

## Generating VCD Files for PowerPlay

To generate a VCD file for PowerPlay, you must first generate a VCD script in the Quartus II software and run the VCD script from the Active-HDL software to generate a VCD file. This VCD file can then be used by PowerPlay for power estimation. The following step-by-step instructions show you how to generate a VCD file.

Perform the following steps to generate VCD Scripts in the Quartus II software:

1. In the Quartus II software, on the Assignments menu, click **Settings**.
2. In the **Settings** dialog box, on the **Simulator Settings** page, choose the appropriate 3<sup>rd</sup> party simulation tool (that is, Active-HDL) selection in the **Tool Name** list, and turn on the **Generate Value Change Dump File Script** option.
3. To generate the VCD Script file, perform a full compilation.

Perform the following steps to generate VCD file in the Active-HDL software:

1. In the Active-HDL software, before simulating your design, source the `<revision_name>_dump_all_vcd_nodes.tcl` script. To source the TCL script, run the following command before running the **vsim** command. For example:

```
source <revision_name>_dump_all_vcd_nodes.tcl
```

2. Continue to run the simulation until the end of the simulation. Exit the Active-HDL software. If you do not exit the software, the Active-HDL software may end the writing process of the VCD files improperly, resulting in a corrupted VCD file.



For more details about using the VCD file for power estimation, refer to the *PowerPlay Power Analysis* chapter in volume 3 of the *Quartus II Handbook*.

## Scripting Support



You can run procedures and create settings described in this chapter in a Tcl script. You can also run some procedures at the command-line prompt.

For more information about Tcl scripting, refer to the *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*.

For more information about command-line scripting, refer to the *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*.

For detailed information about scripting command options, refer to the **Qhelp** command line and Tcl API help browser.

Type this command to start the Qhelp help browser:

```
quartus_sh -qhelp ↵
```

## Generating a Post-Synthesis Simulation Netlist for Active-HDL

You can use the Quartus II software to generate a post-synthesis simulation netlist with Tcl commands or with a command at the command-line prompt. The following examples assume that you are selecting Active-HDL (Verilog HDL output from the Quartus II software).

### *Tcl Commands*

Use the following Tcl commands to set the output format to Verilog HDL, the simulation tool to Active-HDL for Verilog HDL, and to generate a functional netlist:

```
set_global_assignment -name EDA_SIMULATION_TOOL "Active-HDL (Verilog)"  
set_global_assignment -name EDA_GENERATE_FUNCTIONAL_NETLIST ON
```

### *Command Prompt*

Use the following command to generate a simulation output file for the Active-HDL software. Specify VHDL or Verilog HDL for the format:

```
quartus_eda <project name> --simulation=on --format=<format> \  
--tool=activehdl --functional ↵
```

## Generating a Gate-Level Timing Simulation Netlist for Active-HDL

You can use the Quartus II software to generate a gate-level timing simulation netlist with Tcl commands or with a command at the command prompt.

### *Tcl Commands*

Use one of the following Tcl commands:

```
set_global_assignment -name EDA_SIMULATION_TOOL "Active-HDL (Verilog)"  
set_global_assignment -name EDA_SIMULATION_TOOL "Active-HDL (VHDL)"
```

### *Command Line*

Generate a simulation output file for the Active-HDL software by specifying VHDL or Verilog HDL for the format by typing the following command at the command prompt:

```
quartus_eda <project name> --simulation=on --format=<format> --tool=activehdl ↵
```

## Conclusion

Using the Active-HDL simulation software within the Altera FPGA design flow allows you to easily and accurately perform RTL functional simulations, post-synthesis simulations, and gate-level timing simulations on your designs. Proper verification of designs at the functional, post-synthesis, and post place-and-route stages using the Active-HDL software helps ensure design functionality success and, ultimately, a quick time-to-market.

## Referenced Documents

This chapter references the following documents:

- *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*
- *PowerPlay Power Analysis* chapter in volume 3 of the *Quartus II Handbook*
- *Quartus II Classic Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*
- *Quartus II Installation and Licensing for UNIX and Linux Workstations* manual
- *Quartus II Installation and Licensing for Windows* manual
- *Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*
- *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*

## Document Revision History

**Table 5–9. Document Revision History**

| Date / Revision     | Changes Made     | Summary of Changes |
|---------------------|------------------|--------------------|
| May 2008<br>v.8.0.0 | Initial Release. | —                  |



## Introduction

The capacity and complexity of Altera® FPGAs continues to increase as the need for intellectual property (IP) becomes increasingly critical. Using IP megafunctions reduces the design and verification time, allowing you to focus on design customization. Altera and the Altera Megafunction Partners Program (AMPP<sup>SM</sup>) offer a broad portfolio of IP megafunctions optimized for Altera FPGAs. Through parameterization, these reusable blocks of IP can be customized to meet your design requirements.

Even when the IP source code is encrypted or otherwise restricted, Altera's Quartus® II software allows you to easily simulate designs that contain Altera IP. With the Quartus II software, you can custom configure IP designs, then generate a VHDL or Verilog HDL functional simulation model to use with your choice of simulation tools.

This chapter provides an overview of the process for instantiating the IP megafunctions in your design and simulating its functional simulation model in an Altera-supported, third-party simulation tool. In this chapter, IP megafunctions refer to Altera megafunctions, IP MegaCore® functions, and IP AMPP megafunctions.

All IP MegaCore functions come with IP functional simulation (IPFS) models to support functional simulation. Some Altera megafunctions and some AMPP megafunctions also require IPFS models for functional simulation.



An IPFS model is a cycle-accurate VHDL or Verilog HDL model produced by the Quartus II software. The model allows for fast functional simulation of IP using industry-standard VHDL and Verilog HDL simulators.



Use these models only for simulation. Do not use them for synthesis or any other purpose. Using these models for synthesis creates a nonfunctional design.

This chapter discusses the following topics:

- “IP Functional Simulation Flow” on page 6–2
- “Instantiate the IP in Your Design” on page 6–4
- “Perform Simulation” on page 6–4
- “Design Language Examples” on page 6–13

## IP Functional Simulation Flow

The IP megafunction's MegaWizard® interface allows you to quickly and easily view documentation, specify parameters, generate an IP functional simulation (IPFS) model, and output the files necessary to integrate a parameterized IP megafunction into your design. Within the Quartus II software, the MegaWizard Plug-In Manager can be used to select and parameterize your choice of IP megafunctions. The Quartus II software generates an IP megafunction's variation file that is included in your Quartus II project. For IP megafunctions that require IPFS models, Quartus II software can also generate a Verilog Output File (.vo) or VHDL Output File (.vho) that contains a Register Transfer Level (RTL) IPFS model after you have parameterized the megafunction. IPFS models are written to the Quartus II project directory.

Most Altera megafunctions and IP MegaCore functions support functional simulation in Verilog and VHDL for all Altera supported third-party simulators. Simulation libraries are required to simulate IP megafunctions. Refer to [Table 6–2 on page 6–11](#) for a subset of simulation libraries supplied with the Quartus II software.

[Figure 6–1](#) shows a typical simulation flow for Altera IP with third-party simulators.

**Figure 6–1. IP Functional Simulation (IPFS) Model Design Flow**

## Verilog HDL and VHDL IP Functional Simulation (IPFS) Models

Some IP megafunctions require IPFS models to support functional simulation. These IPFS models are generated in Register Transfer Level (RTL) HDL. These RTL models in Verilog HDL or VHDL format differ from the low-level synthesized netlist in Verilog HDL or VHDL format generated by the Quartus II software for post-synthesis or post place-and-route simulations. The IPFS models generated by the Quartus II software are much faster than the low-level post-synthesis or post place-and-route netlists of your design because they are mapped to higher-level primitives such as adders, multipliers, and multiplexers. These IPFS models can be simulated together with the rest of your design in any Altera-supported simulator. Altera recommends that you generate IPFS models in the same hardware language as the IP megafunction's variation file hardware language.



You can use an IPFS model for simulation only. Do not use it for synthesis or any other purpose. Attempting to synthesize an IPFS model will result in a nonfunctional design.



Generating an IPFS model for Altera MegaCore functions does not require a license. However, generating an IPFS model for AMPP megafunctions may require a license. For more information on licensing requirements, contact the IP megafunction vendor.

For details about how to parameterize and generate an IP, refer to the applicable IP user guide.

## Instantiate the IP in Your Design

For each IP megafunction in your design, you must instantiate the corresponding entity or module in your design. Each IP megafunction entity or module name is defined in its Quartus II generated megafunction variation file. After instantiating the IP megafunction in your design, you do not need to edit your design for synthesis or simulation.

To synthesize your design using the Quartus II software, add the Quartus II-generated Verilog HDL or VHDL variation file to your Quartus II project. When you create new variation files for a Quartus II project, they are added to the current open project when the megafunction is generated.

To synthesize your design using a third-party EDA tool, add the Quartus II-generated CMP file (*<megafunction variation>.cmp*) for your VHDL design or the Verilog HDL black box file (*<megafunction variation>\_bb.v*) for your Verilog HDL design to your third-party synthesis project.



For more information about synthesis and compilation with the Quartus II software, refer to the applicable chapters in volume 1 of the *Quartus II Handbook*.

## Perform Simulation

To perform simulation, in addition to adding your design files and testbench files, you also have to add the IP megafunction's variation file or IPFS model to your simulation project. If the IP megafunction does not require an IPFS model for simulation, add the megafunction's variation file to your simulation project. If the IP megafunction you are simulating requires an IPFS model, then add the IPFS model to your simulation project. Your simulation project will also require Altera-supplied libraries for successful simulation. [Figure 6-2](#) shows how the Altera libraries are used in IP functional simulation.

**Figure 6–2. IP Functional Simulation Library Usage****Notes to Figure 6–2:**

- (1) The IP that uses the transceiver requires the Altera transceiver libraries for simulation. Refer to [Table 6–2](#) for all the Altera transceiver libraries.
- (2) An IP that uses the PCI Express (PCIe) hard core in a Stratix IV device requires the PCIe libraries. Refer to [Table 6–2](#) for all the PCIe transceiver libraries.

The Quartus II software contains all the libraries required for setting up and running a successful simulation of Altera IP. You can use the Quartus II NativeLink feature to set up your simulation if the IP megafunction you are using supports Quartus II NativeLink. Refer to the applicable IP megafunction user guide to determine if the IP megafunction supports the NativeLink feature in the Quartus II software. Alternatively, you can simulate Altera IP with third-party simulators directly.

## Simulating Altera IP Using the Quartus II NativeLink Feature

The Quartus II NativeLink feature eases the task of setting up and running a simulation. The NativeLink feature lets you launch the third-party simulator to perform simulation from within the Quartus II software. The NativeLink feature automates the compilation and simulation of testbenches.

The following list briefly describes the steps to simulate IP megafunctions with third-party simulators using the Quartus II NativeLink feature. Each of these steps is described in more detail in the sections that follow.

1. Select the Third-Party Simulation Tool.
2. Specify the Path for the Third-Party Simulator.
3. Specify the Testbench Settings.
4. Analyze and Elaborate the Quartus II Project.
5. Run RTL Functional Simulation.

#### *Set up a Quartus II Project*

To simulate IP megafunctions with the Quartus II NativeLink feature, you must open an existing project or create a new project in the Quartus II software. You can create and parameterize the IP you want to use in your design using the MegaWizard Plug-In Manager within the Quartus II software. Altera IP megafunction variation files are added to your Quartus II project when you create and parameterize the IP. You can also add any other required design files to your Quartus II project. If you are using the Quartus II NativeLink feature and your Quartus II project contains IP megafunctions that require IPFS models for simulation, you do not have to manually add the IPFS models to the Quartus II project for these IP megafunctions. When the Quartus II NativeLink feature launches the third-party simulator tool and starts the simulation, it automatically adds the IPFS model files required for simulation as long as they are present in the Quartus II project directory.

#### *Select the Third-Party Simulation Tool*

You can select the third-party simulation tool from the Project Settings menu, as shown in [Figure 6-3](#).

Figure 6-3. Selecting Third-Party Simulator Tools



Table 6-1 lists the third-party simulators supported by the Quartus II NativeLink feature.

| Third-Party Simulator   | Can be Launched from Quartus II Software (1) | Testbench Support | Mixed Design (Verilog HDL and VHDL) |
|-------------------------|----------------------------------------------|-------------------|-------------------------------------|
| ModelSim PE/SE          | Yes                                          | Yes               | Yes                                 |
| ModelSim Altera Edition | Yes                                          | Yes               | No                                  |
| Synopsys VCS            | Yes                                          | Yes               | No                                  |
| Synopsys VCS-MX         | Yes                                          | Yes               | Yes                                 |
| Cadence NC-Sim          | Yes                                          | Yes               | Yes                                 |
| Aldec Active-HDL        | Yes                                          | Yes               | Yes                                 |

**Note to Table 6-1:**

- (1) The Quartus II software must be running on the same platform as the Third-Party Simulator to launch the simulator tool.

### Specify the Path for the Third-Party Simulator

To launch the third-party simulation tool, the absolute path for the selected simulator must be provided in the **Options** page under the Tools menu. See [Figure 6–4](#). Double-click the **Location of executable** field to change or specify the absolute path.

**Figure 6–4. Specifying the Simulator Path**



### Specify the Testbench Settings

Specify the applicable testbench settings as follows:

1. Under the NativeLink Settings in the **Settings** dialog box ([Figure 6–3](#)), select the **Compile Test Bench** radio button and click **Test Benches** to display the **Test Benches** dialog box. See [Figure 6–5](#).

---

**Figure 6–5. Test Bench Dialog Box**

- 
2. Click **New** to display the **New Test Bench Settings** dialog box (Figure 6–6).

---

**Figure 6–6. New Test Bench Settings Dialog Box**

- 
3. In the **New Test Bench Settings** dialog box, set the appropriate fields with the names for the testbenches.



For specific instructions about specifying testbench settings for your MegaCore function, refer to your MegaCore function user guide.

4. After specifying the testbench files, close the **New Test Bench Settings**, **Test Benches**, and **Settings** dialog boxes.

### Analyze and Elaborate the Quartus II Project

Before starting the simulation using the NativeLink feature, make sure that each IP megafunction's variation files are included in your design project. On the Quartus II Processing menu, point to **Start**, then click **Start Analysis & Elaboration**.

### Run RTL Functional Simulation

After the design is analyzed and elaborated, you can start the simulation by clicking **Run EDA-RTL Simulation** from the Tools menu. See [Figure 6–7](#). During RTL functional simulation, the IPFS models are compiled and used by the simulator.

**Figure 6–7. Running Functional Simulation for IP using NativeLink**



## Simulating Altera IP Without the Quartus II NativeLink Feature

You can also simulate Altera IP directly with third-party simulators. If your design instantiates an IP megafunction, add its variation file to your simulation project. If the IP megafunction requires IPFS model files, **do not** add the megafunction's variation file to your simulation project. Rather, add its IPFS model files (either Verilog HDL or VHDL) to your simulation project. The IPFS model generated by the Quartus II software instantiates high-level primitives such as adders, multipliers, and multiplexers, as well as the library of parameterized modules (LPM) functions and Altera megafunctions.

To properly compile, load, and simulate the IP megafunctions, you must first compile the following libraries in your simulation tool:

- **sgate**—includes the definition of the high-level primitives (needed for IPFS models)
- **altera\_mf**—includes the definition of Altera megafunctions
- **altera\_primitives**—includes the definition of Altera primitives
- **220model**—includes the definition of LPM functions
- **Altera transceiver**—includes the definition of all Altera transceiver megafunctions. If you use IP with the transceiver block, you must compile these libraries, which are device dependent.
- **PCIe**—includes the definition of PCIe hard core megafunctions for Stratix IV. If you use IP with the PCIe hard core for Stratix IV, you must compile these libraries.

You can use these library files with any Altera-supported simulation tool. If you are using the ModelSim® Altera software, the libraries are precompiled and mapped.



To simulate a design containing a Nios® processor or Avalon® peripherals, refer to [AN 189: Simulating Nios Embedded Processor Designs](#).

**Table 6–2** lists the simulation library files, where *<path>* is the directory where the Quartus II software is installed.

**Table 6–2. Simulation Library Files (Part 1 of 2)**

| Location                          | HDL Language | Description                                                                            |
|-----------------------------------|--------------|----------------------------------------------------------------------------------------|
| <path>/eda/sim_lib/sgate.v        | Verilog HDL  | Libraries that contain simulation models for IP functional models                      |
| <path>/eda/sim_lib/sgate.vhd      | VHDL         |                                                                                        |
| <path>/eda/sim_lib/sgate_pack.vhd | VHDL         | Libraries that contain VHDL component declarations for the <b>sgate.vhd</b> library    |
| <path>/eda/sim_lib/220model.v     | Verilog HDL  | Libraries that contain simulation models for the Altera LPM version 2.2.0              |
| <path>/eda/sim_lib/220model.vhd   | VHDL         |                                                                                        |
| <path>/eda/sim_lib/220pack.vhd    | VHDL         | Libraries that contain VHDL component declarations for the <b>220model.vhd</b> library |
| <path>/eda/sim_lib/altera_mf.v    | Verilog HDL  | Libraries that contain simulation models for Altera-specific megafunctions             |
| <path>/eda/sim_lib/altera_mf.vhd  | VHDL         |                                                                                        |

**Table 6–2. Simulation Library Files (Part 2 of 2)**

| Location                                             | HDL Language | Description                                                                                     |
|------------------------------------------------------|--------------|-------------------------------------------------------------------------------------------------|
| <path>/eda/sim_lib/altera_primitives.v               | Verilog HDL  | Libraries that contain simulation models for Altera primitives                                  |
| <path>/eda/sim_lib/altera_primitives.vhd             | VHDL         |                                                                                                 |
| <path>/eda/sim_lib/altera_mf_components.vhd          | VHDL         | Libraries that contain VHDL component declarations for the <b>altera_mf.vhd</b> library         |
| <path>/eda/sim_lib/stratixgx_mf.v                    | Verilog HDL  | Libraries that contain simulation models for Stratix® GX transceivers                           |
| <path>/eda/sim_lib/stratixgx_mf.vhd                  | VHDL         |                                                                                                 |
| <path>/eda/sim_lib/stratixgx_mf_components.vhd       | VHDL         | Libraries that contain VHDL component declarations for the <b>stratixgx_mf.vhd</b> library      |
| <path>/eda/sim_lib/stratixiigx_hssi_atoms.v          | Verilog HDL  | Libraries that contain simulation models for Stratix GX transceivers                            |
| <path>/eda/sim_lib/stratixiigx_hssi_atoms.vhd        | VHDL         |                                                                                                 |
| <path>/eda/sim_lib/stratixiigx_hssi_components.vhd   | VHDL         | Libraries that contain VHDL component declarations for the <b>stratixgx_mf.vhd</b> library      |
| <path>/eda/sim_lib/arriagx_hssi_atoms.v              | Verilog HDL  | Libraries that contain simulation models for Arria® GX transceivers                             |
| <path>/eda/sim_lib/arriagx_hssi_atoms.vhd            | VHDL         |                                                                                                 |
| <path>/eda/sim_lib/arriagx_hssi_components.vhd       | VHDL         | Libraries that contain VHDL component declarations for the <b>arriagx_mf.vhd</b> library        |
| <path>/eda/sim_lib/stratixiv_hssi_atoms.v            | Verilog HDL  | Libraries that contain simulation models for Stratix IV transceivers                            |
| <path>/eda/sim_lib/stratixiv_hssi_atoms.vhd          | VHDL         |                                                                                                 |
| <path>/eda/sim_lib/stratixiv_hssi_components.vhd     | VHDL         | Libraries that contain VHDL component declarations for the <b>stratixiv_mf.vhd</b> library      |
| <path>/eda/sim_lib/stratixiv_pcie_hip_atoms.v        | Verilog HDL  | Libraries that contain simulation models for Stratix IV PCI Express                             |
| <path>/eda/sim_lib/stratixiv_pcie_hip_atoms.vhd      | VHDL         |                                                                                                 |
| <path>/eda/sim_lib/stratixiv_pcie_hip_components.vhd | VHDL         | Libraries that contain VHDL component declarations for the <b>stratix_iv_pcie_hip_atoms.vhd</b> |

## Design Language Examples

The following design language examples explain how to simulate IP megafunctions directly with third-party simulator tools. These design examples describe simulation with:

- ModelSim Verilog
- ModelSim VHDL
- NC-VHDL
- VCS

### Verilog HDL Example: Simulating the IPFS Model in the ModelSim Software

The following example shows the process of simulating a Verilog HDL-based megafunction. The example assumes that the megafunction variation and the IPFS model are generated.

1. Create a ModelSim project by performing the following steps:
  - a. In the ModelSim software, on the File menu, point to New and click **Project**. The **Create Project** dialog box is shown.
  - b. Specify the name of your simulation project.
  - c. Specify the desired location for your simulation project.
  - d. Specify the default library name and click **OK**.
  - e. Add relevant files to your simulation project:
    - Your design files
    - The IPFS model generated by the Quartus II software (if you are using the ModelSim-Altera software, skip to step 5)
    - The **sgate.v**, **220model.v**, and **altera\_mf.v** library files
    - The transceiver library files in Verilog HDL, if you use IP with transceivers. Transceiver libraries are family independent. Refer to [Table 6-2](#) for more information.
    - The PCIe library files in Verilog HDL, if you use IP with the PCIe hard core for Stratix IV devices. Refer to [Table 6-2](#) for more information.

2. Create the required simulation libraries by typing the following commands at the ModelSim prompt:

```
vlib sgate ↵  
vlib lpm ↵  
vlib altera_mf ↵
```

3. Map to the required simulation libraries by typing the following commands at the ModelSim prompt:

```
vmap sgate sgate ↵  
vmap lpm lpm ↵  
vmap altera_mf altera_mf ↵
```

4. Compile the HDL into libraries by typing the following commands at the ModelSim prompt:

```
vlog -work altera_mf altera_mf.v ↵  
vlog -work sgate sgate.v ↵  
vlog -work lpm 220model.v ↵
```

5. Compile the IPFS model by typing the following command at the ModelSim prompt:

```
vlog -work work <my_IP>.vo ↵
```

6. Compile your RTL by typing the following command at the ModelSim prompt:

```
vlog -work work <my_design>.v ↵
```

7. Compile the testbench by typing the following command at the ModelSim prompt:

```
vlog -work work <my_testbench>.v ↵
```

8. Load the testbench by typing the following command at the ModelSim prompt:

```
vsim -L <altera_mf_library_path> -L <lpm_library_path> \  
-L <sgate_library_path> work.<my_testbench> ↵
```

## VHDL Example: Simulating the IPFS Model in the ModelSim Software

The following example shows the process of performing a functional simulation of a VHDL-based, megafunction IPFS model. The example assumes that the megafunction's variation and the IPFS model are generated.

1. Create a ModelSim project by performing the following steps:
  - a. In the ModelSim software, on the File menu, point to New and click **Project**. The **Create Project** dialog box appears.
  - b. Specify the name for your simulation project.
  - c. Specify the desired location for your simulation project.
  - d. Specify the default library name and click **OK**.
  - e. Add the relevant files to your simulation project:
    - Add your design files
    - Add the IPFS model generated by the Quartus II software (if you are using the ModelSim-Altera software, skip to step 5)
    - Add the **sgate.vhd**, **sgate\_pack.vhd**, **220model.vhd**, **220pack.vhd**, **altera\_mf.vhd**, and **altera\_mf\_components.vhd** library files
    - The transceiver library files in VHDL, if you use IP with transceivers. Transceiver libraries are family independent. Refer to [Table 6-2](#) for more information.
    - The PCIe library files in VHDL, if you use IP with the PCIe hard core for Stratix IV. Refer to [Table 6-2](#) for more information.
2. Create the required simulation libraries by typing the following commands at the ModelSim prompt:

```
vlib sgate <br>
vlib lpm <br>
vlib altera_mf <br>
```

3. Map to the required simulation libraries by typing the following commands at the ModelSim prompt:

```
vmap sgate sgate ↵  
vmap lpm lpm ↵  
vmap altera_mf altera_mf ↵
```

4. Compile the HDL into libraries by typing the following commands at the ModelSim prompt:

```
vcom -work altera_mf -93 -explicit \  
altera_mf_components.vhd ↵  
vcom -work altera_mf -93 -explicit altera_mf.vhd ↵  
vcom -work lpm -93 -explicit 220pack.vhd ↵  
vcom -work lpm -93 -explicit 220model.vhd ↵  
vcom -work sgate -93 -explicit sgate_pack.vhd ↵  
vcom -work sgate -93 -explicit sgate.vhd ↵
```

5. Compile the IPFS model by typing the following command at the ModelSim prompt:

```
vcom -work work -93 -explicit <output_netlist>.vho ↵
```

6. Compile the RTL by typing the following command at the ModelSim prompt:

```
vcom -work work -93 -explicit <RTL>.vhd ↵
```

7. Compile the testbench by typing the following command at the ModelSim prompt:

```
vcom -work work -93 -explicit <my_testbench>.vhd ↵
```

8. Load the testbench by typing the following command at the ModelSim prompt:

```
vsim work.my_testbench ↵
```

## NC-VHDL Example: Simulating the IPFS Model in the NC-VHDL Software

The following example shows the process of performing a functional simulation of an NC-VHDL-based, megafunction IP functional-simulation model. The example assumes that the megafunction's variation and the IPFS model are generated.

1. Create a **cds.lib** file by typing the following entries:

```
DEFINE worklib ./worklib  
DEFINE sgate ./sgate  
DEFINE altera_mf ./altera_mf  
DEFINE lpm ./lpm
```

2. Compile library files into appropriate libraries by typing the following commands at the command prompt:

```
ncvhdl -V93 -WORK lpm 220pack.vhd ←  
ncvhdl -V93 -WORK lpm 220model.vhd ←  
ncvhdl -V93 -WORK altera_mf \  
altera_mf_components.vhd ←  
rncvhdl -V93 -WORK altera_mf altera_mf.vhd ←  
ncvhdl -V93 -WORK sgate sgate_pack.vhd ←  
ncvhdl -V93 -WORK sgate sgate.vhd ←
```

3. Compile source code and testbench files by typing the following commands at the command prompt:

```
ncvhdl -V93 -WORK worklib <my_design>.vhd ←  
ncvhdl -V93 -WORK worklib <my_testbench>.vhd ←  
ncvhdl -V93 -WORK worklib \  
<my_IPtoolbench_output_netlist>.vho ←
```

4. Elaborate the design by typing the following command at the command prompt:

```
ncelab worklib.<my_testbench>:entity ↵
```

## Verilog HDL Example: Simulating Your IPFS Model in VCS

The following example illustrates the process of performing a functional simulation of a design that contains a Verilog HDL-based, megafunction IPFS model. This example assumes that the megafunction variation and the IPFS model are generated.

### Single-Step Process

For the single-step process, type the following at the command prompt:

```
vcs <testbench>.v <RTL>.v <output_netlist>.v -v 220model.v \
altera_mf.v sgate.v -R ↵
```

### Two-Step Process (Compilation and Simulation)

For compilation and simulation, perform the following steps:

1. Compile your design files by typing the following at the command prompt:

```
vcs <testbench>.v <RTL>.v <output_netlist>.v -v 220model.v \
altera_mf.v sgate.v -o simulation_out ↵
```

2. Load your simulation by typing the following at a command prompt:

```
source simulation_out ↵
```



For more information about simulating a design in VCS, refer to the chapter *Synopsys VCS Support* in volume 3 of the *Quartus II Handbook*.

## Conclusion

Altera Quartus II software provides full support for simulating IP megafunctions with third party tools either directly or using its NativeLink feature. Using the Quartus II software, you can also generate IPFS models for supported megafunctions that enhances and simplifies design verification. Using an IPFS model is transparent, requiring only the addition of different files in which to synthesize and simulate projects.

## Referenced Documents

This chapter references the following documents:

- *AN 189: Simulating Nios Embedded Processor Designs*
- *Synopsys VCS Support* in volume 3 of the *Quartus II Handbook*
- Volume 1 of the *Quartus II Handbook*

## Document Revision History

Table 6–3 shows the revision history for this chapter.

**Table 6–3. Document Revision History**

| Date and Document Version | Changes Made                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Summary of Changes                                             |
|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
| May 2008<br>v8.0.0        | <ul style="list-style-type: none"> <li>● Updated “Introduction” on page 6–1.</li> <li>● Updated “Simulating Altera IP Without the Quartus II NativeLink Feature” on page 6–10.</li> <li>● Updated “Verilog HDL Example: Simulating the IPFS Model in the ModelSim Software” on page 6–13.</li> <li>● Updated “VHDL Example: Simulating the IPFS Model in the ModelSim Software” on page 6–15.</li> <li>● Updated Figure 6–2.</li> <li>● Updated Table 6–1.</li> <li>● Updated Table 6–2.</li> </ul> | Updated for the Quartus II software, version 8.0.              |
| October 2007<br>v7.2.0    | Reorganized “Referenced Documents” on page 5–16.                                                                                                                                                                                                                                                                                                                                                                                                                                                    | —                                                              |
| May 2007<br>v7.1.0        | <ul style="list-style-type: none"> <li>● Updated Figure 5–6</li> <li>● Added “Referenced Documents” section.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                             | Minor updates to support the Quartus II software, version 7.1. |
| March 2007<br>v7.0.0      | Updated Quartus II software 7.0 revision and date only.                                                                                                                                                                                                                                                                                                                                                                                                                                             | —                                                              |
| November 2006<br>v6.1.0   | <ul style="list-style-type: none"> <li>● Added Quartus II NativeLink feature information</li> <li>● Updated Figure 5–1, 5–2</li> <li>● Added Figure 5–3, 5–4, 5–7</li> <li>● Added Table 5–1</li> </ul>                                                                                                                                                                                                                                                                                             | Chapter updates to support the Quartus II NativeLink feature.  |
| May 2006<br>v6.0.0        | Minor updates for the Quartus II software version 6.0.                                                                                                                                                                                                                                                                                                                                                                                                                                              | —                                                              |
| October 2005<br>v5.1.0    | Updated for the Quartus II software version 5.1.                                                                                                                                                                                                                                                                                                                                                                                                                                                    | —                                                              |
| May 2005<br>v5.0.0        | Chapter 4 was formerly in Section I, Vol 3 in 4.2.                                                                                                                                                                                                                                                                                                                                                                                                                                                  | —                                                              |
| December 2004<br>v1.0.0   | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | —                                                              |



As designs become more complex, the need for advanced timing analysis capability grows. Static timing analysis is a method of analyzing, debugging, and validating the timing performance of a design. The Quartus® II software provides the features necessary to perform advanced timing analysis for today's system-on-a-programmable-chip (SOPC) designs.

Synopsys PrimeTime is an industry standard sign-off tool, used to perform static timing analysis on most ASIC designs. The Quartus II software provides a path to enable you to run PrimeTime on your Quartus II software designs, and export a netlist, timing constraints, and libraries to the PrimeTime environment.

This section explains the basic principles of static timing analysis, the advanced features supported by the Quartus II Timing Analyzer, and how you can run PrimeTime on your Quartus designs.

This section includes the following chapters:

- [Chapter 7, The Quartus II TimeQuest Timing Analyzer](#)
- [Chapter 8, Switching to the Quartus II TimeQuest Timing Analyzer](#)
- [Chapter 9, Quartus II Classic Timing Analyzer](#)
- [Chapter 10, Synopsys PrimeTime Support](#)



For information about the revision history for chapters in this section, refer to each individual chapter for that chapter's revision history.



### 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”
- “Compilation Flow with the Quartus II TimeQuest Timing Analyzer Guidelines” on page 7-3
- “Timing Analysis Overview” on page 7-6
- “The Quartus II TimeQuest Timing Analyzer Flow Guidelines” on page 7-26
- “The Quartus II TimeQuest Timing Analyzer Flow Guidelines” on page 7-26
- “Collections” on page 7-28
- “SDC Constraint Files” on page 7-29
- “Clock Specification” on page 7-32

- “I/O Specifications” on page 7-51
- “Timing Exceptions” on page 7-54
- “Constraint and Exception Removal” on page 7-63
- “Timing Reports” on page 7-64
- “Timing Analysis Features” on page 7-89
- “The TimeQuest Timing Analyzer GUI” on page 7-96
- “Conclusion” on page 7-108



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–26](#).

## 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.

**Table 7-1. Summary of Command Line Options (Part 1 of 2)**

| Command Line Option                                                | Description                                                                                                                         |
|--------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| <code>-h   --help</code>                                           | Provides help information on <code>quartus_staw</code> .                                                                            |
| <code>-t &lt;script file&gt;   --script=&lt;script file&gt;</code> | Sources the <code>&lt;script file&gt;</code> .                                                                                      |
| <code>-s   --shell</code>                                          | Enters shell mode.                                                                                                                  |
| <code>--tcl_eval &lt;tcl command&gt;</code>                        | Evaluates the Tcl command <code>&lt;tcl command&gt;</code> .                                                                        |
| <code>--do_report_timing</code>                                    | Runs the command:<br><code>report_timing -npaths 1 -to_clock \$clock</code> for all clocks in the design.                           |
| <code>--force_dat</code>                                           | Forces the Delay Annotator to annotate the new delays from the recently compiled design to the compiler database.                   |
| <code>--lower_priority</code>                                      | Lowers the computing priority of the <code>quartus_staw</code> process.                                                             |
| <code>--post_map</code>                                            | Uses the post-map database results.                                                                                                 |
| <code>--qsf2sdc</code>                                             | Converts assignments from the Quartus II Settings File ( <code>.qsf</code> ) format to the Synopsys Design Constraints File format. |
| <code>--sdc=&lt;SDC file&gt;</code>                                | Specifies the SDC file to read.                                                                                                     |

| <b>Table 7–1. Summary of Command Line Options (Part 2 of 2)</b> |                                                                                                                                                                         |
|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Command Line Option</b>                                      | <b>Description</b>                                                                                                                                                      |
| --fast_model                                                    | Uses the fast corner delay models.                                                                                                                                      |
| --report_script=<script>                                        | Specifies a custom report script to be called.                                                                                                                          |
| --speed=<value>                                                 | Specifies the device speed grade to be used for timing analysis.                                                                                                        |
| --tq2hc                                                         | Generate temporary files to convert the Quartus II TimeQuest Timing Analyzer SDC file(s) to a PrimeTime SDC file that can be used by the HardCopy Design Center (HCDC). |
| --tq2pt                                                         | Generates temporary files to convert the Quartus II TimeQuest Timing Analyzer SDC file(s) to a PrimeTime SDC file.                                                      |
| -f <argument file>                                              | Specifies a file containing additional command-line arguments.                                                                                                          |
| -c <revision name>  <br>--rev=<revision_name>                   | Specifies which revision and its associated Quartus II Settings File (.qsf) to use.                                                                                     |
| --multicorner                                                   | Specifies that all slack summary reports be generated for both slow and fast corners.                                                                                   |

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.

| <b>Table 7–2. Quartus II TimeQuest Timing Analyzer Terms</b> |                                                                                                               |
|--------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| <b>Terminology</b>                                           | <b>Definition</b>                                                                                             |
| 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.                                                 |
| Clocks                                                       | Abstract objects outside of the design.                                                                       |

**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® 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-3. Sample Design**



**Figure 7-4. The Quartus II TimeQuest Timing Analyzer Timing Netlist**



[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**



Once 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.

**Figure 7–6. Data Arrival and Clock Arrival**



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.

**Figure 7–7. Launch Edge and Latch Edge**

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.

**Figure 7–8. Setup Check**

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 1](#), for internal register-to-register paths.

$$(1) \quad \text{Clock Setup Slack} = \text{Data Required Time} - \text{Data Arrival Time}$$

$$\begin{aligned} \text{Data Arrival Time} &= \text{Launch Edge} + \text{Clock Network Delay to Source Register} + \\ &\quad \mu t_{CO} + \text{Register-to-Register Delay} \end{aligned}$$

$$\text{Data Required} = \text{Clock Arrival Time} - \mu t_{SU} - \text{Setup Uncertainty}$$

$$\text{Clock Arrival Time} = \text{Latch Edge} + \text{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 2](#) to calculate the setup slack time.

$$(2) \quad \text{Clock Setup Slack Time} = \text{Data Required Time} - \text{Data Arrival Time}$$

$$\begin{aligned} \text{Data Arrival Time} &= \text{Launch Edge} + \text{Clock Network Delay} + \\ &\quad \text{Input Maximum Delay of Pin} + \text{Pin-to-Register Delay} \end{aligned}$$

$$\text{Data Required Time} = \text{Latch Edge} + \text{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 3](#) to calculate the setup slack time.

$$(3) \text{ Clock Setup Slack Time} = \text{Data Required Time} - \text{Data Arrival Time}$$

$$\text{Data Arrival Time} = \text{Launch Edge} + \text{Clock Network Delay to Source Register} + \mu t_{CO} + \text{Register-to-Pin Delay}$$

$$\text{Data Required Time} = \text{Latch Edge} + \text{Clock Network Delay} - \text{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 4](#).

$$(4) \text{ Clock Hold Slack} = \text{Data Arrival Time} - \text{Data Required Time}$$

$$\text{Data Arrival Time} = \text{Launch Edge} + \text{Clock Network Delay to Source Register} + \mu r_{co} + \text{Register-to-Register Delay}$$

$$\text{Data Required Time} = \text{Clock Arrival Time} + \mu r_H + \text{Hold Uncertainty}$$

$$\text{Clock Arrival Time} = \text{Latch Edge} + \text{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 5](#) to calculate the hold slack time.

$$(5) \text{ Clock Setup Slack Time} = \text{Data Arrival Time} - \text{Data Required Time}$$

$$\text{Data Arrival Time} = \text{Launch Edge} + \text{Clock Network Delay} + \text{Input Minimum Delay of Pin} + \text{Pin-to-Register Delay}$$

$$\text{Data Required Time} = \text{Latch Edge} + \text{Clock Network Delay to Destination Register} + \mu r_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 6](#) to calculate the setup hold time.

$$(6) \text{ Clock Setup Slack Time} = \text{Data Arrival Time} - \text{Data Required Time}$$

$$\text{Data Arrival Time} = \text{Latch Edge} + \text{Clock Network Delay to Source Register} + \mu r_{co} + \text{Register-to-Pin Delay}$$

$$\text{Data Required Time} = \text{Latch Edge} + \text{Clock Network Delay} - \text{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](#) to calculate the recovery slack time.

$$(7) \quad \text{Recovery Slack Time} = \text{Data Required Time} - \text{Data Arrival Time}$$

$$\text{Data Arrival Time} = \text{Launch Edge} + \text{Clock Network Delay to Source Register} + \mu t_{CO} + \text{Register-to-Register Delay}$$

$$\text{Data Required Time} = \text{Latch Edge} + \text{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 8](#) to calculate the recovery slack time.

$$(8) \quad \text{Recovery Slack Time} = \text{Data Required Time} - \text{Data Arrival Time}$$

$$\text{Data Arrival Time} = \text{Launch Edge} + \text{Clock Network Delay} + \text{Maximum Input Delay} + \text{Port-to-Register Delay}$$

$$\text{Data Required Time} = \text{Latch Edge} + \text{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 9](#) to calculate the removal slack time.

$$(9) \quad \text{Removal Slack Time} = \text{Data Arrival Time} - \text{Data Required Time}$$

$$\text{Data Arrival Time} = \text{Launch Edge} + \text{Clock Network Delay to Source Register} + \mu t_{CO} \text{ of Source Register} + \text{Register-to-Register Delay}$$

$$\text{Data Required Time} = \text{Latch Edge} + \text{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 10](#) to calculate the removal slack time.

$$(10) \quad \text{Removal Slack Time} = \text{Data Arrival Time} - \text{Data Required Time}$$

$$\text{Data Arrival Time} = \text{Launch Edge} + \text{Clock Network Delay} + \text{Input Minimum Delay of Pin} + \text{Minimum Pin-to-Register Delay}$$

$$\text{Data Required Time} = \text{Latch Edge} + \text{Clock Network Delay to Destination Register} + \mu t_H$$



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.

**Figure 7–12. Default Setup and Hold Timing Diagram**

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                |
|------------------------------------------------|--------------------------------------------|
| <code>set_multicycle_path -setup -end</code>   | Latch edge time of the setup relationship  |
| <code>set_multicycle_path -setup -start</code> | Launch edge time of the setup relationship |
| <code>set_multicycle_path -hold -end</code>    | Latch edge time of the hold relationship   |
| <code>set_multicycle_path -hold -start</code>  | Latch 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.

**Figure 7–13. Modified Setup Diagram**

## Metastability

All registers have defined setup and hold time requirements that allow the registers to capture data at the inputs. The captured data is then sent to the output of the register, which has a high- or low-voltage signal, depending on the signal captured at the input. However, if the data violates the setup and/or hold times, the output of the register may go into a metastable state. In this state, the output of a register hovers at a value between the high and low states. When this value propagates through the circuit, registers may latch the wrong value, which may cause the system to fail.

Metastability problems commonly occur when a data signal is transferred between two sets of circuitry that are in unrelated clock domains. To minimize the failures due to metastability, circuit designers generally use a sequence of back-to-back registers (synchronization register chains) in the destination clock domain to resynchronize the data signals to the new clock domain.

Synchronization register chains can be defined as a sequence of registers, that meet the following requirements:

- The registers are all clocked by the same or phase-related clocks
- The first register is driven from an unrelated clock domain, or asynchronously, and the fanout of the register is 1

Figure 7–14 shows a sample synchronization register chain.

**Figure 7–14. Synchronization Chain**



The length of the synchronization register chain is defined by the number of registers in this synchronizing clock domain that meets the above requirements.



Logic can exist between these synchronization registers, as long as each net within the synchronizing clock domain has a valid setup slack.

An example of what is considered to be a synchronization register chain is shown in [Figure 7-15](#).

**Figure 7-15. Synchronization Register Chain**



When metastability occurs the clock-to-out time can be extended beyond the register's nominal  $t_{CO}$  time. The additional time beyond the  $t_{CO}$  time for the output signal to settle to a known state is known as the settling time ( $t_{MET}$ ). The  $t_{MET}$  of a synchronization register chain is the sum of all output slacks of the registers in the chain. [Figure 7-16](#) shows the  $t_{MET}$  for a metastable signal. If the metastable event takes longer to resolve than the settling time of a synchronization chain, this metastable event may be propagated forward, and cause the design to fail.

**Figure 7–16. Metastability Timing Parameters**

Based on the  $t_{MET}$  calculated, the Mean Time Between Failure (MTBF) of the synchronization chain can be calculated with the equation shown in [Equation 11](#).

$$(11) \quad MTBF = \frac{e^{(C_2 \times t_{MET})}}{C_1 \times f_{CLOCK} \times f_{DATA}}$$

The MTBF is an estimate of the average time between instances of failure. The constants **C1** and **C2** are determined by the process technology used to manufacture the device and are specified by the TimeQuest Timing Analyzer for the appropriate device.

The TimeQuest Timing Analyzer analyzes the robustness of the design for metastability by computing the MTBF for each synchronization register chain 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–68 for information about how to enable metastability analysis and report metastability in the TimeQuest Timing Analyzer.



For more information about enable metastability analysis and report metastability in TimeQuest, refer to the *Area and Timing Optimization* chapter of volume 2 in 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-17 shows a typical register-to-register path with the maximum and minimum delay values shown.

**Figure 7-17. 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-17 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-18](#) shows a diagram of the required minimum pulse width time for both the high pulse and low pulse.

**Figure 7-18. 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-18](#), 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-72](#) 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. You can access this option on the **Settings** menu by clicking **TimeQuest settings**.

Also, for CCPP to be taken into consideration during timing analysis, in the TimeQuest console pane, at a Tcl prompt or in a script, type:

```
enable_ccpp_removal
```

## 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-19](#), the path from port `clk_in` to port `clk_out` is both a clock and a data path.

**Figure 7-19. Simplified Source Synchronous Output**



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-20](#).

---

**Figure 7–20. Clock Divider**

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-21](#) to verify timing in the TimeQuest Timing Analyzer.

*Figure 7-21. Timing Verification in the TimeQuest Timing Analyzer*



The following sections describe each of the steps shown in [Figure 7-21](#).

### 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.



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-31](#).

## 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-64](#).



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.

| <b>Table 7-4. Collection Commands</b> |                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Command</b>                        | <b>Description</b>                                                                                                                                                                                                                                                                                                                                              |
| 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</code> or <code>-to</code> of <code>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-5 describes the SDC extension collection commands supported by the Quartus II TimeQuest Timing Analyzer.

| <b>Table 7-5. SDC Extension Collection Commands (Part 1 of 2)</b> |                                                                                                                                              |
|-------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Command</b>                                                    | <b>Description</b>                                                                                                                           |
| get_fanouts <filter>                                              | Returns a collection of fan-out nodes starting from <filter>.                                                                                |
| get_keepers <filter>                                              | Returns a collection of keeper nodes (non-combinational nodes) in the design.                                                                |
| get_nodes <filter>                                                | Returns a collection of nodes in the design. The <code>get_nodes</code> collection cannot be used when specifying constraints or exceptions. |
| get_partitions <filter>                                           | Returns a collection of partitions matching the <filter>.                                                                                    |
| get_registers <filter>                                            | Returns a collection of registers in the design.                                                                                             |
| get_fanins <filter>                                               | Returns a collection of fan-in nodes starting from <filter>.                                                                                 |

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

| Command                        | Description                                                                                                                                                                              |
|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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® Plug-In Manager. |
| get_assignment_groups <filter> | Returns either a collection of keepers, ports, or registers that have been saved to the Quartus Settings File (.qsf) with the <b>Assignment (Time) Groups</b> option.                    |
| remove_clock <clock list>      | Removes the list of clocks specified by <clock list>.                                                                                                                                    |
| set_scc_mode <size>            | Allows you to set the maximum Strongly Connected Components (SCC) loop size or force the Quartus II TimeQuest Timing Analyzer to always estimate delays through SCCs.                    |
| set_time_format                | Sets time format, including time unit and decimal places.                                                                                                                                |



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**.



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-22](#).

**Figure 7–22. Synopsys Design Constraints File Order of Precedence****Note to Figure 7–22:**

- (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.



If you type the `read_sdc` command at the command line without any arguments, the precedence order shown in [Figure 7–22](#) 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.

**Example 7-2. create\_clock Command**

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

Table 7-6 describes the options for the `create_clock` command.

| <b>Table 7-6. create_clock Command Options</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Option                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <code>-period &lt;period value&gt;</code>      | Specifies the clock period. You can also specify the clock period in units of frequency, such as <code>-period &lt;num&gt;MHz</code> . (1)                                                                                                                                                                                                                                                                                                                                |
| <code>-name &lt;clock name&gt;</code>          | Name of the specific clock; for example, <code>sysclock</code> . If you do not specify the clock name, the clock name is the same as the node to which it is assigned.                                                                                                                                                                                                                                                                                                    |
| <code>-waveform &lt;edge list&gt;</code>       | 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 <code>-waveform { 0 5 }</code> . The difference must be within one period unit, and the rise edge must come before the fall edge. The default edge list is <code>{ 0 &lt;period&gt;/2 }</code> , or a 50% duty cycle. |
| <code>-add</code>                              | Allows you to specify more than one clock to the same port or pin.                                                                                                                                                                                                                                                                                                                                                                                                        |
| <code>&lt;targets&gt;</code>                   | 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 “ <a href="#">Virtual Clocks</a> ” on page 7-37 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                                                                                                                                                                 |
|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-name &lt;clock name&gt;</code>   | Name of the generated clock; for example, <code>clk_x2</code> . If you do not specify the clock name, the clock name is the same as the first node to which it is assigned. |
| <code>-source &lt;master pin&gt;</code> | The <code>&lt;master pin&gt;</code> specifies the node in the design from which the clock settings derive.                                                                  |

**Table 7-7. *create\_generated\_clock* Command Options (Part 2 of 2)**

| Option                                                                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-edges &lt;edge list&gt;  <br/>           -edge_shift &lt;shift list&gt;</code> | <p>The <code>-edges</code> 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 <math>1 \dots &lt;n&gt;</math> 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 <code>&lt;edge list&gt;</code> 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.</p> <p><code>-edge_shift</code> specifies the amount of shift for each edge in the <code>&lt;edge list&gt;</code>. The <code>-invert</code> option can be used to invert the clock after the <code>-edges</code> and <code>-edge_shifts</code> are applied. (1)</p> |
| <code>-divide_by &lt;factor&gt;  <br/>           -multiply_by &lt;factor&gt;</code>   | <p>The <code>-divide_by</code> and <code>-multiply_by</code> factors are based on the first rising edge of the clock, and extend or contract the waveform by the specified factors. For example, a <code>-divide_by 2</code> is equivalent to <code>-edges {1 3 5}</code>. 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.</p>                                                                                                                                                                                                                                                                                                                                                                                              |
| <code>-duty_cycle &lt;percent&gt;</code>                                              | <p>Specifies the duty cycle of the generated clock. The duty cycle is applied last.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| <code>-add</code>                                                                     | <p>Allows you to specify more than one clock to the same pin.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <code>-invert</code>                                                                  | <p>Inversion is applied at the output of the clock after all other modifications are applied, except duty cycle.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <code>-master_clock &lt;clock&gt;</code>                                              | <p><code>-master_clock</code> is used to specify the clock if multiple clocks exist at the master pin.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <code>-phase &lt;phase&gt;</code>                                                     | <p>Specifies the phase of the generated clock.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <code>-offset &lt;offset&gt;</code>                                                   | <p>Specifies the offset of the generated clock.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <code>&lt;targets&gt;</code>                                                          | <p>Specifies the port(s) or pin(s) to which the assignment applies.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

**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–23 shows how to create an inverted generated clock based on a 10 ns clock.

### Figure 7–23. Generating an Inverted Clock

```
create_clock -period 10 [get_ports clk]
create_generated_clock -divide_by 1 -invert -source [get_registers clk] \
    [get_registers gen|clkreg]
```



Figure 7–24 shows how to modify the generated clock using the `-edges` and `-edge_shift` options.

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

```
create_clock -period 10 -waveform { 0 5} [get_ports clk]
# Creates a divide-by-5 clock
create_generated_clock -source [get_ports clk] -edges {1 3 5 } [get_registers \
clkdivA|clkreg]
# Creates a divide-by-2 clock independent of the master clocks' duty cycle (now 50%)
create_generated_clock -source [get_ports clk] -edges {1 1 5} -edge_shift { 0 2.5 0 } \
[get_registers clkdivB|clkreg]
```



Figure 7–25 shows the effect of the `-multiply_by` option on the generated clock.

**Figure 7–25. Multiplying a Generated Clock**

```
create_clock -period 10 -waveform { 0 5 } [get_ports clk]
# Creates a multiply-by-2 clock
create_generated_clock -source [get_ports clk] -multiply_by 2 [get_registers \
clkmult|clkreg]
```



## 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–26 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.

---

**Figure 7–26. Virtual Clock Board Topology**

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.

| <b>Table 7-8. derive_clocks Command Options</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Option                                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <code>-period &lt;period value&gt;</code>       | Creates the clock period. You can also specify the frequency as <code>-period &lt;num&gt;MHz</code> . (1)                                                                                                                                                                                                                                                                                                                                                                 |
| <code>-waveform &lt;edge list&gt;</code>        | 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 <code>waveform { 0 5 }</code> . The difference must be within one period unit, and the rising edge must come before the falling edge. The default edge list is <code>{ 0 period/2 }</code> , 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                                                                                                                                             |
|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-use_tan_name</code>       | 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. |
| <code>-create_base_clocks</code> | 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 [Figure 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 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 serialization factors.

For example, [Figure 7-27](#) shows a simple PLL design with a register-to-register path.

**Figure 7-27. 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-27](#), 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 will be 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.

| <b>Table 7-10. <code>set_clock_groups</code> Command Options</b> |                                                                                                                                                            |
|------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Option</b>                                                    | <b>Description</b>                                                                                                                                         |
| <code>-asynchronous</code>                                       | Asynchronous clocks—when the two clocks have no phase relationship and are active at the same time.                                                        |
| <code>-exclusive</code>                                          | 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. |
| <code>-group &lt;clock name&gt;</code>                           | Specifies valid destination clock names that are mutually exclusive. <code>&lt;clock name&gt;</code> is used to specify the clock names.                   |

| <b>Option</b>                          | <b>Description</b>                                                                                                                                         |
|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-asynchronous</code>             | Asynchronous clocks—when the two clocks have no phase relationship and are active at the same time.                                                        |
| <code>-exclusive</code>                | 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. |
| <code>-group &lt;clock name&gt;</code> | Specifies valid destination clock names that are mutually exclusive. <code>&lt;clock name&gt;</code> 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 co-exist 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, if port A can be fed by a 25-MHz or a 50-MHz clock, two clocks can be created on the port, use `set_clock_groups -exclusive` to declare that they cannot co-exist 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 C]
set_false_path -from [get_clocks D] -to [get_clocks A]
set_false_path -from [get_clocks D] -to [get_clocks C]
```

---

## 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.



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.

| <b>Table 7-11. <code>set_clock_latency</code> Command Options</b> |                                                                                     |
|-------------------------------------------------------------------|-------------------------------------------------------------------------------------|
| Option                                                            | Description                                                                         |
| <code>-source</code>                                              | Specifies a source latency.                                                         |
| <code>-clock &lt;clock list&gt;</code>                            | Specifies the clock to use if the target has more than one clock assigned to it.    |
| <code>-rise   -fall</code>                                        | Specifies the rising or falling delays.                                             |
| <code>-late   -early</code>                                       | Specifies the earliest or the latest arrival times to the clock.                    |
| <code>&lt;delay&gt;</code>                                        | Specifies the delay value.                                                          |
| <code>&lt;targets&gt;</code>                                      | Specifies the clocks or clock sources if a clock is clocked by more than one clock. |

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>
```

---

Table 7-12 describes the options for the `set_clock_` uncertainty command.

| <b>Table 7-12. <code>set_clock_</code> uncertainty Command Options</b> |                                |
|------------------------------------------------------------------------|--------------------------------|
| <b>Option</b>                                                          | <b>Description</b>             |
| <code>-from &lt;from clock&gt;</code>                                  | Specifies the from clock.      |
| <code>-rise_from &lt;rise from clock&gt;</code>                        | Specifies the rise-from clock. |
| <code>-fall_from &lt;fall from clock&gt;</code>                        | Specifies the fall-from clock. |
| <code>-to &lt;to clock&gt;</code>                                      | Specifies the to clock.        |
| <code>-rise_to &lt;rise to clock&gt;</code>                            | Specifies the rise-to clock.   |
| <code>-fall_to &lt;fall to clock&gt;</code>                            | Specifies the fall-to clock.   |
| <code>-setup   -hold</code>                                            | Specifies setup or hold.       |
| <code>&lt;value&gt;</code>                                             | Uncertainty value.             |

## 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.

| <b>Table 7-13. <code>derive_clock_</code> uncertainty Command Options</b> |                                                                                    |
|---------------------------------------------------------------------------|------------------------------------------------------------------------------------|
| <b>Option</b>                                                             | <b>Description</b>                                                                 |
| <code>-overwrite</code>                                                   | Overwrites previously performed clock uncertainty assignments                      |
| <code>-add</code>                                                         | 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

 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-28.

**Figure 7-28. Intra-Clock Transfer**



### 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-29.

**Figure 7-29. 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-30.

**Figure 7-30. I/O Interface-Clock Transfer**



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-31 shows a typical input I/O interface with the clock specifications.

**Figure 7-31. I/O Interface Specifications**



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

**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-32](#) shows an input delay path.

**Figure 7-32. 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.

| <b>Table 7-14. <code>set_input_delay</code> Command Options</b> |                                                                                                                                                                               |
|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Option</b>                                                   | <b>Description</b>                                                                                                                                                            |
| <code>-clock &lt;clock name&gt;</code>                          | Specifies the source clock.                                                                                                                                                   |
| <code>-clock_fall</code>                                        | Specifies the arrival time with respect to the falling edge of the clock.                                                                                                     |
| <code>-rise   -fall</code>                                      | Specifies either the rise or fall delay at the port.                                                                                                                          |
| <code>-max   -min</code>                                        | Specifies the minimum or maximum data arrival time.                                                                                                                           |
| <code>-add_delay</code>                                         | Adds another delay, but does not replace the existing delays assigned to the port.                                                                                            |
| <code>-reference_pin &lt;target&gt;</code>                      | 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. |
| <code>-source_latency_included</code>                           | Specifies that the input delay value includes the source latency delay value; therefore, any source clock latency assigned to the clock is ignored.                           |
| <code>&lt;delay value&gt;</code>                                | Specifies the delay value.                                                                                                                                                    |
| <code>&lt;targets&gt;</code>                                    | 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-33 shows an output delay path.

**Figure 7-33. 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                                                                        |
|----------------------------------------|------------------------------------------------------------------------------------|
| <code>-clock &lt;clock name&gt;</code> | Specifies the source clock.                                                        |
| <code>-clock_fall</code>               | Specifies the required time with respect to the falling edge of the clock.         |
| <code>-rise   -fall</code>             | Specifies either the rise or fall delay at the port.                               |
| <code>-max   -min</code>               | Specifies the minimum or maximum data arrival time.                                |
| <code>-add_delay</code>                | Adds another delay, but does not replace the existing delays assigned to the port. |

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

| Option                                     | Description                                                                                                                                                                    |
|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-reference_pin &lt;target&gt;</code> | 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. |
| <code>-source_latency_included</code>      | 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.          |
| <code>&lt;delay value&gt;</code>           | Specifies the delay value.                                                                                                                                                     |
| <code>&lt;targets&gt;</code>               | Specifies the destination ports or pins.                                                                                                                                       |



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.

## 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-55
- “Minimum Delay” on page 7-56
- “Maximum Delay” on page 7-58
- “Multicycle Path” on page 7-59

## 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-24](#) shows the `set_false_path` command and options.

---

**Example 7-24. `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-16](#) describes the options for the `set_false_path` command.

| <b>Table 7-16. <code>set_false_path</code> Command Options (Part 1 of 2)</b> |                                                                                                                                                             |
|------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Option</b>                                                                | <b>Description</b>                                                                                                                                          |
| <code>-fall_from &lt;clocks&gt;</code>                                       | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies false path begins at the fall from <code>&lt;clocks&gt;</code> . |
| <code>-fall_to &lt;clocks&gt;</code>                                         | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies false path ends at the fall to <code>&lt;clocks&gt;</code> .     |
| <code>-from &lt;names&gt;</code>                                             | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies false path begins at the <code>&lt;names&gt;</code> .            |
| <code>-hold</code>                                                           | Specifies the false path is valid during the hold analysis only.                                                                                            |
| <code>-rise_from &lt;clocks&gt;</code>                                       | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies false path begins at the rise from <code>&lt;clocks&gt;</code> . |

**Table 7-16. *set\_false\_path* Command Options (Part 2 of 2)**

| Option                               | Description                                                                                                                                             |
|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-rise_to &lt;clocks&gt;</code> | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies false path ends at the rise to <code>&lt;clocks&gt;</code> . |
| <code>-setup</code>                  | Specifies the false path is valid during the setup analysis only.                                                                                       |
| <code>-through &lt;names&gt;</code>  | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies false path passes through <code>&lt;names&gt;</code> .       |
| <code>-to &lt;names&gt;</code>       | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies false path ends at <code>&lt;names&gt;</code> .              |
| <code>&lt;delay&gt;</code>           | 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. The following list shows the `set_min_delay` command and options.

**Example 7-25. *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-17 describes the options for the `set_min_delay` command.

| <b>Table 7-17. <code>set_min_delay</code> Command Options</b> |                                                                                                                                                                          |
|---------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Option                                                        | Description                                                                                                                                                              |
| <code>-fall_from &lt;clocks&gt;</code>                        | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies the minimum delay begins at the falling edge of <code>&lt;clocks&gt;</code> . |
| <code>-fall_to &lt;clocks&gt;</code>                          | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies the minimum delay ends at the falling of <code>&lt;clocks&gt;</code> .        |
| <code>-from &lt;names&gt;</code>                              | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. The <code>&lt;names&gt;</code> acts as the start point of the path.                     |
| <code>-rise_from &lt;clocks&gt;</code>                        | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies the minimum delay at the rising edge of <code>&lt;clocks&gt;</code> .         |
| <code>rise_to &lt;clocks&gt;</code>                           | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies the minimum delay at the rising edge of <code>&lt;clocks&gt;</code> .         |
| <code>-through &lt;names&gt;</code>                           | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. The <code>&lt;names&gt;</code> acts as the through point of the path.                   |
| <code>-to &lt;names&gt;</code>                                | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. The <code>&lt;names&gt;</code> acts as the end point of the path.                       |
| <code>&lt;delay&gt;</code>                                    | 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 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.



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-26](#) shows the `set_max_delay` command and options.

### Example 7-26. `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-18](#) describes the options for the `set_max_delay` command.

**Table 7-18. or `set_max_delay` Command Options**

| Option                                 | Description                                                                                                                                                              |
|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-fall_from &lt;clocks&gt;</code> | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies the maximum delay begins at the falling edge of <code>&lt;clocks&gt;</code> . |
| <code>-fall_to &lt;clocks&gt;</code>   | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies the maximum delay ends at the falling of <code>&lt;clocks&gt;</code> .        |
| <code>-from &lt;names&gt;</code>       | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. The <code>&lt;names&gt;</code> acts as the start point of the path.                     |
| <code>-rise_from &lt;clocks&gt;</code> | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies the maximum delay at the rising edge of <code>&lt;clocks&gt;</code> .         |
| <code>-rise_to &lt;clocks&gt;</code>   | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies the maximum delay at the rising edge of <code>&lt;clocks&gt;</code> .         |
| <code>-through &lt;names&gt;</code>    | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. The <code>&lt;names&gt;</code> acts as the through point of the path.                   |
| <code>-to &lt;names&gt;</code>         | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. The <code>&lt;names&gt;</code> acts as the end point of the path.                       |
| <code>&lt;delay&gt;</code>             | 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-27](#) shows the `set_multicycle_path` command and options.

**Example 7-27. 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-19 describes the options for the `set_multicycle_path` command.

| <b>Table 7-19. set_multicycle_path Command Options</b> |                                                                                                                                                                       |
|--------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Option                                                 | Description                                                                                                                                                           |
| <code>fall_from &lt;clocks&gt;</code>                  | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies the multicycle begins at the falling edge of <code>&lt;clocks&gt;</code> . |
| <code>fall_to &lt;clocks&gt;</code>                    | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies the multicycle ends at the falling of <code>&lt;clocks&gt;</code> .        |
| <code>-from &lt;names&gt;</code>                       | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. The <code>&lt;names&gt;</code> acts as the start point of the path.                  |
| <code>-hold   -setup</code>                            | Specifies the type of multicycle to be applied.                                                                                                                       |
| <code>-rise_from &lt;clocks&gt;</code>                 | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies the multicycle at the rising edge of <code>&lt;clocks&gt;</code> .         |
| <code>-rise_to &lt;clocks&gt;</code>                   | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies the multicycle ends at the rising edge of <code>&lt;clocks&gt;</code> .    |
| <code>-start   -end</code>                             | Specifies whether the start or end clock acts as the source or destination for the multicycle.                                                                        |
| <code>-through &lt;names&gt;</code>                    | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. Specifies multicycle passes through <code>&lt;names&gt;</code> .                     |
| <code>-to &lt;names&gt;</code>                         | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. The <code>&lt;names&gt;</code> acts as the end point of the path.                    |
| <code>&lt;path multiplier&gt;</code>                   | 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.

## Application Examples

This section describes specific examples for the `set_multicycle_path` command.

Figure 7–34 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–34. Register-to-Register Path**



Figure 7–35 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–35. 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–20 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–20. 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–36 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–36. Modified Setup Diagram**

```
# latch every 2nd edge
set_multicycle_path -from [get_clocks src_clk] -to [get_clocks dst_clk] -setup -end 2
```



## 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-21 lists commands that allow you to remove constraints and exceptions from a design.

**Table 7-21. Constraint and Exception Removal**

| Command                                                                             | Description                                                                                                                               |
|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| <code>remove_clock [-all] [&lt;clock list&gt;]</code>                               | Removes any clocks specified by <i>&lt;clock list&gt;</i> that have been previously created. The -all option removes all declared clocks. |
| <code>remove_clock_groups -all</code>                                               | Removes all clock groups previously created. Specific clock groups cannot be removed.                                                     |
| <code>remove_clock_latency -source &lt;targets&gt;</code>                           | Removes the clock latency constraint from the clock specified by <i>&lt;targets&gt;</i> .                                                 |
| <code>remove_clock_uncertainty -from &lt;from clock&gt; -to &lt;to clock&gt;</code> | Removes the clock uncertainty constraint from <i>&lt;from clock&gt;</i> to <i>&lt;to clock&gt;</i> .                                      |
| <code>remove_input_delay &lt;targets&gt;</code>                                     | Removes the input delay constraint from <i>&lt;targets&gt;</i> .                                                                          |
| <code>remove_output_delay &lt;targets&gt;</code>                                    | Removes the output delay constraint from <i>&lt;targets&gt;</i> .                                                                         |
| <code>reset_design</code>                                                           | 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-28](#) shows the `report_timing` command and options.

---

#### **Example 7-28. report\_timing Command**

```
report_timing
[-append]
[-detail <summary|path_only|path_and_clock|full_path>]
[-fall_from_clock <names>]
[-fall_to_clock <names>]
[-false_path]
[-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]
[-show_routing]
[-stdout]
[-through <names>]
[-to <names>]
[-to_clock <names>]
```

---

Table 7–22 describes the options for the `report_timing` command.

| <b>Table 7–22. <code>report_timing</code> Command Options (Part 1 of 2)</b> |                                                                                                                                                                                                                                                                                                |
|-----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Option                                                                      | Description                                                                                                                                                                                                                                                                                    |
| <code>-append</code>                                                        | Specifies that the current report be appended to the file specified by the <code>-file</code> option                                                                                                                                                                                           |
| <code>-detail &lt;summary path_only path_and_clock full_path&gt;</code>     | Specifies whether or not the clock path detail is reported:<br>Path Only: Clock network delay is lumped together<br>Summary: Lists each individual path<br>Path and Clock: Clock network delay is shown in detail<br>Full Path: More clock network details, in particular for generated clocks |
| <code>-fall_from_clock &lt;names&gt;</code>                                 | Specifies the falling edge of the <code>&lt;names&gt;</code> from the source register to be analyzed. The options <code>from_clock</code> , <code>fall_from_clock</code> , and <code>rise_from_clock</code> are mutually exclusive                                                             |
| <code>-fall_to_clock &lt;names&gt;</code>                                   | Specifies the falling edge of the <code>&lt;names&gt;</code> to the destination register to be analyzed; the options <code>to_clock</code> , <code>fall_to_clock</code> , and <code>rise_to_clock</code> are mutually exclusive                                                                |
| <code>-false_path</code>                                                    | Reports only paths that are cut by a false path assignment                                                                                                                                                                                                                                     |
| <code>-file &lt;names&gt;</code>                                            | Indicates that the current report is written to the file <code>&lt;name&gt;</code>                                                                                                                                                                                                             |
| <code>-hold</code>                                                          | Specifies a clock hold analysis                                                                                                                                                                                                                                                                |
| <code>-less_than_slack &lt;slack limit&gt;</code>                           | Limits the paths to be reported to the <code>&lt;slack limit&gt;</code> value                                                                                                                                                                                                                  |
| <code>-npaths &lt;number&gt;</code>                                         | Specifies the number of paths to report                                                                                                                                                                                                                                                        |
| <code>-nworst &lt;number&gt;</code>                                         | Restricts the number of paths per endpoint                                                                                                                                                                                                                                                     |
| <code>-panel_name &lt;names&gt;</code>                                      | Specifies the name of the panel in the <b>Reports</b> pane                                                                                                                                                                                                                                     |
| <code>-panel_name &lt;names&gt;</code>                                      | Sends the results to the panel and specifies the name of the new panel                                                                                                                                                                                                                         |
| <code>-pairs_only</code>                                                    | When set, paths with the same start and end points are considered equivalent; only the worst-case path for each unique combination is displayed                                                                                                                                                |
| <code>-recovery</code>                                                      | Specifies a recovery analysis                                                                                                                                                                                                                                                                  |
| <code>-removal</code>                                                       | Specifies a removal analysis                                                                                                                                                                                                                                                                   |
| <code>-rise_from_clock &lt;names&gt;</code>                                 | Specifies the rising edge of the <code>&lt;names&gt;</code> from the source register to be analyzed; the options <code>from_clock</code> , <code>fall_from_clock</code> , and <code>rise_from_clock</code> are mutually exclusive                                                              |
| <code>-rise_to_clock &lt;names&gt;</code>                                   | Specifies the rising edge of the <code>&lt;names&gt;</code> to the destination register to be analyzed; the options <code>to_clock</code> , <code>fall_to_clock</code> , and <code>rise_to_clock</code> are mutually exclusive                                                                 |
| <code>-setup</code>                                                         | Specifies a clock setup analysis                                                                                                                                                                                                                                                               |
| <code>-show_routing</code>                                                  | Option to display detailed routing in the path                                                                                                                                                                                                                                                 |
| <code>-stdout</code>                                                        | Indicates the report be sent to <code>stdout</code>                                                                                                                                                                                                                                            |
| <code>-through &lt;names&gt;</code>                                         | Specifies the through node for analysis                                                                                                                                                                                                                                                        |

**Table 7-22. report\_timing Command Options (Part 2 of 2)**

| Option                               | Description                                  |
|--------------------------------------|----------------------------------------------|
| <code>-to &lt;names&gt;</code>       | Specifies the to node for analysis           |
| <code>-to_clock &lt;names&gt;</code> | Specifies the destination clock for analysis |

**Example 7-29** 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-29. Sample report\_timing Report**

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:
Info: Total (ns)  Incr (ns)    Type  Node
Info: ======  ======  ==  =====
Info: 0.000      0.000      launch edge time
Info: 2.237      2.237      R      clock network delay
Info: 2.410      0.173      uTco   src_reg
Info: 2.410      0.000      RR     CELL   src_reg|regout
Info: 3.407      0.997      RR     IC     dataout|datain
Info: 3.561      0.154      RR     CELL   dst_reg
Info:
Info: Data Required Path:
Info:
Info: Total (ns)  Incr (ns)    Type  Node
Info: ======  ======  ==  =====
Info: 10.000     10.000     latch edge time
Info: 11.958     1.958      R      clock network delay
Info: 11.610     -0.348     uTsu   dst_reg
Info:
Info: Data Arrival Time : 3.561
Info: Data Required Time : 11.610
Info: Slack           : 8.049
Info: ======
```

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–23](#).



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.

**Table 7–23. Timing Report Data**

| 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 |
| Type        | Shows the node type; refer to <a href="#">Table 7–24</a> 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–24](#) provides a description of the possible node type in the `report_timing` reports.

**Table 7–24. Type Description**

| Type Name    | Description                                                                                                                                                       |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CELL         | Indicates the element is either a register or a combinational element in the FPGA; the CELL can be a register in the ALM, memory blocks, DSP blocks, or I/O block |
| COMP         | Indicates the PLL clock network compensation delay                                                                                                                |
| IC           | Indicates the element is an interconnect delay                                                                                                                    |
| $\mu t_{CO}$ | Indicates the element's micro clock-to-out time                                                                                                                   |
| $\mu t_{SU}$ | Indicates the element's micro setup time                                                                                                                          |
| $\mu t_H$    | Indicates the element's micro hold time                                                                                                                           |
| $t_{EXT}$    | Indicates the element's external input delay time                                                                                                                 |
| $\phi_{EXT}$ | Indicates the element's external output delay time                                                                                                                |

## report\_metastability

Use the `report_metastability` function to estimate the robustness of asynchronous transfers in your design, and to generate a report that details the MTBF for all detected synchronization register chains.

### **Example 7-30. `report_metastability` command**

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

**Table 7-25** describes the options for the `report_metastability` command.

**Table 7-25. `report_metastability` Command Options**

| Option                                | Description                                                                                   |
|---------------------------------------|-----------------------------------------------------------------------------------------------|
| <code>-append</code>                  | Specifies that the current report be appended to the file specified by the <code>-file</code> |
| <code>-file &lt;name&gt;</code>       | Sends the results to a file                                                                   |
| <code>-panel_name &lt;name&gt;</code> | Sends the results to the panel and specifies the name of the new panel                        |
| <code>-stdout</code>                  | Indicates the report be sent to <code>stdout</code>                                           |

The `report_metastability` function generates a list of synchronization register chains found in the design, and estimates the MTBF of each chain. The design MTBF is an estimate of the overall robustness of the design, computed from the MTBF results from all of the synchronization chains.

The MTBF estimates assume typical conditions, defined as nominal silicon characteristics for the selected device speed grade, as well as nominal voltage and temperature (25°C).

The MTBF estimates assume the data being synchronized is switching at a toggle rate of 12.5% of the source clock frequency. That is, the estimates are made under the assumption that the arriving data switches once every eight source clock cycles. If multiple clocks apply, the highest frequency is used. If no source clocks can be determined, then the data rate is taken as 12.5% of the synchronization clock frequency.

The design must be fully constrained and pass timing for the features to be available in the TimeQuest Timing Analyzer. If an input port fans out to registers that are not acting as synchronization registers, it is important

that a `set_input_delay` constraint is applied to the input port. Without the constraint, the TimeQuest Timing Analyzer views the input port as an asynchronous input, and therefore these registers are reported as synchronization registers. Likewise, registers that are at the end of false paths are also considered synchronization registers.

If you constrain a synchronous input port with a `set_max_delay` constraint, this does not prevent synchronizer identification. Because the `set_max_delay` constraint does not associate the input port with a clock domain, this input port is still considered to be asynchronous. Instead of using the `set_max_delay` constraint, use a `set_input_delay -max` constraint.

For example, instead of specifying setup requirements as:

```
set_max_delay < $t_{SU}$  requirement>
```

use the following syntax:

```
set_input_delay -max <latch-launch -  $t_{SU}$  requirement>
```

### *Settings*

Before the TimeQuest Timing Analyzer can analyze a design for metastability, both the Metastability Analysis and Synchronization Register Chain Length options must be set.

#### **Metastability Analysis**

This option controls how aggressively the TimeQuest Timing Analyzer and the Fitter identifies registers as being part of a synchronization register chain. The recommended setting for the **Metastability Analysis** option is **AUTO**.

The definitions of various settings of the **Metastability Analysis** option are shown in [Table 7-26](#).

**Table 7-26. Settings for the Metastability Analysis Option**

| Settings    | Description                                                                                                                                                                                             |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ON</b>   | <ul style="list-style-type: none"> <li>Traverse through logic to identify synchronization registers if necessary.</li> <li>Report all synchronization registers found, regardless of length.</li> </ul> |
| <b>AUTO</b> | <ul style="list-style-type: none"> <li>Identify synchronization chains that does not contain logic.</li> <li>Report only synchronization register chains of length greater than 1.</li> </ul>           |
| <b>OFF</b>  | <ul style="list-style-type: none"> <li>No synchronization registers will be identified.</li> </ul>                                                                                                      |

To adjust the **Metastability Analysis** option, in the Quartus II software, on the Settings menu, point to the TimeQuest Timing Analyzer page under **Timing Analysis Settings**. From the drop-down menu next to metastability Analysis, select your desired setting.



If you change the **Metastability Analysis** setting, you must re-run the Fitter to account for the new setting.

In addition to the global assignment, the Assignment Editor supports the **Metastability Analysis** option on a node- and entity-level. This option allows you to specify a node or entity and turn off metastability analysis for specific parts of the design. If some synchronization chains are misidentified and you remove them from the report, you can turn off analysis of these paths. To do this, on the Assignment Editor, set **Analyze Metastability** to **OFF** for the first register in these synchronization chains. When this option is turned off, metastability analysis is not performed for these synchronization chains.

Conversely, if there are synchronization chains in your design that were not detected, you can turn on the **Analyze Metastability** option for the first register in this chain, and it will be reported if it meets the criteria for being a synchronization chain. This can often occur if there is logic present between the registers of the synchronization chain. In the default mode of metastability analysis, these structures are not considered to be synchronizers.

### Synchronization Register Chain Length

The **Synchronization Register Chain Length** option prevents the Quartus II software optimization algorithms from being performed on the registers contained in synchronization chain. For example, if the **Synchronization Register Chain Length** is set to 2, optimizations such as register duplication or logic retiming is prevented from being performed on the first two registers in all identified synchronization chains. The default setting for the **Synchronization Register Chain Length** option is 2.

To change the **Synchronization Register Chain Length** option, on the Settings menu, point to **Analysis & Synthesis**. Click **More Settings**. The **More Settings** dialog box appears. From this dialog box, you can set the Synchronization Register Chain Length.

You can also set the Synchronization Register Chain Length on a node or an entity via the Assignment Editor. You can set this value on the head of a synchronization chain to protect only registers in this chain, up to the value you specify. This is useful if you protect a specific synchronization chain up to the third register, but want a global default protection level of two.

Altera recommends that you set this option to the maximum length of synchronization chains you have in your design so that all synchronization registers are preserved.

### **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-31](#) shows the `report_clock_transfers` command and options.

---

#### **Example 7-31. report\_clock\_transfers Command**

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

---

[Table 7-27](#) describes the options for the `report_clock_transfers` command.

| <b>Table 7-27. report_clock_transfers Command Options (Part 1 of 2)</b> |                                                                                                       |
|-------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| <b>Option</b>                                                           | <b>Description</b>                                                                                    |
| <code>-append</code>                                                    | Specifies that the current report be appended to the file specified by the <code>-file</code> option. |
| <code>-file &lt;name&gt;</code>                                         | Indicates that the current report is written to the file <code>&lt;name&gt;</code> .                  |
| <code>-hold</code>                                                      | Creates a clock transfer summary for hold analysis.                                                   |
| <code>-setup</code>                                                     | Creates a clock transfer summary for setup analysis.                                                  |
| <code>-stdout</code>                                                    | Indicates the report be sent to <code>stdout</code> .                                                 |
| <code>-recovery</code>                                                  | Creates a clock transfer summary for recovery analysis.                                               |

**Table 7-27. report\_clock\_transfers Command Options (Part 2 of 2)**

| Option                                | Description                                                             |
|---------------------------------------|-------------------------------------------------------------------------|
| <code>-removal</code>                 | Creates a clock transfer summary for removal analysis.                  |
| <code>-panel_name &lt;name&gt;</code> | 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-32 shows the `report_clocks` command and options.

**Example 7-32. report\_clocks Command**

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

Table 7-28 describes the options for the `report_clocks` command.

**Table 7-28. report\_clocks Command Options**

| Option                                | Description                                                                                           |
|---------------------------------------|-------------------------------------------------------------------------------------------------------|
| <code>-append</code>                  | Specifies that the current report be appended to the file specified by the <code>-file</code> option. |
| <code>-file &lt;name&gt;</code>       | Indicates that the current report is written to the file <code>&lt;name&gt;</code> .                  |
| <code>-desc</code>                    | Specifies the clock names to sort in descending order. The default is ascending order.                |
| <code>-stdout</code>                  | Indicates the report be sent to <code>stdout</code> .                                                 |
| <code>-panel_name &lt;name&gt;</code> | Sends the results to the panel and specifies the name of the new panel.                               |

### 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-33](#) shows the `report_min_pulse_width` command and options.

---

**Example 7-33. `report_min_pulse_width` Command**

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

---

[Table 7-29](#) describes the options for the `report_min_pulse_width` command.

**Table 7-29. `report_min_pulse_width` Command Options (Part 1 of 2)**

| Option                              | Description                                                                                                   |
|-------------------------------------|---------------------------------------------------------------------------------------------------------------|
| <code>-append</code>                | If output is sent to a file, this option appends the result to that file. Otherwise, the file is overwritten. |
| <code>-file &lt;name&gt;</code>     | Sends the results to a file.                                                                                  |
| <code>-nworst &lt;number&gt;</code> | Specifies the number of pulse width checks to report. The default is 1.                                       |

**Table 7-29. report\_min\_pulse\_width Command Options (Part 2 of 2)**

| Option             | Description                                                                                                                                             |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| -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           | Specifies registers.                                                                                                                                    |
| -panel_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-34 shows the report\_net\_timing command and options.

**Example 7-34. report\_net\_timing Command**

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

Table 7-30 describes the options for the report\_net\_timing command.

**Table 7-30. report\_net\_timing Command Options**

| Option                  | Description                                                                              |
|-------------------------|------------------------------------------------------------------------------------------|
| -append                 | Specifies that the current report be appended to the file specified by the -file option. |
| -file <name>            | Indicates that the current report is written to the file <name>.                         |
| -nworst_delay <number>  | Specifies that <number> worst net delays be reported.                                    |
| -nworst_fanout <number> | Specifies that <number> worst net fan-outs be reported.                                  |
| -stdout                 | Indicates the report be sent to stdout.                                                  |
| -panel_name <name>      | Sends the results to the panel and specifies the name of the new panel.                  |

## report\_sdc

Use the use the `report_sdc` command to generate a report of all the Synopsys design constraints in the project.

[Example 7-35](#) shows the `report_sdc` command and options.

---

### Example 7-35. `report_sdc` Command

```
report_sdc
[-ignored]
[-append]
[-file]
[-stdout]
[-panel_name <name>]
```

---

[Table 7-31](#) describes the options for the `report_sdc` command.

| <b>Table 7-31. <code>report_sdc</code> Command Options</b> |                                                                                                       |
|------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| Option                                                     | Description                                                                                           |
| <code>-ignored</code>                                      | Reports assignments that were ignored.                                                                |
| <code>-append</code>                                       | Specifies that the current report be appended to the file specified by the <code>-file</code> option. |
| <code>-file</code>                                         | Indicates that the current report is written to the file <code>&lt;name&gt;</code> .                  |
| <code>-stdout</code>                                       | Indicates that the report is sent to <code>stdout</code> .                                            |
| <code>-panel_name &lt;name&gt;</code>                      | 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-36](#) shows the `report_ucp` command and options.

---

### Example 7-36. `report_ucp` Command

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

---

Table 7–32 describes the options for the `report_ucp` command.

| <b>Table 7–32. Option Descriptions for <code>report_ucp</code></b> |                                                                                                       |
|--------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| <b>Option</b>                                                      | <b>Description</b>                                                                                    |
| <code>-append</code>                                               | Specifies that the current report be appended to the file specified by the <code>-file</code> option. |
| <code>-file &lt;name&gt;</code>                                    | Indicates that the current report is written to the file <code>&lt;name&gt;</code> .                  |
| <code>-hold</code>                                                 | Reports all unconstrained hold paths.                                                                 |
| <code>-setup</code>                                                | Reports all unconstrained setup paths.                                                                |
| <code>-stdout</code>                                               | Indicates the report be sent to <code>stdout</code> .                                                 |
| <code>-summary</code>                                              | Generates only the summary panel.                                                                     |
| <code>-panel_name &lt;name&gt;</code>                              | Sends the results to the panel and specifies the name of the new panel.                               |

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

| <b>Table 7–33. Reports from the Tasks Pane and <code>Tcl</code> Commands (Part 1 of 2)</b> |                                              |                                                                                    |
|--------------------------------------------------------------------------------------------|----------------------------------------------|------------------------------------------------------------------------------------|
| <b>Task Pane Report</b>                                                                    | <b>Tcl Command</b>                           | <b>Description</b>                                                                 |
| Report Setup Summary                                                                       | <code>create_timing_summary -setup</code>    | Generates a clock setup summary for all defined clocks.                            |
| Report Hold Summary                                                                        | <code>create_timing_summary -hold</code>     | Generates a clock hold summary for all defined clocks.                             |
| Report Recovery Summary                                                                    | <code>create_timing_summary -recovery</code> | Generates a clock recovery summary for all defined clocks.                         |
| Report Removal Summary                                                                     | <code>create_timing_summary -removal</code>  | Generates a clock removal summary for all defined clocks.                          |
| Report Clocks                                                                              | <code>report_clocks</code>                   | Generates a clock summary for all defined clocks.                                  |
| Report Clock Transfers                                                                     | <code>report_clock_transfers</code>          | Generates a clock transfer summary for all clock-to-clock transfers in the design. |
| Report SDC                                                                                 | <code>report_sdc</code>                      | Generates a summary of all SDC file commands read.                                 |
| Report Unconstrained Paths                                                                 | <code>report_ucp</code>                      | Generates a summary of all unconstrained paths in the design.                      |
| Report Timing                                                                              | <code>report_timing</code>                   | Generates a detailed summary for specific paths in the design.                     |
| Report Net Timing                                                                          | <code>report_net_timing</code>               | Generates a detailed summary for specific nets in the design.                      |

| <b>Table 7-33. Reports from the Tasks Pane and Tcl Commands (Part 2 of 2)</b> |                                     |                                                                    |
|-------------------------------------------------------------------------------|-------------------------------------|--------------------------------------------------------------------|
| <b>Task Pane Report</b>                                                       | <b>Tcl Command</b>                  | <b>Description</b>                                                 |
| Report Minimum Pulse Width                                                    | <code>report_min_pulse_width</code> | Generates a detailed summary for specific registers in the design. |
| Create Slack Histogram                                                        | <code>create_slack_histogram</code> | Generates a detailed histogram for a specific clock in the design. |

### **report\_path**

Use the `report_path` command to report the longest delay paths and corresponding delay value.

Example 7-37 shows the `report_path` command and options.

---

#### **Example 7-37. report\_path Command**

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

---

Table 7-34 describes the options for the `report_path` command.

| <b>Table 7-34. report_path Command Options</b> |                                                                                                       |
|------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| <b>Option</b>                                  | <b>Description</b>                                                                                    |
| <code>-append</code>                           | Specifies that the current report be appended to the file specified by the <code>-file</code> option. |
| <code>-file &lt;name&gt;</code>                | Indicates that the current report is written to the file <code>&lt;name&gt;</code> .                  |
| <code>-from &lt;names&gt;</code>               | Specifies the source node for analysis.                                                               |
| <code>-npaths &lt;number&gt;</code>            | Specifies the number of paths to report.                                                              |
| <code>-stdout</code>                           | Indicates the report be sent to <code>stdout</code> .                                                 |
| <code>-through &lt;name&gt;</code>             | Specifies the through node for analysis.                                                              |
| <code>-to &lt;names&gt;</code>                 | Specifies the destination node for analysis.                                                          |
| <code>-panel_name &lt;name&gt;</code>          | Sends the results to the panel and specifies the name of the new panel.                               |

## 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-38](#) shows the report\_bottleneck command and options.

### Example 7-38. 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, 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-35](#) describes the options for the report\_bottleneck command.

**Table 7-35. report\_bottleneck Command**

| Option                                                                               | Description                                                                             |
|--------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| <code>-cmetric &lt;cmetric_name&gt;</code>                                           | Custom metric function to evaluate individual nodes                                     |
| <code>-details</code>                                                                | Show the detailed information (number of failing edges, number of fanins, and so forth) |
| <code>-metric &lt;default tns num_paths num_fpaths num_fanins num_fanouts&gt;</code> | Indicate the metric to use to rate individual nodes                                     |
| <code>-panel &lt;panel_name&gt;</code>                                               | Sends the results to the panel and specifies the name of the new panel                  |

**Table 7-35. report\_bottleneck Command**

| Option  | Description                            |
|---------|----------------------------------------|
| -stdout | Indicates the report be sent to stdout |
| <paths> | Paths to be analyzed                   |

[Example 7-39](#) shows how to create a custom metric with the report\_bottleneck command.

---

**Example 7-39. 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-40](#) shows the report\_datasheet command and options.

---

**Example 7-40. report\_datasheet Command**

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

---

Table 7–36 describes the options for the `report_datasheet` command.

| <b>Table 7–36. report_datasheet Command Options</b> |                                                                                                       |
|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| <b>Option</b>                                       | <b>Description</b>                                                                                    |
| <code>-append</code>                                | Specifies that the current report be appended to the file specified by the <code>-file</code> option. |
| <code>-file &lt;name&gt;</code>                     | Indicates that the current report is written to the file <code>&lt;name&gt;</code> .                  |
| <code>-stdout</code>                                | Indicates the report be sent to <code>stdout</code> .                                                 |
| <code>-panel_name &lt;name&gt;</code>               | 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_{CO}$  and  $mint_{PD}$ .

### **report\_rskm**

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

Example 7–41 shows the `report_rskm` command and options.

---

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

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

---

Table 7–37 describes the options for the `report_rskm` command.

| <b>Table 7–37. report_rskm Command Options</b> |                                                                                                       |
|------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| <b>Type Name</b>                               | <b>Description</b>                                                                                    |
| <code>-append</code>                           | Specifies that the current report be appended to the file specified by the <code>-file</code> option. |
| <code>-file &lt;name&gt;</code>                | Indicates that the current report is written to the file <code>&lt;name&gt;</code> .                  |
| <code>-panel_name &lt;name&gt;</code>          | Sends the results to the panel and specifies the name of the new panel.                               |
| <code>-stdout</code>                           | Indicates the report be sent to <code>stdout</code> .                                                 |

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 12](#):

$$(12) \quad \text{RSKM} = \frac{(\text{TUI} - \text{SW} - \text{RCCS})}{2}$$

The time unit interval is the LVDS clock period ( $1/f_{\text{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-42](#) shows the `report_tccs` command and options.

---

#### **Example 7-42. report\_tccs Command**

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

---

[Table 7-38](#) describes the options for the `report_tccs` command.

| <b>Table 7-38. report_tccs Command Options (Part 1 of 2)</b> |                                                                                                       |
|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| Type Name                                                    | Description                                                                                           |
| <code>-append</code>                                         | Specifies that the current report be appended to the file specified by the <code>-file</code> option. |
| <code>-file &lt;name&gt;</code>                              | Indicates that the current report is written to the file <code>&lt;name&gt;</code> .                  |

| Type Name                       | Description                                                                                           |
|---------------------------------|-------------------------------------------------------------------------------------------------------|
| <code>-append</code>            | Specifies that the current report be appended to the file specified by the <code>-file</code> option. |
| <code>-file &lt;name&gt;</code> | Indicates that the current report is written to the file <code>&lt;name&gt;</code> .                  |

**Table 7-38. report\_tccs Command Options (Part 2 of 2)**

| Type Name                             | Description                                                                          |
|---------------------------------------|--------------------------------------------------------------------------------------|
| <code>-panel_name &lt;name&gt;</code> | Sends the results to the panel and specifies the name of the new panel.              |
| <code>-quiet</code>                   | Specifies that nothing will be printed if there are no LVDS receivers in the design. |
| <code>-stdout</code>                  | Indicates the report be sent to <code>stdout</code> .                                |

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

### **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-43](#) shows the `report_path` command and options.

**Example 7-43. 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-39](#) describes the options for the `report_path` command.

**Table 7-39. report\_path Command Options (Part 1 of 2)**

| Type Name                        | Description                                                                                                                                          |
|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>-append</code>             | Specifies that the current report be appended to the file specified by the <code>-file</code> option.                                                |
| <code>-file &lt;name&gt;</code>  | Indicates that the current report is written to the file <code>&lt;name&gt;</code> .                                                                 |
| <code>-from &lt;names&gt;</code> | The <code>&lt;names&gt;</code> is a collection or list of objects in the design. The <code>&lt;names&gt;</code> acts as the start point of the path. |
| <code>-min_path</code>           | Displays the minimum delay paths.                                                                                                                    |

**Table 7-39. report\_path Command Options (Part 2 of 2)**

| Type Name          | Description                                                                                                  |
|--------------------|--------------------------------------------------------------------------------------------------------------|
| -npaths <number>   | Specifies the number of paths to report.                                                                     |
| -nworst <number>   | Specifies the maximum number of paths to report for each endpoint.                                           |
| -panel_name <name> | Sends the results to the panel and specifies the name of the new panel.                                      |
| -stdout            | Indicates the report be sent to stdout.                                                                      |
| -summary           | Creates a single table with a summary of each path found.                                                    |
| -through <names>   | The <names> is a collection or list of objects in the design. Specifies false path passes through <names>.   |
| -to <names>        | The <names> is a collection or list of objects in the design. The <names> 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-37 shows a simple design with a register-to-register path.

**Figure 7-37. Simple Register-to-Register Path**

Example 7-44 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-44. report\_path from Keeper Output Pin to Keeper Input Pin**

```
Info: =====
Info: From Node : reg1|regout
Info: To Node : reg2|datain
Info:
Info: Path:
Info:
Info: Total (ns) Incr (ns) Type Element
Info: ===== ===== == === =====
Info: 0.000 0.000 reg1|regout
Info: 0.206 0.206 RR IC and2|datae
Info: 0.360 0.154 RR CELL and2|combout
Info: 0.360 0.000 RR IC reg2|datain
Info:
Info: Total Path Delay : 0.360
Info: =====
```

---

Example 7-45 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-45. 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-45 because the destination passes through an input pin of a keeper node.

### **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-46 shows the `check_timing` command and options.

---

**Example 7-46. check\_timing Command**

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

---

Table 7–40 describes the options for the `check_timing` command.

| <b>Table 7–40. <code>check_timing</code> Command Options</b> |                                                                                                                                |
|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| Option                                                       | Description                                                                                                                    |
| <code>-append</code>                                         | Specifies that the current report be appended to the file specified by the <code>-file</code> option.                          |
| <code>-file &lt;name&gt;</code>                              | Indicates that the current report is written to the file <code>&lt;name&gt;</code> .                                           |
| <code>-include</code>                                        | Indicates that a check is to be performed with the <code>&lt;check_list&gt;</code> . Refer to Table 7–41 for a list of checks. |
| <code>-stdout</code>                                         | Indicates the report be sent to <code>stdout</code> .                                                                          |
| <code>-panel_name &lt;name&gt;</code>                        | Sends the results to the panel and specifies the name of the new panel.                                                        |

Table 7–41 describes the possible checks.

| <b>Table 7–41. Possible Checks (Part 1 of 2)</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Option                                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| <code>no_clock</code>                            | 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.                                                                                                                                                                                                                                                                                                                                                                                                          |
| <code>multiple_clock</code>                      | Checks that registers have at most one clock at their clock pin. When multiple clocks reach a register's clock pin, both clocks will be used for analysis.                                                                                                                                                                                                                                                                                                                                                                                              |
| <code>generated_clock</code>                     | 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 ( <code>clk1</code> cannot have <code>clk2</code> as a source if <code>clk2</code> already uses <code>clk1</code> as a source).                                                                                                                                                                                                                                                         |
| <code>no_input_delay</code>                      | Checks that every input port that is not determined to be a clock has an input delay set on it.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| <code>no_output_delay</code>                     | Checks that every output port has an output delay set on it.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <code>partial_input_delay</code>                 | Checks that input delays are complete. Makes sure that input delays have a rise-min, fall-min, rise-max, and fall-max portion set.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <code>partial_output_delay</code>                | Checks that output delays are complete. Makes sure that output delays have a rise-min, fall-min, rise-max, and fall-max portion set.                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <code>reference_pin</code>                       | Checks if reference pins specified in <code>set_input_delay</code> and <code>set_output_delay</code> using the <code>reference_pin</code> option are valid. A <code>reference_pin</code> is valid if the clock option specified in the same <code>set_input_delay</code> / <code>set_output_delay</code> command matches the clock that is in the direct fan-in of the <code>reference_pin</code> . Being in the direct fan-in of the <code>reference_pin</code> means that there must be no keepers between the clock and <code>reference_pin</code> . |

| <b>Table 7–41. Possible Checks (Part 2 of 2)</b> |                                                                                                                                                                                                                                                                                                    |
|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Option                                           | Description                                                                                                                                                                                                                                                                                        |
| 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 if there are latches in the design. The Quartus II TimeQuest Timing Analyzer warns the user that the latches exist and cannot be properly analyzed.                                                                                                                                         |

Example 7–47 shows how the `check_timing` command can be used.

---

**Example 7–47. 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
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-48 shows the `report_clock_fmax_summary` command and options.

---

**Example 7-48. `report_clock_fmax_summary` Command**

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

---

Table 7-42 describes the options for the `report_clock_fmax_summary` command.

| <b>Table 7-42. <code>report_clock_fmax_summary</code> Command Options</b> |                                                                                                       |
|---------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| <b>Option</b>                                                             | <b>Description</b>                                                                                    |
| <code>-append</code>                                                      | Specifies that the current report be appended to the file specified by the <code>-file</code> option. |
| <code>-file &lt;name&gt;</code>                                           | Indicates that the current report is written to the file <code>&lt;name&gt;</code> .                  |
| <code>-stdout</code>                                                      | Indicates the report be sent to <code>stdout</code> .                                                 |
| <code>-panel_name &lt;name&gt;</code>                                     | 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-43.

| <b>Table 7-43. <math>f_{MAX}</math> Summary Report Column</b> |                                                                                                                                                                                                                                                                                                                                                     |
|---------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Column Name</b>                                            | <b>Description</b>                                                                                                                                                                                                                                                                                                                                  |
| $f_{MAX}$                                                     | 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_{MAX}$                                          | 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-49 shows the `create_timing_summary` command and options.

---

### Example 7-49. `create_timing_summary` Command

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

---

Table 7-44 describes the options for the `create_timing_summary` command.

**Table 7-44. `create_timing_summary` Command Options**

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

## Timing Analysis Features

The TimeQuest Timing Analyzer supports many features that enhances and provides a thorough 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 of the device used for static timing analysis.



Use the `create_timing_netlist` command to change the speed grade of the device you would like to analyze. For more information about the `create_timing_netlist` command, refer to “[Create a Timing Netlist](#)” on page [7-26](#).

[Example 7-50](#) shows the `set_operating_conditions` command and options.

---

#### **Example 7-50. `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-45](#) describes the options for the `set_operating_conditions` command.

**Table 7-45. `set_operating_conditions` Command Options**

| Option                                              | Description                                                                           |
|-----------------------------------------------------|---------------------------------------------------------------------------------------|
| <code>-model &lt;fast slow&gt;</code>               | Specifies the timing model.                                                           |
| <code>-speed &lt;speed grade&gt;</code>             | Specifies the device speed grade.                                                     |
| <code>-temperature &lt;value in °C&gt;</code>       | Specifies the operating temperature.                                                  |
| <code>-voltage &lt;value in mV&gt;</code>           | Specifies the operating voltage.                                                      |
| <code>&lt;operating condition Tcl object&gt;</code> | 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-46 shows a few of the available operating conditions that can be set for each device family.

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



Use the `get_available_operating_conditions` command to obtain a list of available operating conditions for the target device.

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

---

**Example 7-51. 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-51 with the Tcl object as shown in Example 7-52.

---

**Example 7-52. 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 on or off the **Advanced I/O Timing** 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 on or off the Advanced I/O Timing or change Board Trace Model assignments and do recompile before you analyze timing, you do not need to use the **-force\_dat** command when you create the timing netlist. You can create the timing netlist with the **create\_timing\_netlist** command, or with the **Create Timing Netlist** 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–47 shows the results of using these search strings.

| <b>Table 7–47. Sample Search Strings and Search Results</b> |                      |
|-------------------------------------------------------------|----------------------|
| Search String                                               | Search Result        |
| get_pins *  dataa                                           | foo dataa            |
| get_pins *  datac                                           | <empty>              |
| get_pins * * datac                                          | foo bar datac        |
| get_pins foo* *                                             | foo dataa, foo datab |
| get_pins -hierarchical * * datac                            | <empty> (1)          |
| get_pins -hierarchical foo *                                | foo dataa, foo datab |
| get_pins -hierarchical * datac                              | foo bar datac        |
| get_pins -hierarchical foo * datac                          | <empty> (1)          |
| get_pins -compatibility * datac                             | foo bar datac        |
| get_pins -compatibility * * datac                           | foo bar datac        |

**Note to Table 7–47:**

(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-53 shows the `locate` command and options.

---

#### **Example 7-53. *locate* Command**

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

---

Table 7–48 describes the options for the `locate` command.

| <b>Table 7–48. <i>locate</i> Options</b>                                                   |                                                                                                                                                                                          |
|--------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Option</b>                                                                              | <b>Description</b>                                                                                                                                                                       |
| <code>-chip</code>                                                                         | Locates the object in the Chip Planner                                                                                                                                                   |
| <code>-color &lt;black blue brown green grey light_grey orange purple red white&gt;</code> | Identifies the objects you are locating                                                                                                                                                  |
| <code>-cps</code>                                                                          | Locates the object in the Critical Path Settings dialog of the Chip Planner                                                                                                              |
| <code>-label &lt;label&gt;</code>                                                          | Specifies a label used to identify the objects you are locating                                                                                                                          |
| <code>-rpe</code>                                                                          | Locates in the Resource Property Editor                                                                                                                                                  |
| <code>-tmv</code>                                                                          | Locates the object in the Technology Map Viewer                                                                                                                                          |
| <code>&lt;items&gt;</code>                                                                 | 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–54 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–54. 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-97](#)
- “View Pane” described on [page 7-97](#)
- “Tasks Pane” described on [page 7-100](#)
- “Console Pane” described on [page 7-103](#)
- “Report Pane” described on [page 7-103](#)
- “Constraints” described on [page 7-103](#)
- “Name Finder” described on [page 7-105](#)
- “Target Pane” described on [page 7-107](#)
- “SDC Editor” described on [page 7-107](#)

Each pane provides features that enhance productivity ([Figure 7-38](#)).

**Figure 7-38. The TimeQuest GUI**



## 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–49](#).

**Table 7–49. The Quartus II TimeQuest Timing Analyzer Settings**

| 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. |
| 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.            |



The options shown in [Table 7–49](#) 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–39](#) shows the **View** pane after you select the **Summary (Setup)** report from the **Report** pane.

**Figure 7-39. Summary (Setup) Report**

| Summary (Setup) |                                            |       |               |
|-----------------|--------------------------------------------|-------|---------------|
|                 | Clock                                      | Slack | End Point TNS |
| 1               | inclk0                                     | 0.303 | 0.000         |
| 2               | altpll0:inst altpll:altpll_componentl_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-40).

**Figure 7-40. Splitting the View Pane to the Left (Before and After Split Left)**


| Summary (Setup) |                                            |       |               |
|-----------------|--------------------------------------------|-------|---------------|
|                 | Clock                                      | Slack | End Point TNS |
| 1               | inclk0                                     | 0.303 | 0.000         |
| 2               | altpll0:inst altpll:altpll_componentl_clk0 | 0.384 | 0.000         |

  

| Summary (Setup) |                                            |       |               |
|-----------------|--------------------------------------------|-------|---------------|
|                 | Clock                                      | Slack | End Point TNS |
| 1               | inclk0                                     | 0.303 | 0.000         |
| 2               | altpll0:inst altpll:altpll_componentl_clk0 | 0.384 | 0.000         |

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

**Figure 7–41. 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–42).

**Figure 7–42. Removing a Split Window (Before and After Split is Removed)**

## 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 12 commands located in this folder are summarized in [Table 7-50](#).

**Table 7-50. Reports Folder Commands (Part 1 of 2)**

| Report Task              | Description                                                          |
|--------------------------|----------------------------------------------------------------------|
| Report $f_{MAX}$ Summary | Generates a $f_{MAX}$ 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.  |

| <b>Table 7-50. Reports Folder Commands (Part 2 of 2)</b> |                                                                           |
|----------------------------------------------------------|---------------------------------------------------------------------------|
| <b>Report Task</b>                                       | <b>Description</b>                                                        |
| 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 SDC 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-51 describes the commands available in the Macros folder.

| <b>Table 7-51. Macros Folder Commands</b> |                                                                                                                                                                                                                            |
|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Macro Task</b>                         | <b>Description</b>                                                                                                                                                                                                         |
| Report All Summaries                      | This command runs the <b>Report Setup Summary</b> , <b>Report Hold Summary</b> , <b>Report Recovery Summary</b> , <b>Report Removal Summary</b> , and <b>Minimum Pulse Width</b> 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 <b>Create Slack Histogram</b> 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.                                                                                                                             |

## 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-43](#) shows the **Create Clock** dialog box.

**Figure 7–43. Create Clock Dialog Box**

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 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-28*.

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–91.

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–44](#).

**Figure 7–44. 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–45). Table 7–52 describes the state of each window.

**Figure 7–45. Target Pane**



**Table 7–52. View Pane Window State**

| 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.                                     |

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

## SDC Editor

The TimeQuest 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 Constraints menu, on the menu bar, opens the **Constraints** dialog box. After you have finished entering all required parameters, the SDC 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:

- *I/O Management chapter in volume 2 of the Quartus II Handbook*
- *SDC and TimeQuest API Reference Manual*
- *Volume 4: SOPC Builder in the Quartus II Handbook*
- *Switching to the Quartus II TimeQuest Timing Analyzer chapter in volume 3 of the Quartus II Handbook*
- *TimeQuest Quick Start Tutorial*

# Document Revision History

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

| <b>Table 7–53. Document Revision History (Part 1 of 2)</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                     |
|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|
| <b>Date and Version</b>                                    | <b>Changes Made</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <b>Summary of Changes</b>                                           |
| May 2008<br>v8.0.0                                         | <p>Updated for the Quartus II software version 8.0, including:</p> <ul style="list-style-type: none"> <li>Changed the heading “Specify Design Timing Requirements” to “The Quartus II TimeQuest Timing Analyzer Flow Guidelines” on page 7–26</li> <li>In “SDC Constraint Files” on page 7–29, added information about order-sensitivity</li> <li>Added a new section on “Metastability” on page 7–19</li> <li>Added a new section on “Common Clock Path Pessimism” on page 7–22</li> <li>Removed information about Asynchronous clocks from “Clock Groups” on page 7–43</li> <li>Updated information in Example 7–28</li> <li>Added three entries to Table 7–22</li> <li>Added information to Table 7–24 (ADoQS 10001445)</li> <li>Added information about the RSKM to “report_rskm” on page 7–80, including a formulaic equation (Equation 12)</li> <li>Added the section “Clock Groups” on page 7–43</li> <li>Added Table 7–44 to “report_clock_fmax_summary” on page 7–86</li> <li>Added qualifier to introduction of Table 7–46</li> <li>Added Speed Grade information to Table 7–46</li> <li>Removed [-dtw] and added [-add] to information about the derive_clock_uncertainty command (“Derive Clock Uncertainty” on page 7–47)</li> <li>Added the section “report_metastability” on page 7–68</li> <li>Added a new information about RSKM to “report_rskm” on page 7–80</li> <li>Added the section “Cross-Probing” on page 7–93</li> <li>Minor editorial updates</li> <li>Added hyperlinks to referenced documents throughout chapter</li> </ul> | Significant update for the Quartus II software version 8.0 release. |
| October 2007<br>v7.2.0                                     | <p>Updated for the Quartus II software version 7.2, including:</p> <ul style="list-style-type: none"> <li>Updated organization flow of the Compilation Flow with TimeQuest Guidelines, Timing Analysis Overview, and Specify Design Timing Requirements sections</li> <li>Added new information on Clock as Data Analysis</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Updated for the Quartus II software version 7.2.                    |

| <b>Table 7-53. Document Revision History (Part 2 of 2)</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                  |
|------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|
| <b>Date and Version</b>                                    | <b>Changes Made</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <b>Summary of Changes</b>                        |
| May 2007<br>v7.1.0                                         | <p>Updated for the Quartus II software version 7.1, including:</p> <ul style="list-style-type: none"> <li>● Added support of <code>report_path</code> in “Timing Reports” on page 6-57</li> <li>● Added <code>report_timing</code> information, especially on page 6-11</li> <li>● Added new information under the following headings: <ul style="list-style-type: none"> <li>● “Derive Clock Uncertainty” on page 6-40</li> <li>● “<code>report_rskm</code>” on page 6-69</li> <li>● “<code>report_tccs</code>” on page 6-69</li> <li>● “<code>report_path</code>” on page 6-70</li> </ul> </li> <li>● Replaced the “Fast Timing Model Analysis” section with “Multi-Corner Analysis” on page 6-76</li> <li>● Performed general 7.1 updates</li> </ul> | Updated for the Quartus II software version 7.1. |
| March 2007<br>v7.0.0                                       | Updated Quartus II software 7.0 revision and date only. No other changes made to chapter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | —                                                |
| November 2006 v6.1.0                                       | <p>Updated for the Quartus II software version 6.1, including:</p> <ul style="list-style-type: none"> <li>● New “Getting Started” section, including descriptions of the Create Clock and Create Generated Clock dialog boxes/commands, sections on Specifying Clock Requirements, Specifying Input and Output Port Requirements, and Reporting</li> <li>● SDC Editor</li> <li>● Usability enhancements to the GUI</li> <li>● Updated SDC support</li> <li>● Numerous changes throughout chapter</li> </ul>                                                                                                                                                                                                                                             | Updated for the Quartus II software version 6.1. |
| July 2006<br>v6.0.1                                        | Updated for the Quartus II software version 6.0.1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | —                                                |
| May 2006<br>v6.0.0                                         | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | —                                                |

### Introduction

The Quartus II TimeQuest Timing Analyzer provides more powerful timing analysis features than the Quartus II Classic Timing Analyzer. This chapter describes the benefits of switching to the Quartus II TimeQuest Timing Analyzer, the differences between the Quartus II TimeQuest and Quartus II Classic Timing Analyzers, and the process you should follow to switch a design from using the Quartus II Classic Timing Analyzer to the Quartus II TimeQuest Timing Analyzer.

#### Benefits of Switching to the Quartus II TimeQuest Analyzer

Increasing design complexity requires a timing analysis tool with greater capabilities and flexibility. The Quartus II TimeQuest Timing Analyzer offers the following benefits:

- Industry-standard Synopsys Design Constraint (SDC) support increases productivity.
- Simple, flexible reporting uses industry-standard terminology and makes timing sign-off faster.



For more detailed information about the features and capabilities of the Quartus II TimeQuest Timing Analyzer, refer to the *Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

These features ease constraint and analysis of modern, complex designs. SDC constraints support complex clocking schemes, high-speed interfaces, and more logic. An example includes designs that have multiplexed clocks, regardless of whether they are switched on or off chip. Designs with source-synchronous interfaces, such as DDR memory interfaces, are much simpler to constrain and analyze with the Quartus II TimeQuest Timing Analyzer.

There are three main differences between the Quartus II Classic and Quartus II TimeQuest Timing Analyzers. Unlike the Quartus II Classic Timing Analyzer, the Quartus II TimeQuest Timing Analyzer has the following three benefits:

- All clocks are related by default. (Refer to “[Related and Unrelated Clocks](#)” on page 8-13.)
- The default hold multicycle value is zero. (Refer to “[Hold Multicycle](#)” on page 8-24.)

- You must constrain all ports and ripple clocks. (Refer to “[Automatic Clock Detection](#)” on page 8–19.)

## Chapter Contents

“[Switching to the Quartus II TimeQuest Analyzer](#)” describes the four-step process you should follow to switch a design to the Quartus II TimeQuest Timing Analyzer.

“[Differences Between Quartus II TimeQuest and Quartus II Classic Timing Analyzers](#)” on page 8–5 covers terminology, constraints, clocks, hold multicycle, and other differences.

“[Timing Assignment Conversion](#)” on page 8–33 is a comprehensive guide to converting Quartus II Classic QSF timing assignments to Quartus II TimeQuest SDC constraints.

“[Conversion Utility](#)” on page 8–55 describes a utility that helps you convert Classic QSF timing assignments to the Quartus II TimeQuest SDC constraints.

“[Notes](#)” on page 8–68 includes notes about support for specific features in the current version of the Quartus II TimeQuest Timing Analyzer.

## Switching to the Quartus II TimeQuest Analyzer

You should use the following process to switch a design from the Quartus II Classic Timing Analyzer to the Quartus II TimeQuest Timing Analyzer. The process is composed of the following steps, which are described in detail in the next sections:

1. Compile your design and perform timing analysis with the Quartus II Classic Timing Analyzer ([page 8–2](#)).
2. Create an SDC file that contains timing constraints ([page 8–3](#)).
3. Perform timing analysis with the Quartus II TimeQuest Timing Analyzer and examine the reports ([page 8–4](#)).
4. Set the default timing analyzer to TimeQuest ([page 8–4](#)).

### Compile Your Design

To begin, compile your design with the Quartus® II software. You should run the Quartus II Classic Timing Analyzer during compilation because it is easier to convert your assignments to SDC constraints when you create an SDC file. To run the Quartus II Classic Timing Analyzer in the Quartus II GUI, on the Processing menu, click **Start**, then click **Start**

**Timing Analyzer.** To run the Quartus II Classic Timing Analyzer if you are a command-line user, type `quartus_tan <project>` ↵ at a system command prompt.

## Create an SDC File

The Quartus II TimeQuest Timing Analyzer supports SDC format constraints. If you are familiar with SDC terminology, you can create an SDC file with any text editor and skip to “[Perform Timing Analysis with the Quartus II TimeQuest Timing Analyzer](#)” on page 8–4. Name the SDC file `<revision>.sdc` (`<revision>` is the current revision of your project) and save it in your project directory.



Refer to the [SDC and TimeQuest Tcl API Reference Manual](#) for a TimeQuest SDC command reference.

Alternately, you can use a Quartus II TimeQuest conversion utility to help you convert the timing assignments in an existing QSF file to corresponding SDC constraints.

### Conversion Utility

To run the Quartus II TimeQuest conversion utility, click **Generate SDC file from QSF** on the Constraints menu. You can also run the conversion utility by typing either of the following commands at a system command prompt:

✓ `quartus_tan --qsf2sdc <project name>` ↵

or

✓ `quartus_sta --qsf2sdc <project name>` ↵

The SDC file created by the conversion utility is named `<revision>.sdc`.

For information about how to run the Quartus II TimeQuest Timing Analyzer, refer to “[Run the Quartus II TimeQuest Analyzer](#)” on page 8–4.



If you use the conversion utility, you must review the SDC file to ensure it is correct and complete, and make changes if necessary. Refer to “[Constraint File Priority](#)” on page 8–10 for the recommended way to make changes.

The conversion utility cannot convert some types of Quartus II Classic assignments for the following reasons:

- No corresponding SDC constraint exists

- Multiple SDC constraints are valid, so correct conversion requires knowledge of the intended function of your design

You must manually convert any such assignments based on the guidelines in “[Timing Assignment Conversion](#)” on page 8-33.

## Perform Timing Analysis with the Quartus II TimeQuest Timing Analyzer

When your SDC file is complete, use the reporting capabilities in the Quartus II TimeQuest Timing Analyzer. If you use the Quartus II TimeQuest GUI, double-click any of the reports listed in the **Task** pane. You can also type commands in the Quartus II TimeQuest Tcl shell to generate reports.

You should also review “[Notes](#)” on page 8-68 to ensure the Quartus II TimeQuest Timing Analyzer supports all stages of your design flow.



For complete information about how to use the Quartus II TimeQuest Timing Analyzer, and descriptions of commands and reports, refer to the *Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*, and the *SDC and TimeQuest Tcl API Reference Manual*.

### *Run the Quartus II TimeQuest Analyzer*

If you are using the Quartus II software, to open the Quartus II TimeQuest GUI, on the Tools menu, click **TimeQuest Timing Analyzer**. The Quartus II TimeQuest GUI automatically opens the project you have open in the Quartus II GUI.

If you use the system command prompt to open the Quartus II TimeQuest Timing Analyzer, type `quartus_staw ↵` to open the Quartus II TimeQuest GUI, or type `quartus_sta -s ↵` to start the Quartus II TimeQuest Timing Analyzer in Tcl shell mode. Use the `project_open` command to open your project, or, on the File menu, click **Open Project**.

### **Set the Default Timing Analyzer**

To use the Quartus II TimeQuest Timing Analyzer as the default timing analyzer for your project, turn on **Use TimeQuest Timing Analyzer during compilation**. In the Quartus II GUI, on the Assignments menu, click **Settings**, then click the **Timing Analysis Settings** category, and select **Use TimeQuest Timing Analyzer during compilation**. You can make the same setting in your project's QSF file with the following Tcl command:

```
set_global_assignment -name \
USE_TIMEQUEST_TIMING_ANALYZER ON
```

This setting directs the Quartus II software to use the Quartus II TimeQuest Timing Analyzer instead of the Quartus II Classic Timing Analyzer.

The setting to make the Quartus II TimeQuest Timing Analyzer the default Timing Analyzer is specific to each project, so you can decide on a per-project basis whether to use the Quartus II TimeQuest Timing Analyzer or the Quartus II Classic Timing Analyzer.

If you want to use the Quartus II Classic Timing Analyzer instead of the Quartus II TimeQuest timing analyzer, ensure **Use Classic Timing Analyzer during compilation** is selected. You can delete the <revision>.sdc file, because the Quartus II Classic Timing Analyzer does not use it.

In the Quartus II software, a timing analyzer performs two functions:

- Processing timing constraints and exceptions that affect how your design is placed and routed
- Reporting after place and route is complete so you know whether the design meets timing requirements

Although you can use one timing analyzer to process timing constraints during place and route and the other for reporting, you should use the same timing analyzer for both. The Quartus II Classic Timing Analyzer uses assignments in the QSF file, and the Quartus II TimeQuest Timing Analyzer uses constraints in the SDC file. Any differences between the timing assignments in the two files may cause inconsistent results.

## Differences Between Quartus II TimeQuest and Quartus II Classic Timing Analyzers

The Quartus II TimeQuest Timing Analyzer is different from the Quartus II Classic Timing Analyzer in the following ways:

- Terminology ([page 8-5](#))
- Constraints ([page 8-7](#))
- Clocks ([page 8-13](#))
- Hold Multicycle ([page 8-24](#))
- Fitter Behavior ([page 8-27](#))
- Reporting ([page 8-27](#))
- Scripting API ([page 8-32](#))

### Terminology

This section introduces the industry-standard SDC terminology that the Quartus II TimeQuest Timing Analyzer uses.



For more detailed information about this terminology, refer to the *Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

### Netlist

The Quartus II TimeQuest Timing Analyzer uses SDC naming conventions for netlists. Netlists consist of cells, pins, nets, ports, and clocks.

- Cells are instances of fundamental hardware elements in Altera® FPGAs (such as logic elements, look-up tables, and registers).
- Pins are inputs and outputs of cells.
- Nets are connections between output pins and input pins.
- Ports are top-level module inputs and outputs (device inputs and outputs).
- Clocks are abstract objects outside the netlist.



The terminology of pins and ports is opposite to that of the Quartus II Classic Timing Analyzer. In the Quartus II Classic Timing Analyzer, ports are inputs and outputs of cells, and pins are top-level module inputs and outputs (device inputs and outputs).

Figure 8–1 shows a simple design, and Figure 8–2 shows the Quartus II TimeQuest netlist representation of the design. Netlist elements in Figure 8–2 are labeled to illustrate the SDC terminology.

**Figure 8–1. Sample Design**



**Figure 8–2. Quartus II TimeQuest Timing Analyzer Netlist**

### Collections

In addition to standard SDC collections, the Quartus II TimeQuest Timing Analyzer supports the following Altera-specific collection types:

- **Keepers**—Non-combinational nodes in a netlist
- **Nodes**—Nodes can be combinational, registers, latches, or ports (device inputs and outputs)
- **Registers**—Registers or latches in the netlist

You can use the **get\_keepers**, **get\_nodes**, or **get\_registers** commands to access these collections.

### Constraints

The Quartus II Classic and Quartus II TimeQuest Timing Analyzers store constraints in different files, support different methods for constraint entry, and prioritize constraints differently. The following sections detail these differences.

#### Constraint Files

The Quartus II TimeQuest Timing Analyzer stores all SDC timing constraints in SDC files. The Quartus II Classic Timing Analyzer stores all timing assignments in your project's Quartus II Settings File (QSF) file. The QSF file contains all your project's assignments and settings except for the Quartus II TimeQuest Timing Analyzer constraints. The

Quartus II TimeQuest Timing Analyzer ignores the timing assignments in your QSF file except when the conversion utility converts Quartus II Quartus II Classic QSF timing assignments to Quartus II TimeQuest SDC constraints. There is no automatic process that keeps timing constraints synchronized between your QSF and SDC files. If you want to keep the constraints synchronized, you must convert them manually.

### *Constraint Entry*

In the Quartus II Classic Timing Analyzer, you enter timing assignments with the Settings dialog box, the Assignment Editor, or with commands in Tcl scripts. The Quartus II TimeQuest Timing Analyzer does not use the Assignment Editor for its constraints, and you cannot use the Assignment Editor to enter SDC constraints. You must use one of the following methods to enter Quartus II TimeQuest constraints:

- Enter constraints at the Tcl prompt in the Quartus II TimeQuest Timing Analyzer
- Enter constraints in an SDC file with a text editor or SDC editor
- Use the constraint entry commands on the Constraints menu in the Quartus II TimeQuest GUI

You can enter timing assignments for the Quartus II Classic Timing Analyzer even if no timing netlist exists for your design. The Quartus II TimeQuest Timing Analyzer requires that a netlist exist for interactive constraint entry. Each Quartus II TimeQuest Timing Analyzer constraint is a Tcl command evaluated in real-time, if entered directly in the Tcl console. As part of this evaluation, the Quartus II TimeQuest Timing Analyzer validates all names. To do this, SDC commands can only be evaluated after a netlist is created. An SDC file can be created at any time using the Quartus II TimeQuest Timing Analyzer or any other text editor, but a netlist is required before an SDC file can be sourced. You must create a timing netlist in the Quartus II TimeQuest Timing Analyzer before you can enter constraints with either of the following interactive methods:

- At the Tcl console of the Quartus II TimeQuest Timing Analyzer
- With commands on the Constraints menu in the Quartus II TimeQuest GUI

If you enter constraints with a text editor separate from the Quartus II TimeQuest Timing Analyzer, no timing netlist is required.

To create a timing netlist in the Quartus II TimeQuest Timing Analyzer, use the **create\_timing\_netlist** command, or double-click **Create Timing Netlist** in the Task pane of the Quartus II TimeQuest GUI.

If you have never compiled your design, and you want to use the Quartus II TimeQuest Timing Analyzer to enter constraints interactively, you must synthesize your design before you create a timing netlist. To synthesize your design, type `quartus_map <project name>` ↵ at a system command prompt, or, if you use the Quartus II GUI, ensure that your project is open, then click **Start** on the Processing menu, and click **Start Analysis and Synthesis**.

To create the netlist, open the Quartus II TimeQuest Timing Analyzer. Then, on the Netlist menu, click **Create Timing Netlist...**, select **Post-map**, and click **OK**. Alternately, type `create_timing_netlist -post_map` ↵ at the Tcl Console.

### Time Units

Enter time values are in default time units of nanoseconds (ns) with up to three decimal places. Note that the Quartus II TimeQuest Timing Analyzer does not display the default time unit when it displays time values.

You can specify a different default time unit with the `set_time_format -unit <default time unit>` command, or specify another unit when you enter a time value, for example, 300ps.

 Specifying time units with the value is not part of the standard SDC format. This is a Quartus II TimeQuest extension.

You can specify clock constraints with period or frequency in the Quartus II TimeQuest Timing Analyzer. For example, you can use either of the following constraints:

- `create_clock -period 10.000`  
(assuming default units and decimal places)
- `create_clock -period "100 MHz"`
- `create_clock -period "10 ns"`

### MegaCore Functions

If you change any MegaCore function settings and regenerate the core after you convert your timing assignments to SDC constraints, you must manually update the SDC constraints or reconvert your assignments. You must update or reconvert, because changes to MegaCore function settings can affect timing assignments embedded in the hardware description language files of the core. The timing assignments are not converted automatically when the core settings change.



You should make a backup copy of your SDC file before reconverting assignments. If you made changes to the SDC file, you can manually copy the updated MegaCore timing constraints to your SDC file.

### Bus Name Format

In the Quartus II Classic Timing Analyzer, you can make a timing assignment to all bits in a bus with the bus name (or the bus name followed by an asterisk enclosed in square brackets) as the target. For example, to make an assignment to all bits of a bus called address, use address or address [\*] as the target of the assignment.

In the Quartus II TimeQuest Timing Analyzer, you must use the bus name followed by square brackets enclosing an asterisk, like this: address [\*].

### *Constraint File Priority*

The Quartus II TimeQuest Timing Analyzer searches for SDC files with a specific priority, as shown in [Figure 8–3](#).

**Figure 8–3. SDC File Search Order**



If you specify constraints in multiple SDC files, or if you use a single SDC file with a name other than *<revision>.sdc*, you must add the files to your project so the Quartus II TimeQuest Timing Analyzer can find them. If you use the Quartus II software, click **Add/Remove Files in Project** on the Project menu, and add the appropriate SDC files. You can also add SDC files to your project with the following Tcl command in your QSF file, repeated once for each SDC file:

```
set_global_assignment -name SDC_FILE <SDC file name>
```

The Quartus II TimeQuest Timing Analyzer reads constraint files from the files list in the order they are listed, first to last.



If you use an SDC file created by the conversion utility, you should place it before all other SDC files in the list of files. When conflicting constraints apply to the same node, the last constraint has the highest priority. Therefore, SDC files with your additions or changes should be listed after the SDC file created by the conversion utility, so your constraints have higher priority.

Beginning with version 6.1, the Quartus II TimeQuest Timing Analyzer does not run the conversion utility automatically when it cannot find an SDC file according to the priority shown in [Figure 8–3](#). It may prompt you to run the conversion utility from the Constraints menu in the Quartus II TimeQuest GUI.



You must review the SDC file as you would when manually running the conversion utility. Refer to [“Reviewing Conversion Results” on page 8–64](#) for information about how to review the converted constraints.

If no SDC file exists when you run the Quartus II Fitter, and you have turned on **Use TimeQuest Timing Analyzer during compilation**, the Fitter does not create an SDC file automatically, but it attempts to meet a default 1 GHz constraint on all clocks in your design.

### *Constraint Priority*

The Quartus II Classic Timing Analyzer prioritizes assignments based on the specificity of the nodes to which they are assigned. The more specific an assignment is, the higher its priority. The Quartus II TimeQuest Timing Analyzer simplifies these precedence rules. When overlaps occur in the nodes to which the constraints apply, constraints at the bottom of the file take priority over constraints at the top of the file.

As an example, in the Quartus II Classic Timing Analyzer, point-to-point multicycle assignments have higher priority than single point multicycle assignments. The two assignments in [Example 8-1](#) result in a multicycle assignment of 2 between A\_reg and all nodes beginning with B, including B\_reg. The single point assignment does not apply to paths from A\_reg to B\_reg, because the specific point-to-point assignment takes priority over the general single point assignment.

---

**Example 8-1. Quartus II Classic Timing Analyzer Multicycle Assignments**

```
set_instance_assignment -name MULTICYCLE -from A_reg -to B* 2
set_instance_assignment -name MULTICYCLE -to B_reg 3
```

---

[Example 8-2](#) shows SDC versions of the Quartus II Classic Timing Analyzer timing assignments above. However, the Quartus II TimeQuest Timing Analyzer evaluates the constraints top to bottom (regardless of point-to-point or single point), so the path from A\_reg to B\_reg receives a multicycle exception of 3 because it is second in order.

---

**Example 8-2. Quartus II TimeQuest Timing Analyzer Multicycle Exceptions**

```
set_multicycle_path -from [get_keepers A_reg] -to [get_keepers B*] 2
set_multicycle_path -to [get_keepers B_reg] 3
```

---

### Ambiguous Constraints

Because of new capabilities in the Quartus II TimeQuest Timing Analyzer, some Quartus II Classic assignments can be ambiguous after conversion by the conversion utility. These assignments require manual updating based on your knowledge of your design.

[Figure 8-4](#) shows a ripple clock circuit. The explanation that follows shows an ambiguous constraint for that circuit, and how to edit the constraint to remove the ambiguity in the Quartus II TimeQuest Timing Analyzer.

---

**Figure 8-4. Ripple Clock Circuit**



In the Quartus II Classic Timing Analyzer, the following QSF multicycle assignment from `clk_a` to `clk_b` with a value of 2 applies to paths transferring data from the `clk_a` domain to the `clk_b` domain.

```
set_instance_assignment -name MULTICYCLE -from clk_a -to clk_b 2
```

In [Figure 8-4](#), this assignment applies to the path from `reg_c` to `reg_d`. In the Quartus II TimeQuest Timing Analyzer, the use of the clock node names in the following equivalent multicycle exception is ambiguous.

```
set_multicycle_path -setup -from clk_a -to clk_b 2
```

The exception could apply to the path between `clk_a` and `clk_b`, or it could apply to paths from one ripple clock domain to the other ripple clock domain (`reg_c` to `reg_d`).

The Quartus II TimeQuest exceptions shown in [Example 8-3](#) are not ambiguous because they use collections to explicitly specify the targets of the exception.

---

#### ***Example 8-3. Unambiguous Quartus II TimeQuest Timing Analyzer Exceptions***

```
# Applies to path from reg_c to reg_d
set_multicycle_path -setup -from [get_clocks clk_a] \
    -to [get_clocks clk_b] 2
# Applies to path from clk_a to clk_b
set_multicycle_path -setup -from [get_registers clk_a] \
    -to [get_registers clk_b] 2
```

---

## Clocks

The Quartus II Classic and Quartus II TimeQuest Timing Analyzers detect, analyze, and report clocks differently. The following sections describe these differences.

### *Related and Unrelated Clocks*

In the Quartus II TimeQuest Timing Analyzer, all clocks are related by default, and you must add assignments to indicate unrelated clocks. However, in the Quartus II Classic Timing Analyzer, all base clocks are unrelated by default. All derived clocks of a base clock are related to each other, but are unrelated to other base clocks and their derived clocks.



You can change the default behavior of the Quartus II Classic Timing Analyzer to treat all clocks as related clocks. On the Assignments menu, click **Timing Analysis Settings**. Click **More Settings** and then select **Cut paths between unrelated clock domains**. Ensure that the setting is off.

**Figure 8–5 on page 8–14** shows a simple circuit with a path between two clock domains. The Quartus II TimeQuest Timing Analyzer analyzes the path from `reg_a` to `reg_b` because all clocks are related by default. The Quartus II Classic Timing Analyzer does not analyze the path from `reg_a` to `reg_b` by default.

**Figure 8–5. Cross Clock Domain Path**



To make clocks unrelated in the Quartus II TimeQuest Timing Analyzer, use the `set_clock_groups` command with the `-exclusive` option. For example, the following command makes `clock_a` and `clock_b` unrelated, so the Quartus II TimeQuest Timing Analyzer does not analyze paths between the two clock domains.

```
set_clock_groups -exclusive -group {clock_a} -group {clock_b}
```

### Clock Offset

In the Quartus II TimeQuest Timing Analyzer, clocks can have non-zero values for the rising edge of the waveform, a feature that the Quartus II Classic Timing Analyzer does not support. To specify an offset for your clock, use the waveform option for the `create_clock` command to specify the rising and falling edge times, as shown in this example:

```
-waveform {<rising edge time> <falling edge time>}
```

Figure 8–6 shows a clock constraint with an offset in the Quartus II TimeQuest Timing Analyzer GUI.

**Figure 8–6. Create Clock Screen**



Clock offset affects setup and hold relationships. Launch and latch edges are evaluated after offsets are applied. Depending on the offset, the setup relationship can be the offset value, or the difference between the period and offset. You should not use clock offset to emulate latency. You should use the clock latency constraint instead. Refer to “[Offset and Latency Example](#)” on page 8–15 for an example that illustrates the different effects of offset and latency.

### *Clock Latency*

The Quartus II TimeQuest Timing Analyzer does not ignore early clock latency and late clock latency differences when the clock source is the same, as the Quartus II Classic Timing Analyzer does. When you specify latencies, you should take common clock path pessimism into account and use uncertainty to control pessimism differences for clock-to-clock data transfers. Unlike clock offset, clock latency affects skew, and launch and latch edges are evaluated before latencies are applied, so the setup relationship is always equal to the period.

### *Offset and Latency Example*

Figure 8–7 shows a simple register-to-register circuit used to illustrate the different effects of offset and latency. The examples show why you should not use clock offset to emulate clock latency. You should always turn on

the **Enable Clock Latency** option in the Quartus II Classic Timing Analyzer. This option is in the **More Settings** box of the **Timing Settings** dialog box.

**Figure 8-7. Simple Circuit for Offset and Latency Examples**



The period for `clk` is 10 ns, and the period for the PLL output is 10 ns. The PLL compensation value is -2 ns. The network delay from the PLL to `reg_a` equals the network delay from `clk` to `reg_b`. Finally, the delay from `reg_a` to `reg_b` is 3 ns.

#### Clock Offset Scenario

Treat the PLL compensation value of -2 ns as a clock offset of -2 ns with a clock skew of 0 ns. Launch and latch edges are evaluated after offsets are applied, so the setup relationship is 2 ns (Figure 8-8).

**Figure 8-8. Setup Relationship Using Offset**



Equation 1 shows how to calculate the slack value for the path from `reg_a` to `reg_b`.

$$\begin{aligned}(1) \quad \text{slack} &= \text{clock arrival} - \text{data arrival} \\ \text{slack} &= \text{setup relationship} + \text{clock skew} - \text{reg\_to\_reg delay} \\ \text{slack} &= 2\text{ns} + 0\text{ns} - 3\text{ns} \\ \text{slack} &= -1\text{ns}\end{aligned}$$

The negative slack requires a multicycle assignment with a value of 2 and a hold multicycle assignment with a value of 1 to correct. With these assignments from `reg_a` to `reg_b`, the setup relationship is then 12 ns, resulting in a slack of 9 ns.

### Clock Latency Scenario

Treat the PLL compensation value of -2 ns as latency with a clock skew of 2 ns. Because launch and latch edges are evaluated before latencies are applied, the setup relationship is 10 ns (the period of `clk` and the PLL) (Figure 8-9).

---

**Figure 8-9. Setup Relationship Using Latency**



Equation 2 shows how to calculate the slack value for the path from `reg_a` to `reg_b`.

$$\begin{aligned}(2) \quad \text{slack} &= \text{clock arrival} - \text{data arrival} \\ \text{slack} &= \text{setup relationship} + \text{clock skew} - \text{reg\_to\_reg delay} \\ \text{slack} &= 10\text{ns} + 2\text{ns} - 3\text{ns} \\ \text{slack} &= 9\text{ns}\end{aligned}$$

The slack of 9 ns is identical to the slack computed in the previous example, but because this example uses latency instead of offset, no multicycle assignment is required.

### Clock Uncertainty

The Quartus II Classic Timing Analyzer ignores **Clock Setup Uncertainty** and **Clock Hold Uncertainty** assignments when you specify a setup or hold relationship between two clocks. However, the Quartus II TimeQuest Timing Analyzer does not ignore clock uncertainty when you specify a setup or hold relationship between two clocks. Figures 8–10 and 8–11 illustrate the different behavior between the Quartus II TimeQuest and Quartus II Classic Timing Analyzers.

In both figures, the constraints are identical. There is a 20-ns period for `clk_a` and `clk_b`. There is a setup relationship (a `set_max_delay` exception in the Quartus II TimeQuest Timing Analyzer) of 7 ns from `clk_a` to `clk_b`, and a clock setup uncertainty constraint of 1 ns from `clk_a` to `clk_b`. The actual setup relationship in the Quartus II TimeQuest Timing Analyzer is 1 ns less than in the Quartus II Classic Timing Analyzer because of the way they analyze clock uncertainty.

**Figure 8–10. Quartus II Classic Timing Analyzer Behavior**



**Figure 8–11. Quartus II TimeQuest Timing Analyzer Behavior**



### Derived and Generated Clocks

Generated clocks in the Quartus II TimeQuest Timing Analyzer are different than derived clocks in the Quartus II Classic Timing Analyzer. In the Quartus II Classic Timing Analyzer, the source of a derived clock must be a base clock. However, in the Quartus II TimeQuest Timing Analyzer, the source of a generated clock can be any other clock in the design (including virtual clocks), or any node to which a clock propagates through the clock network. Because generated clocks are related through the clock network, you can specify generated clocks for isolated modules, such as IP, without knowing the details of the clocks outside of the module.

In the Quartus II TimeQuest Timing Analyzer, you can specify generated clocks relative to specific edges and edge shifts of a master clock, a feature that the Quartus II Classic Timing Analyzer does not support.

Figure 8–12 shows a simple ripple clock that you should constrain with generated clocks in the Quartus II TimeQuest Timing Analyzer.

---

**Figure 8–12. Generated Clocks Circuit**



---

The Quartus II TimeQuest Timing Analyzer constraints shown in Example 8–4 constrain the clocks in the circuit above. Note that the source of each generated clock can be the input pin of the register itself, not the name of another clock.

---

**Example 8–4. Generated Clock Constraints**

```
create_clock -period 10 -name clk clk
create_generated_clock -divide_by 2 -source reg_a|CLK -name reg_a reg_a
create_generated_clock -divide_by 2 -source reg_b|CLK -name reg_b reg_b
```

---

### Automatic Clock Detection

The Quartus II Classic and Quartus II TimeQuest Timing Analyzers identify clock sources of registers that do not have a defined clock source. The Quartus II Classic Timing Analyzer traces back along the clock

network, through registers and logic, until it reaches a top-level port in your design. The Quartus II TimeQuest Timing Analyzer also traces back along the clock network, but it stops at registers.

You can use two SDC commands in the Quartus II TimeQuest Timing Analyzer to automatically detect and create clocks for unconstrained clock sources:

- **derive\_clocks**—creates clocks on sources of clock pins that do not already have at least one clock sourcing the clock pin
- **derive\_pll\_clocks**—identifies PLLs and creates generated clocks on the clock output pins

#### **derive\_clocks** Command

Figure 8–13 shows a simple circuit with a divide-by-2 register and indicates the clock network delays as A, B, and C. The following explanation describes how the Quartus II Classic and Quartus II TimeQuest Timing Analyzers detect the clocks in Figure 8–13.

**Figure 8–13. Circuit for *derive\_clocks* Example**



The Quartus II Classic Timing Analyzer detects that `clk` is the clock source for registers `reg_a`, `reg_b`, and `reg_c`. It detects that `clk` is the clock source for `reg_c` because it traces back along the clock network for `reg_c` through `reg_a`, until it finds the `clk` port. The Quartus II Classic Timing Analyzer computes the clock arrival time for `reg_c` as  $A + C$ .

The **derive\_clocks** command in the Quartus II TimeQuest Timing Analyzer creates two base clocks, one on the `clk` port and one on `reg_a`, because the command does not trace through registers on the clock network. The clock arrival time for `reg_c` is  $C$  because the clock starts at `reg_a`.

To make the Quartus II TimeQuest Timing Analyzer compute the same clock arrival time ( $A + C$ ) as the Quartus II Classic Timing Analyzer for **reg\_c**, make the following modifications to the clock constraints created by the **derive\_clocks** command:

- Change the base clock named **reg\_a** to a generated clock
- Make the source the clock pin of **reg\_a** (**reg\_a|clk**) or the port **clk**
- Add a **-divide\_by 2** option

These modifications cause the clock arrival times to **reg\_c** to match between the Quartus II Classic Timing Analyzer and the Quartus II TimeQuest Timing Analyzer. However, the clock for **reg\_c** is shown as **reg\_a** instead of **clk**, and the launch and latch edges may change for some paths due to the divide-by-2.

You can use the **derive\_clocks** command at the beginning of your design cycle when you do not know all of the clock constraints for your design, but you should not use it during timing sign-off. Instead, you should constrain each clock in your design with the **create\_clock** or **create\_generated\_clocks** commands.

The **derive\_clocks** command detects clocks in your design using the following rules:

1. An input clock port is detected as a clock only if there are no other clocks feeding the destination registers.
  - a. Input clock ports are not detected automatically if they feed only other base clocks.
  - b. If other clocks feed the port's register destinations, the port is assumed to be an enable or data port for a gated clock.
  - c. When no clocks are defined, and multiple clocks feed a destination register, the auto-detected clock is selected arbitrarily.
2. All ripple clocks (registers in a clock path) are detected as clocks automatically using the same rules for input clock ports. If both an input port and a register feed register clock pins, the input port is selected as the clock.

The following examples show how the **derive\_clocks** command detects clocks in the simple circuit, shown in [Figure 8–14](#).

**Figure 8–14. Simple Circuit 1**



- If you do not make any clock settings, and then you run **derive\_clocks**, it detects **a\_in** as a clock according to rule 1, because there are no other clocks feeding the register.
- If you create a clock with **b** as its target, and then you run **derive\_clocks**, it does not detect **a\_in** as a clock according to rule 1a, because **a\_in** feeds only another clock.

The following examples show how the **derive\_clocks** command detects clocks in the simple circuit shown in [Figure 8–15](#).

**Figure 8–15. Simple Circuit 2**



- If you do not make any clock settings and then you run **derive\_clocks**, it selects a clock arbitrarily, according to rule 1c.
- If you create a clock with **a\_in** as its target and then you run **derive\_clocks**, it does not detect **b\_in** as a clock according to rule 1b, because another clock (**a\_in**) feeds the register.

#### **derive\_pll\_clocks** Command

The **derive\_pll\_clocks** command names the generated clocks according to the names of the PLL output pins by default, and you cannot change these generated clock names. If you want to use your own clock names, you must use the **create\_generated\_clock** command for each PLL output clock and specify the names with the **-name** option.

If you use the PLL clock-swtichover feature, the **derive\_pll\_clocks** command creates additional generated clocks on each output clock pin of the PLL based on the secondary clock input to the PLL. This may require **set\_clock\_groups** or **set\_false\_path** commands to cut the primary and secondary clock outputs. For information about how to make clocks unrelated, refer to “[Related and Unrelated Clocks](#)” on page 8–13.

### Hold Relationship

The Quartus II TimeQuest and Quartus II Classic Timing Analyzers choose the worst-case hold relationship differently. Refer to [Figure 8–16](#) for sample waveforms to illustrate the different effects.

**Figure 8–16. Worst-Case Hold**



The Quartus II Classic Timing Analyzer first identifies the worst-case setup relationship. The worst-case setup relationship is **Setup B**. Then the Quartus II Classic Timing Analyzer chooses the worst-case hold relationship (Hold Check B1 or Hold Check B2) for that specific setup relationship, Setup B. The Quartus II Classic Timing Analyzer chooses Hold Check B2 for the worst-case hold relationship.

However, the Quartus II TimeQuest Timing Analyzer calculates worst-case hold relationships for all possible setup relationships and chooses the absolute worst-case hold relationship. The Quartus II TimeQuest Timing Analyzer checks two hold relationships for every setup relationship:

- Data launched by the current launch edge not captured by the previous latch edge (Hold Check A1 and Hold Check B1)
- Data launched by the next launch edge not captured by the current latch edge (Hold Check A2 and Hold Check B2)

The Quartus II TimeQuest Timing Analyzer chooses Hold Check A2 as the absolute worst-case hold relationship.

### Clock Objects

The Quartus II Classic Timing Analyzer treats nodes with clock settings assigned to them as special objects in the timing netlist. Any node in the timing netlist with a clock setting is treated as a clock object, regardless of its actual type, such as a register. When a register has a clock setting

assigned to it, the Quartus II Classic Timing Analyzer does not analyze register-to-register paths beginning or ending at that register. [Figure 8-17](#) shows a circuit that illustrates this situation.

**Figure 8-17. Clock Objects**



With no clock assignments on any of the registers, the Quartus II Classic Timing Analyzer analyzes timing on the path from `reg_a` to `reg_b`, and from `reg_c` to `reg_d`. If you make a clock setting assignment to `reg_b`, `reg_b` is no longer considered a register node in the netlist, and the path from `reg_a` to `reg_b` is no longer analyzed.

In the Quartus II TimeQuest Timing Analyzer, clocks are abstract objects that are associated with nodes in the timing netlist. The Quartus II TimeQuest Timing Analyzer analyzes the path from `reg_a` to `reg_b` even if there is a clock assigned to `reg_b`.

## Hold Multicycle

The hold multicycle value numbering scheme is different in the Quartus II Classic and Quartus II TimeQuest Timing Analyzers. Also, you can choose between two values for the default hold multicycle value in the Quartus II Classic Timing Analyzer but you cannot change the default value in the Quartus II TimeQuest Timing Analyzer. The hold multicycle value specifies which clock edge is used for hold analysis when you change the latch edge with a multicycle assignment.

In the Quartus II Classic Timing Analyzer, the hold multicycle value is based on 1, and is the number of clock cycles away from the setup edge. In the Quartus II TimeQuest Timing Analyzer, the hold multicycle value is based on zero, and is the number of clock cycles away from the default hold edge. In the Quartus II TimeQuest Timing Analyzer, the default hold edge is one edge before or after the setup edges. Subtract 1 from any hold multicycle value in the Quartus II Classic Timing Analyzer to compute the equivalent value for the Quartus II TimeQuest Timing Analyzer.

In the Quartus II Classic Timing Analyzer, you can set the default value of the hold multicycle assignment to **One** or **Same as Multicycle**. The default value applies to any multicycle assignment in your design that does not also have a multicycle hold assignment. [Figure 8-18](#) illustrates the difference between **One** and **Same as Multicycle** for a multicycle assignment of 2 using the Quartus II Classic Timing Analyzer.

---

**Figure 8-18. Difference Between One and Same As Multicycle**



---

If the default value is **One**, the Quartus II Classic Timing Analyzer uses the clock edge one before the setup edge for hold analysis. If the default value is **Same as Multicycle**, the Quartus II Classic Timing Analyzer uses the clock edge that is *<value of multicycle assignment>* edges back from the setup edge.

[Figure 8-19](#) shows simple waveforms for a cross-clock domain transfer with the indicated setup and hold edges.

---

**Figure 8-19. First Relationship Example**



---

In the Quartus II TimeQuest Timing Analyzer, only a multicycle exception of 2 is required to constrain the design for the indicated setup and hold relationships.

In the Quartus II Classic Timing Analyzer, if the **Default Hold Multicycle** value is **One**, only a multicycle assignment of 2 is required to constrain the design.

In the Quartus II Classic Timing Analyzer, if the **Default Hold Multicycle** value is **Same as Multicycle**, you must make two assignments to constrain the design:

- A multicycle assignment of 2
- A hold multicycle assignment of 1 to override the default value

Figure 8–20 shows simple waveforms for a different cross-clock domain transfer with indicated setup and hold edges. The following explanation shows what exceptions to apply to achieve the desired setup and hold relationships.

**Figure 8–20. Second Relationship Example**



In the Quartus II TimeQuest Timing Analyzer, you must use the following two exceptions:

- A multicycle exception of 2
- A hold multicycle exception of 1, because the hold edge is one edge behind the default hold edge, which is one edge after the setup edge.

In the Quartus II Classic Timing Analyzer, if the **Default Hold Multicycle** value is **One**, you must make two assignments to constrain the design:

- A multicycle assignment of 2
- A hold multicycle assignment of 2 to override the default value

In the Quartus II Classic Timing Analyzer, if the **Default Hold Multicycle** value is **Same as Multicycle**, only a multicycle assignment of 2 is required to constrain the design.



You should always add a hold multicycle assignment for every multicycle assignment to ensure the correct exceptions are applied regardless of the timing analyzer you use, or, for the Quartus II Classic Timing Analyzer, the **Default Hold Multicycle** setting.

## Fitter Behavior

The behavior for one value of the **Optimize hold time** Fitter assignment differs between the Quartus II TimeQuest Timing Analyzer and the Quartus II Classic Timing Analyzer. When you set the Quartus II TimeQuest Timing Analyzer as the default timing analyzer, the **I/O Paths and Minimum TPD Paths** value directs the Fitter to optimize all hold time paths, which has the same affect as the **All Paths** value.

### *Fitter Performance*

If you use the Quartus II TimeQuest Timing Analyzer as your default timing analyzer, the Fitter memory use and compilation time may increase. However, the timing analysis time may decrease.

## Reporting

The Quartus II TimeQuest Timing Analyzer provides a more flexible and powerful interface for reporting timing analysis results than the Quartus II Classic Timing Analyzer. Although the interface and constraints are more flexible and powerful, both analyzers use the same device timing models, except for device families that support rise/fall analysis. The Quartus II Classic Timing Analyzer does not support rise/fall analysis, but the Quartus II TimeQuest Timing Analyzer does. Therefore, you may see slightly different delays on identical paths in device families that support rise/fall analysis if you analyze timing in both analyzers.

This means that both analyzers report identical delays along identically constrained paths in your design. The Quartus II TimeQuest Timing Analyzer allows you to constrain some paths that you could not constrain with the Quartus II Classic Timing Analyzer. Differently constrained paths result in different reported values, but for identical paths in your design that are constrained the same way, the delays are exactly the same. Both timing analyzers use the same timing models.



For information about reporting with the Quartus II TimeQuest Timing Analyzer, refer to the *Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

### Paths and Pairs

In reporting, the most significant difference between the two analyzers is that the Quartus II TimeQuest Timing Analyzer reports paths, while the Quartus II Classic Timing Analyzer reports pairs. Path reporting means that the analyzer separately reports every path between two registers. Pair reporting means that the analyzer reports only the worst-case path between two registers. One benefit of path reporting over pair reporting is that you can more easily identify common points in failing paths that may be good targets for optimization.

If your design does not meet timing constraints, this reporting difference can give the impression that there are many more timing failures when you use the Quartus II TimeQuest Timing Analyzer. [Figure 8-21](#) shows a sample circuit followed by a description of the differences between path and pair reporting.

**Figure 8-21. Failing Paths**



There is an 8-ns period constraint on `clk`, resulting in two paths that fail timing: `regA → C → regB` and `regA → D → regB`. The Quartus II Classic Timing Analyzer reports only worst-case path `regA → C → regB`. The Quartus II TimeQuest Timing Analyzer reports both failing paths `regA → C → regB` and `regA → D → regB`. It also reports path `regA → E → regB` with positive slack.

### Default Reports

The Quartus II TimeQuest Timing Analyzer generates only a small number of reports by default, as compared to the Quartus II Classic Timing Analyzer, which generates every report by default. With the Quartus II TimeQuest Timing Analyzer, you generate desired reports on demand.



To learn how to create custom reports, refer to the [Quartus II TimeQuest Timing Analyzer](#) chapter in volume 3 of the [Quartus II Handbook](#).

### *Netlist Names*

The Quartus II Classic Timing Analyzer uses register names in reporting, but the Quartus II TimeQuest Timing Analyzer uses register pin names (with the exception of port names of the top-level module). Buried nodes or register names are used when necessary.

**Example 8-5** shows how register names are used in Quartus II Classic Timing Analyzer reports.

---

#### **Example 8-5. Netlist Names in the Quartus II Classic Timing Analyzer**

```
Info: + Shortest register to register delay is 0.538 ns
      Info: 1: + IC(0.000 ns) + CELL(0.000 ns) = 0.000 ns; Loc. =
LCFF_X1_Y5_N1;
Fanout = 1; REG Node = 'inst'
      Info: 2: + IC(0.305 ns) + CELL(0.149 ns) = 0.454 ns; Loc. =
LCCOMB_X1_Y5_N20; Fanout = 1; COMB Node = 'inst3~feeder'
      Info: 3: + IC(0.000 ns) + CELL(0.084 ns) = 0.538 ns; Loc. =
LCFF_X1_Y5_N21; Fanout = 1; REG Node = 'inst3'
      Info: Total cell delay = 0.233 ns ( 43.31 % )
      Info: Total interconnect delay = 0.305 ns ( 56.69 % )
```

---

**Example 8-6** shows the same information as presented in a Quartus II TimeQuest Timing Analyzer report. In this example, register pin names are used in place of register names.

---

#### **Example 8-6. Netlist Names in the Quartus II TimeQuest Timing Analyzer**

```
Info:      3.788      0.250    uTco  inst
Info:      3.788      0.000    RR    CELL  inst|regout
Info:      4.093      0.305    RR    IC    inst3~feeder|datad
Info:      4.242      0.149    RR    CELL  inst3~feeder|combout
Info:      4.242      0.000    RR    IC    inst3|datain
Info:      4.326      0.084    RR    CELL  inst3
```

---

### *Non-Integer Clock Periods*

In some cases when related clock periods are not integer multiples of each other, a lack of precision in clock period definition in the Quartus II TimeQuest Timing Analyzer can result in reported setup or hold relationships of a few picoseconds. In addition, launch and latch times for the relationships can be very large. If you experience this, use the **set\_max\_delay** and **set\_min\_delay** exceptions to specify the correct relationships. The Quartus II Classic Timing Analyzer can maintain additional information about clock frequency that mitigates the lack of precision in clock period definition.

When the clock period cannot be expressed as an integer in terms of picoseconds, then you have the problem detailed in [Figure 8–22](#). This figure shows two clocks: `clk_a` has a 10 ns period, and `clk_b` has a 6.667 ns period.

**Figure 8–22. Very Small Setup Relationship**



There is a 1 ps setup relationship at 20 ns because you cannot specify the 6.667 ns period beyond picosecond precision. You should apply the maximum and minimum delay exceptions shown in [Example 8–7](#) between the two clocks to specify the correct relationships.

---

**Example 8–7. Minimum and Maximum Delay Exceptions**

```
set_max_delay -from [get_clocks clk_a] -to [get_clocks clk_b] 3.333
set_min_delay -from [get_clocks clk_a] -to [get_clocks clk_b] 0
```

---

### Other Features

The Quartus II TimeQuest Timing Analyzer reports time values without units. By default, the units are nanoseconds, and three decimal places are displayed. You can change the default time unit and decimal places with the `set_time_format` command.

When you use the Quartus II TimeQuest Timing Analyzer in a Tcl shell, output is ASCII-formatted, and columns are aligned for easy reading on 80-column consoles. [Example 8–8](#) shows sample output from a `report_timing` command from the Quartus II TimeQuest Timing Analyzer.

**Example 8-8. ASCII-Formatted Quartus II TimeQuest Timing Analyzer Report**

```
tcl> report_timing -from inst -to inst5
Info: Report Timing: Found 1 setup paths (0 violated). Worst case slack is 3.634
  Info: -from [get_keepers inst]
  Info: -to [get_keepers inst5]
Info: Path #1: Slack is 3.634
  Info: =====
  Info: From Node    : inst
  Info: To Node     : inst5
  Info: Launch Clock : clk_a
  Info: Latch Clock  : clk_b
  Info:
  Info: Data Arrival Path:
  Info:
  Info: Total (ns)  Incr (ns)      Type  Node
  Info: =====  =====  =====  =====
  Info:      0.000      0.000      launch edge time
  Info:      2.347      2.347      R      clock network delay
  Info:      2.597      0.250      uTco  inst
  Info:      2.597      0.000      RR     CELL   inst|regout
  Info:      3.088      0.491      RR     IC     inst6|datac
  Info:      3.359      0.271      RR     CELL   inst6|combout
  Info:      3.359      0.000      RR     IC     inst5|datain
  Info:      3.443      0.084      RR     CELL   inst5
  Info:
  Info: Data Required Path:
  Info:
  Info: Total (ns)  Incr (ns)      Type  Node
  Info: =====  =====  =====  =====
  Info:      4.000      4.000      launch edge time
  Info:      7.041      3.041      R      clock network delay
  Info:      7.077      0.036      uTsu  inst5
  Info:
  Info: Data Arrival Time  :      3.443
  Info: Data Required Time :      7.077
  Info: Slack              :      3.634
  Info: =====
  Info:
```

---

1 3.634

## Scripting API

In versions of the Quartus II software earlier than 6.0, the **::quartus::project** Tcl package contained the following SDC-like commands for making timing assignments:

- `create_base_clock`
- `create_relative_clock`
- `get_clocks`
- `set_clock_latency`
- `set_clock_uncertainty`
- `set_input_delay`
- `set_multicycle_assignment`
- `set_output_delay`
- `set_timing_cut_assignment`

These commands are not SDC-compliant. Beginning with version 6.0, these commands are in a new package called **::quartus::timing\_assignment**. To ensure backward compatibility with existing Tcl scripts, the **::quartus::timing\_assignment** package is loaded by default in the following executables:

- `quartus`
- `quartus_sh`
- `quartus_cdb`
- `quartus_sim`
- `quartus_stp`
- `quartus_tan`

The **::quartus::timing\_assignment** package is not loaded by default in the **quartus\_sta** executable. The **::quartus::sdc** Tcl package includes SDC-compliant versions of the commands listed above. That package is available only in the **quartus\_sta** executable, and it is loaded by default.

# Timing Assignment Conversion

This section describes Quartus II Classic QSF timing assignments and their equivalent Quartus II TimeQuest constraints. You can convert many Quartus II Classic timing assignments to SDC constraints. Some Quartus II Classic timing assignments can be converted to two different SDC constraints, and you must understand the intended functionality of the design to make an appropriate conversion. You cannot convert some Quartus II Classic timing assignments because there is no equivalent SDC constraint.

This section includes the following topics, arranged alphabetically:

|                                             |      |
|---------------------------------------------|------|
| Clock Enable Multicycle .....               | 8-38 |
| Clock Latency .....                         | 8-34 |
| Clock Settings .....                        | 8-37 |
| Clock Uncertainty .....                     | 8-34 |
| Cut Timing Path .....                       | 8-52 |
| Default Required $f_{MAX}$ Assignment ..... | 8-35 |
| Hold Relationship .....                     | 8-34 |
| Input and Output Delay .....                | 8-39 |
| Inverted Clock .....                        | 8-35 |
| Maximum Clock Arrival Skew .....            | 8-53 |
| Maximum Data Arrival Skew .....             | 8-53 |
| Maximum Delay .....                         | 8-52 |
| Minimum Delay .....                         | 8-52 |
| Minimum $t_{CO}$ Requirement .....          | 8-48 |
| Minimum $t_{PD}$ Requirement .....          | 8-51 |
| Multicycle .....                            | 8-37 |
| Not a Clock .....                           | 8-35 |
| Setup Relationship .....                    | 8-33 |
| $t_{CO}$ Requirement .....                  | 8-45 |
| $t_H$ Requirement .....                     | 8-43 |
| $t_{PD}$ Requirement .....                  | 8-50 |
| $t_{SU}$ Requirement .....                  | 8-40 |
| Virtual Clock Reference .....               | 8-36 |

## Setup Relationship

The **Setup Relationship** assignment overrides the setup relationship between two clocks. By default, the Quartus II Classic Timing Analyzer automatically calculates the setup relationship based on your clock settings. The QSF variable for the **Setup Relationship** assignment is `SETUP_RELATIONSHIP`. In the Quartus II TimeQuest Timing Analyzer, use the `set_max_delay` command to specify the maximum setup relationship for a path.

The setup relationship value is the time between latch and launch edges before the Quartus II TimeQuest Timing Analyzer accounts for clock latency, source  $\mu t_{CO}$ , or destination  $\mu t_{SU}$ .

## Hold Relationship

The **Hold Relationship** assignment overrides the hold relationship between two clocks. By default, the Quartus II Classic Timing Analyzer automatically calculates the hold relationship based on your clock settings. The QSF variable for the **Hold Relationship** assignment is **HOLD\_RELATIONSHIP**. In the Quartus II TimeQuest Timing Analyzer, use the **set\_min\_delay** command to specify the minimum hold relationship for a path.

## Clock Latency

Table 8-1 shows the equivalent SDC constraints for each of these Quartus II Classic assignments.

| <b>Table 8-1. Quartus II Classic and SDC Equivalent Constraints</b> |                     |                                  |
|---------------------------------------------------------------------|---------------------|----------------------------------|
| <b>Quartus II Classic Timing Assignment</b>                         |                     | <b>SDC Constraint</b>            |
| <b>Assignment Name</b>                                              | <b>QSF Variable</b> |                                  |
| Early Clock Latency                                                 | EARLY_CLOCK_LATENCY | set_clock_latency -source -late  |
| Late Clock Latency                                                  | LATE_CLOCK_LATENCY  | set_clock_latency -source -early |

For more information about clock latency support in the Quartus II TimeQuest Timing Analyzer, refer to “[Clock Latency](#)” on page 8-15.

## Clock Uncertainty

This section describes the conversion for the following Quartus II Classic assignments:

- Clock Setup Uncertainty
- Clock Hold Uncertainty

Table 8–2 shows the equivalent SDC constraints for each of these Quartus II Classic assignments.

| <b>Table 8–2. Quartus II Classic and SDC Equivalent Constraints</b> |                         |                              |
|---------------------------------------------------------------------|-------------------------|------------------------------|
| <b>Quartus II Classic Timing Assignment</b>                         |                         | <b>SDC Constraint</b>        |
| <b>Assignment Name</b>                                              | <b>QSF Variable</b>     |                              |
| Clock Setup Uncertainty                                             | CLOCK_SETUP_UNCERTAINTY | set_clock_uncertainty -setup |
| Clock Hold Uncertainty                                              | CLOCK_HOLD_UNCERTAINTY  | set_clock_uncertainty -hold  |

### Inverted Clock

The Quartus II Classic Timing Analyzer detects inverted clocks automatically when the clock inversion occurs at the input of the LCELL that contains the register specified in the assignment. You must make an **Inverted Clock** assignment in all other situations for Quartus II Classic Timing Analyzer analysis. The QSF variable for the **Inverted Clock** assignment is INVERTED\_CLOCK. The Quartus II TimeQuest Timing Analyzer detects inverted clocks automatically, regardless of the type of inversion circuit, in designs that target device families that support unateness: Stratix® II, Cyclone® II, and HardCopy® II. For designs that target any other device family, you must create a generated clock with the -invert option on the output of the cell that inverts the clock.



For more information about unateness, refer to the *Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

### Not a Clock

The **Not a Clock** assignment directs the Quartus II Classic Timing Analyzer that the specified node is not a clock source when it would normally be detected as a clock because of a global  $f_{MAX}$  requirement. The QSF variable for the **Not a Clock** assignment is NOT\_A\_CLOCK. This assignment is not supported in the Quartus II TimeQuest Timing Analyzer and there is no equivalent constraint. Appropriate clock constraints are created in the Quartus II TimeQuest Timing Analyzer only.

### Default Required $f_{MAX}$ Assignment

The **Default Required  $f_{MAX}$**  assignment allows you to specify an  $f_{MAX}$  requirement for the Quartus II Classic Timing Analyzer for all unconstrained clocks in your design. The QSF variable for the **Default Required  $f_{MAX}$**  assignment is FMAX\_REQUIREMENT. You can use the

**derive\_clocks** command to create clocks on sources of clock pins in your design that do not already have clocks assigned to them. You should constrain each individual clock in your design with the **create\_clock** or **create\_generated\_clock** command, not the **derive\_clocks** command. Refer to “[Automatic Clock Detection](#)” on page [8-19](#) to learn why you should constrain individual clocks in your design.

## Virtual Clock Reference

The **Virtual Clock Reference** assignment allows you to define timing characteristics of a reference clock outside the FPGA. The QSF variable for the **Virtual Clock Reference** assignment is **VIRTUAL\_CLOCK\_REFERENCE**. The Quartus II TimeQuest Timing Analyzer supports virtual clocks by default, while the Quartus II Classic Timing Analyzer requires the **Virtual Clock Reference** assignment to indicate that a clock setting is for a virtual clock. To create a virtual clock in the Quartus II TimeQuest Timing Analyzer, use the **create\_clock** or **create\_generated\_clock** commands with the **-name** option and no targets.

[Figure 8-23](#) shows a simple circuit that requires a virtual clock, and the following example shows how to constrain the circuit. The circuit shows data transfer between an Altera FPGA and another device, and the clocks for the two devices are not related. You can constrain the path with an output delay assignment, but that assignment requires a virtual clock that defines the clock characteristics of the destination device.

**Figure 8-23. Virtual Clock Sample Circuit**



Assume the circuit has the following assignments in the Quartus II Classic Timing Analyzer:

- Clock period of 10 ns on **system\_clk** (clock for the Altera FPGA)
- Clock period of 8 ns on **virt\_clk** (clock for the other device)
- Virtual Clock Reference setting for **virt\_clk** is on (indicates that **virt\_clk** is a virtual clock)

- Output Maximum Delay of 5 ns on dataout with respect to virt\_clk (constrains the path between the two devices)

The SDC commands shown in [Example 8–9](#) constrain the circuit the same way.

#### **Example 8–9. SDC Constraints**

```
# Clock for the Altera FPGA
create_clock -period 10 -name system_clk [get_ports system_clk]
# Virtual clock for the other device, with no targets
create_clock -period 8 -name virt_clk
# Constrains the path between the two devices
set_output_delay -clock virt_clk 5 [get_ports dataout]
```

## Clock Settings

The Quartus II Classic Timing Analyzer includes a variety of assignments to describe clock settings. These include duty cycle,  $f_{MAX}$ , offset, and others. In the Quartus II TimeQuest Timing Analyzer, use the `create_clock` and `create_generated_clock` commands to constrain clocks.

## Multicycle

[Table 8–3](#) shows the equivalent SDC exceptions for each of these Quartus II Classic Timing Analyzer timing assignments.

**Table 8–3. Quartus II Classic and SDC Equivalent Exceptions**

| Quartus II Classic Timing Assignment  |                     | SDC Exception                     |
|---------------------------------------|---------------------|-----------------------------------|
| Assignment Name                       | QSF Variable        |                                   |
| Multicycle <a href="#">(1)</a>        | MULTICYCLE          | set_multicycle_path -setup -end   |
| Source Multicycle <a href="#">(2)</a> | SRC_MULTICYCLE      | set_multicycle_path -setup -start |
| Multicycle Hold <a href="#">(3)</a>   | HOLD_MULTICYCLE     | set_multicycle_path -hold -end    |
| Source Multicycle Hold                | SRC_HOLD_MULTICYCLE | set_multicycle_path -hold -start  |

*Notes to Table 8–3:*

- (1) A multicycle assignment is also known as a “destination multicycle setup” assignment.
- (2) A source multicycle assignment is also known as a “source multicycle setup” assignment.
- (3) A multicycle hold is also known as a “destination multicycle hold” assignment.

The default value and numbering scheme for the hold multicycle value is different in the Quartus II Classic and Quartus II TimeQuest Timing Analyzers. Refer to [“Hold Multicycle” on page 8–24](#) for more information

about the difference between the default value and numbering scheme for the hold multicycle value in the Quartus II Classic and Quartus II TimeQuest Timing Analyzers.



For more information about how to convert the hold multicycle value, refer to the *Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

## Clock Enable Multicycle

The Quartus II Classic Timing Analyzer supports the following clock enable multicycle assignments. Corresponding types of multicycle assignments are applied to all registers enabled by the targets of the specified clock.

- Clock Enable Multicycle
- Clock Enable Source Multicycle
- Clock Enable Multicycle Hold
- Clock Enable Source Multicycle Hold

The Quartus II TimeQuest Timing Analyzer supports clock-enabled multicycle constraints with the `get_fanouts` command. Use the `get_fanouts` command to create a collection of nodes that have a common source signal, such as a clock enable.

## I/O Constraints

FPGA I/O timing assignments have typically been made with FPGA-centric  $t_{SU}$  and  $t_{CO}$  requirements for the Quartus II Classic Timing Analyzer. However, the Quartus II Classic Timing Analyzer also supports input and output delay assignments to accommodate industry-standard, system-centric timing constraints. Where possible, you should use system-centric constraints to constrain your designs for the Quartus II TimeQuest Timing Analyzer. Table 8-4 includes Quartus II Classic I/O assignments, the equivalent FPGA-centric SDC constraints, and recommended system-centric SDC constraints.

For setup checks ( $t_{SU}$  and  $t_{CO}$ ),  $\langle latch - launch \rangle$  equals the clock period for same-clock transfers. For hold checks ( $t_H$  and Minimum  $t_{CO}$ ),  $\langle latch - launch \rangle$  equals 0 for same clock transfers. Conversions from Quartus II Classic assignments to `set_input_delay` and `set_output_delay` constraints work well only when the source and destination registers' clocks are the same (same clock and polarity). If the source and

destination registers' clocks are different, the conversion may not be straightforward and you should take extra care when converting to `set_input_delay` and `set_output_delay` constraints.

**Table 8–4. Quartus II Classic and Quartus II TimeQuest Timing Analyzers Equivalent I/O Constraints**

| Classic                      | FPGA-centric SDC                                                           | System-centric SDC                                                                                  |
|------------------------------|----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
| $t_{SU}$ Requirement         | <code>set_max_delay &lt;<math>t_{SU}</math> requirement&gt;</code>         | <code>set_input_delay -max &lt;latch - launch - <math>t_{SU}</math> requirement&gt;</code>          |
| $t_H$ Requirement            | <code>set_min_delay - &lt;<math>t_H</math> requirement&gt;</code> (1)      | <code>set_input_delay -min &lt;latch - launch + <math>t_H</math> requirement&gt;</code>             |
| $t_{CO}$ Requirement         | <code>set_max_delay &lt;<math>t_{CO}</math> requirement&gt;</code>         | <code>set_output_delay -max &lt;latch - launch - <math>t_{CO}</math> requirement&gt;</code>         |
| Minimum $t_{CO}$ Requirement | <code>set_min_delay &lt;minimum <math>t_{CO}</math> requirement&gt;</code> | <code>set_output_delay -min &lt;latch - launch - minimum <math>t_{CO}</math> requirement&gt;</code> |
| $t_{PD}$ Requirement         | <code>set_max_delay &lt;<math>t_{PD}</math> requirement&gt;</code>         | (2)                                                                                                 |
| Minimum $t_{PD}$ Requirement | <code>set_min_delay &lt;minimum <math>t_{PD}</math> requirement&gt;</code> | (2)                                                                                                 |

*Notes to Table 8–4:*

- (1) Refer to “ $t_H$  Requirement” on page 8–43 for an explanation about why this exception uses the negative  $t_H$  requirement.
- (2) The input and output delays can be used for  $t_{PD}$  paths, such that they will be analyzed as a system  $f_{MAX}$  path. This is a feature unique to the Quartus II TimeQuest Timing Analyzer.

## Input and Output Delay

Table 8–5 shows the equivalent SDC exceptions for each of these Quartus II Classic Timing Analyzer timing assignments.

**Table 8–5. Quartus II Classic and SDC Equivalent Exceptions**

| Quartus II Classic Timing Assignment |                  | SDC Exception                      |
|--------------------------------------|------------------|------------------------------------|
| Assignment Name                      | QSF Variable     |                                    |
| Input Maximum Delay                  | INPUT_MAX_DELAY  | <code>set_input_delay -max</code>  |
| Input Minimum Delay                  | INPUT_MIN_DELAY  | <code>set_input_delay -min</code>  |
| Output Maximum Delay                 | OUTPUT_MAX_DELAY | <code>set_output_delay -max</code> |
| Output Minimum Delay                 | OUTPUT_MIN_DELAY | <code>set_output_delay -min</code> |

In some circumstances, you may receive the following warning message when you update the SDC netlist:

```
Warning: For set_input_delay/set_output_delay, port
"<port>" does not have delay for flag (<rise|fall>,
<min|max>)
```

This warning occurs whenever port constraints have maximum or minimum delay assignments, but not both. In the Quartus II Classic Timing Analyzer, device inputs can have **Input Maximum Delay** assignments, **Input Minimum Delay** assignments, or both, and device outputs can have **Output Maximum Delay** assignments, **Output Minimum Delay** assignments, or both.

To avoid receiving the warning, your SDC file must specify both the `-max` and `-min` options for each port, or specify neither. If a device I/O in your design includes both the maximum and minimum delay assignments in the Quartus II Classic Timing Analyzer, the conversion utility converts both, and no warning appears about that device I/O. If a device I/O has only maximum or minimum delay assignments in the Quartus II Classic Timing Analyzer, you have the following options:

- Add the missing minimum or maximum delay assignment to the device I/O before performing the conversion.
- Modify the SDC constraint after the conversion to add appropriate `-max` or `-min` values.
- Modify the SDC constraint to remove the `-max` or `-min` option so the value is used for both by default.

## **$t_{SU}$ Requirement**

The  **$t_{SU}$  Requirement** assignment specifies the maximum acceptable clock setup time for the input (data) pin. The QSF variable for the  **$t_{SU}$  Requirement** assignment is `TSU_REQUIREMENT`. You can convert the  **$t_{SU}$  Requirement** assignment to the **set\_max\_delay** command or the **set\_input\_delay** command with the `-max` option. The delay value for the **set\_input\_delay** command is `<latch-launch-tSU requirement>`. Refer to the labeled paths in [Figure 8–24](#) to understand the names in Equations 3 and 4.

**Figure 8–24. Path Names**

Equation 3 shows the derivation of this conversion.

(3) required – arrival > 0

$$\text{required} = \text{latch} + \text{board.dstclk} + \text{dst.clk} - \text{dst.utsu}$$

$$\text{arrival} = \text{launch} + \text{board.srcclk} + \text{src.clk} + \text{src.utco} + \text{src.out} + \text{srctodst} + \text{dst.in}$$

$$\text{input\_delay} = \text{board.srcclk} + \text{src.clk} + \text{src.utco} + \text{src.out} + \text{srctodst} - \text{board.dstclk}$$

$$\text{required} = \text{latch} + \text{dst.clk} - \text{dst.utsu}$$

$$\text{arrival} = \text{launch} + \text{input\_delay} + \text{dst.in}$$

$$(\text{latch} + \text{dst.clk} - \text{dst.utsu}) - (\text{launch} + \text{input\_delay} + \text{dst.in}) > 0$$

$$t_{su} \text{ requirement} - \text{actual } t_{su} > 0$$

$$\text{actual } t_{su} = \text{dst.in} + \text{dst.utsu} - \text{dst.clk}$$

$$t_{su} \text{ requirement} - (\text{dst.in} + \text{dst.utsu} - \text{dst.clk}) > 0$$

$$t_{su} \text{ requirement} = \text{latch} - \text{launch} - \text{input\_delay}$$

$$\text{input\_delay} = \text{latch} - \text{launch} - t_{su} \text{ requirement}$$

The delay value is the difference between the period of the clock source of the register and the **t<sub>su</sub> Requirement** value, as shown in [Figure 8–25](#).

**Figure 8–25. t<sub>su</sub> Requirement**



The delay value for the **set\_max\_delay** command is the **t<sub>su</sub> Requirement** value. [Equation 4](#) shows the derivation of this conversion.

(4) required – arrival > 0

$$\text{required} = \text{latch} + \text{board.dstclk} + \text{dst.clk} - \text{dst.utsu}$$

$$\text{arrival} = \text{launch} + \text{board.srcclk} + \text{src.clk} + \text{src.utco} + \text{src.out} + \text{srctodst} + \text{dst.in}$$

$$\text{max\_delay} = \text{latch} + \text{board.dstclk} + \text{launch} - \text{board.srcclk} - \text{src.clk} - \text{src.out} - \text{srctodst}$$

$$\text{required} = \text{max\_delay} + \text{dst.clk} - \text{dst.utsu}$$

$$\text{arrival} = \text{dst.in}$$

$$(\text{max\_delay} + \text{dst.clk} - \text{dst.utsu}) - (\text{dst.in}) > 0$$

$$\text{t}_{\text{su}} \text{ requirement} - \text{t}_{\text{su}} > 0$$

$$\text{actual t}_{\text{su}} = \text{dst.in} + \text{dst.utsu} - \text{dst.clk}$$

$$\text{t}_{\text{su}} \text{ requirement} - (\text{dst.in} + \text{dst.utsu} - \text{dst.clk}) > 0$$

$$\text{set\_max\_delay} = \text{t}_{\text{su}} \text{ requirement}$$

Table 8–6 shows the different ways you can make  $t_{SU}$  assignments in the Quartus II Classic Timing Analyzer, and the corresponding options for the **set\_max\_delay** exception.

| <b><math>t_{SU}</math> Requirement Options</b> | <b>set_max_delay Options</b>                           |
|------------------------------------------------|--------------------------------------------------------|
| -to <pin>                                      | -from [get_ports <pin>] -to [get_registers *]          |
| -to <clock>                                    | -from [get_ports *] -to [get_clocks <clock>]           |
| -to <register>                                 | -from [get_ports *] -to [get_registers <register>]     |
| -from <pin> -to <register>                     | -from [get_ports <pin>] -to [get_registers <register>] |
| -from <clock> -to <pin>                        | -from [get_ports <pin>] -to [get_clocks <clock>] (1)   |

**Notes to Table 8–6:**

- (1) If the pin in this assignment feeds registers clocked by the same clock, it is equivalent to the first option, -to <pin>. If the pin feeds registers clocked by different clocks, use **set\_input\_delay** to constrain the paths properly.

To convert a global  $t_{SU}$  assignment to an equivalent SDC exception, use the command shown in [Example 8–10](#).

**Example 8–10. Converting a Global  $t_{SU}$  Assignment to an Equivalent SDC Exception**

```
set_max_delay -from [all_inputs] -to [all_registers] < $t_{SU}$  value>
```

## **$t_H$ Requirement**

The  **$t_H$  Requirement** specifies the maximum acceptable clock hold time for the input (data) pin. The QSF variable for the  **$t_H$  Requirement** assignment is **TH\_REQUIREMENT**. You can convert the  **$t_H$  Requirement** assignment to the **set\_min\_delay** command, or the **set\_input\_delay** command with the **-min** option. The delay value for the **set\_input\_delay** command is  $<latch - launch + t_H requirement>$ . Refer to the labeled paths in [Figure 8–26](#) to understand the names in Equations 5 and 6.

**Figure 8–26. Path Names**



Equation 5 shows the derivation of this calculation.

$$(5) \quad \text{arrival} - \text{required} > 0$$

$$\text{arrival} = \text{launch} + \text{board.srcclk} + \text{src.clk} + \text{src.utco} + \text{src.out} + \text{srctodst} + \text{dst.in}$$

$$\text{required} = \text{latch} + \text{board.dstclk} + \text{dst.clk} + \text{dst.uth}$$

$$\text{input\_delay} = \text{board.srcclk} + \text{src.clk} + \text{src.utco} + \text{src.out} + \text{srctodst} - \text{board.dstclk}$$

$$\text{arrival} = \text{launch} + \text{input\_delay} + \text{dst.in}$$

$$\text{required} = \text{latch} + \text{dst.clk} + \text{dst.uth}$$

$$(\text{launch} + \text{input\_delay} + \text{dst.in}) - (\text{latch} + \text{dst.clk} + \text{dst.uth}) > 0$$

$$t_H \text{ requirement} - \text{actual } t_H > 0$$

$$\text{actual } t_H = \text{dst.clk} + \text{dst.uth} - \text{dst.in}$$

$$t_H \text{ requirement} - (\text{dst.clk} + \text{dst.uth} - \text{dst.in}) > 0$$

$$t_H \text{ requirement} = \text{launch} - \text{latch} + \text{input\_delay}$$

$$\text{input\_delay} = \text{latch} - \text{launch} + t_H \text{ requirement}$$

The delay value for the **set\_min\_delay** command is the  **$t_H$  Requirement** value. Equation 6 shows the derivation of this conversion.

$$(6) \quad \text{arrival} - \text{required} > 0$$

$$\text{arrival} = \text{dst.in}$$

$$\text{required} = \text{min\_delay} + \text{dst.clk} + \text{dst.uth}$$

$$\text{dst.in} - (\text{min\_delay} + \text{dst.clk} + \text{dst.uth})$$

$$t_H \text{ requirement} - \text{actual } t_H > 0$$

$$\text{actual } t_H = \text{dst.clk} + \text{dst.uth} - \text{dst.in}$$

$$t_H \text{ requirement} - (\text{dst.clk} + \text{dst.uth} - \text{dst.in}) > 0$$

$$\text{set\_min\_delay} = -t_H \text{ requirement}$$

Table 8–7 shows the different ways you can make  $t_H$  assignments in the Quartus II Classic Timing Analyzer, and the corresponding options for the **set\_min\_delay** command.

| <b>Table 8–7. <math>t_H</math> Requirement and <b>set_min_delay</b> Equivalence</b> |                                                        |
|-------------------------------------------------------------------------------------|--------------------------------------------------------|
| <b><math>t_H</math> Requirement Options</b>                                         | <b><b>set_min_delay</b> Options</b>                    |
| -to <pin>                                                                           | -from [get_ports <pin>] -to [get_registers *]          |
| -to <clock>                                                                         | -from [get_ports *] -to [get_clocks <clock>]           |
| -to <register>                                                                      | -from [get_ports *] -to [get_registers <register>]     |
| -from <pin> -to <register>                                                          | -from [get_ports <pin>] -to [get_registers <register>] |
| -from <clock> -to <pin>                                                             | -from [get_ports <pin>] -to [get_clocks <clock>] (1)   |

**Notes to Table 8–7:**

- (1) If the pin in this assignment feeds registers clocked by the same clock, it is equivalent to the first option, -to <pin>. If the pin feeds registers clocked by different clocks, use **set\_input\_delay** to constrain the paths properly. Refer to “[Input and Output Delay](#)” on page 8–39 for additional information.

To convert a global  $t_H$  assignment to an equivalent SDC exception, use the command shown in [Example 8–11](#).

---

**Example 8–11. Converting a Global  $t_H$  Assignment to an Equivalent SDC Exception**

`set_min_delay -from [all_inputs] -to [all registers] <negative  $t_H$  value>`

---

## **$t_{CO}$ Requirement**

The  **$t_{CO}$  Requirement** assignment specifies the maximum acceptable clock to output delay to the output pin. The QSF variable for the  **$t_{CO}$  Requirement** assignment is TCO\_REQUIREMENT. You can convert the  **$t_{CO}$  Requirement** assignment to the **set\_max\_delay** command or the **set\_output\_delay** with the -max option. The delay value for the **set\_output\_delay** command is <latch – launch +  $t_{CO}$  requirement>. Refer to the labeled paths in [Figure 8–27](#) to understand the names in Equations 7 and 8.

**Figure 8–27. Path Names**

Equation 7 shows the derivation of this conversion.

- (7)  $\text{required} - \text{arrival} > 0$   
 $\text{required} = \text{latch} - \text{output\_delay}$   
 $\text{arrival} = \text{launch} + \text{src.clk} + \text{src.utco} + \text{src.out}$   
 $\text{output\_delay} = \text{srctodst} + \text{dst.in} + \text{dst.utsu} - \text{dst.clk} - \text{board.dstclk} + \text{board.srcclk}$
- $$(\text{latch} - \text{output\_delay}) - (\text{launch} + \text{src.clk} + \text{src.utco} + \text{src.out}) > 0$$
- $$t_{co} \text{ requirement} - \text{actual } t_{co} > 0$$
- $$\text{actual } t_{co} = \text{launch} + \text{src.clk} + \text{src.utco} + \text{src.out}$$
- $$t_{co} \text{ requirement} - (\text{src.clk} + \text{src.utco} + \text{src.out}) > 0$$
- $$t_{co} \text{ requirement} = \text{latch} - \text{launch} - \text{output\_delay}$$
- $$\text{output\_delay} = \text{latch} - \text{launch} - t_{co} \text{ requirement}$$

The delay value is the difference between the period of the clock source of the register and the  **$t_{co}$  Requirement** value, as illustrated in Figure 8–28.

**Figure 8–28.  $t_{co}$  Requirement**

The delay value for the `set_max_delay` command is the  $t_{CO}$  Requirement value. [Equation 8](#) shows the derivation of this conversion.

$$\begin{aligned}
 (8) \quad & \text{required} - \text{arrival} > 0 \\
 & \text{required} = \text{set\_max\_delay} \\
 & \text{arrival} = \text{src.clk} + \text{src.utco} + \text{src.out} \\
 & \text{set\_max\_delay} - (\text{src.clk} + \text{src.utco} + \text{src.out}) > 0 \\
 \\
 & t_{CO} \text{ requirement} - \text{actual } t_{CO} > 0 \\
 & \text{actual } t_{CO} = \text{src.clk} + \text{src.utco} + \text{src.out} \\
 & t_{CO} \text{ requirement} - (\text{src.clk} + \text{src.utco} + \text{src.out}) > 0 \\
 \\
 & \text{set\_max\_delay} = t_{CO} \text{ requirement}
 \end{aligned}$$

[Table 8-8](#) shows the different ways you can make  $t_{CO}$  assignments in the Quartus II Classic Timing Analyzer, and the corresponding options for the `set_max_delay` exception.

| <b>Table 8-8. <math>t_{CO}</math> Requirement and <code>set_max_delay</code> Equivalence</b> |                                                                                 |
|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| <b><math>t_{CO}</math> Requirement Options</b>                                               | <b><code>set_max_delay</code> Options</b>                                       |
| <code>-to &lt;pin&gt;</code>                                                                 | <code>-from [get_registers *] -to [get_ports &lt;pin&gt;]</code>                |
| <code>-to &lt;clock&gt;</code>                                                               | <code>-from [get_clocks &lt;clock&gt;] -to [get_ports *]</code>                 |
| <code>-to &lt;register&gt;</code>                                                            | <code>-from [get_registers &lt;register&gt;] -to [get_ports *]</code>           |
| <code>-from &lt;register&gt; -to &lt;pin&gt;</code>                                          | <code>-from [get_registers &lt;register&gt;] -to [get_ports &lt;pin&gt;]</code> |
| <code>-from &lt;clock&gt; -to &lt;pin&gt;</code>                                             | <code>-from [get_clocks &lt;clock&gt;] -to [get_ports &lt;pin&gt;] (1)</code>   |

*Notes to Table 8-8:*

- (1) If the pin in this assignment feeds registers clocked by the same clock, it is equivalent to the first option, `-to <pin>`. If the pin feeds registers clocked by different clocks, you should use `set_output_delay` to constrain the paths properly.

To convert a global  $t_{CO}$  assignment to an equivalent SDC exception, use the command in [Example 8-12](#).

---

**Example 8-12. Converting a Global  $t_{CO}$  Assignment to an Equivalent SDC Exception**

---

`set_max_delay -from [all_registers] -to [all_outputs] < $t_{CO}$  value>`

---

## Minimum $t_{CO}$ Requirement

The **Minimum  $t_{CO}$  Requirement** assignment specifies the minimum acceptable clock to output delay to the output pin. The QSF variable for the **Minimum  $t_{CO}$  Requirement** assignment is `MIN_TCO_REQUIREMENT`. You can convert the **Minimum  $t_{CO}$  Requirement** assignment to the `set_min_delay` command or the `set_output_delay` command with the `-min` option. The delay value for the `set_output_delay` command is  $<\text{latch} - \text{launch} + \text{minimum } t_{CO} \text{ requirement}>$ . Refer to the labeled paths in Figure 8-29 to understand the names in Equations 9 and 10.

Figure 8-29. Path Names



Equation 9 shows the derivation of this conversion.

- (9)    arrival + required > 0  

$$\text{arrival} = \text{launch} + \text{src.clk} + \text{src.utco} + \text{src.out}$$
  

$$\text{required} = \text{latch} - \text{output\_delay}$$
  

$$\text{output\_delay} = \text{srctodst} + \text{dst.in} - \text{dst.uth} - \text{dst.clk} - \text{board.dstclk} + \text{board.srcclk}$$
  

$$(\text{launch} + \text{src.clk} + \text{src.utco} + \text{src.out}) - (\text{latch} - \text{output\_delay}) > 0$$
  

$$\text{minimum } t_{CO} - \text{minimum } t_{CO} \text{ requirement} > 0$$
  

$$\text{minimum } t_{CO} = \text{launch} + \text{src.clk} + \text{src.utco} + \text{src.out}$$
  

$$(\text{launch} + \text{src.clk} + \text{src.utco} + \text{src.out}) - \text{minimum } t_{CO} \text{ requirement} > 0$$
  

$$\text{minimum } t_{CO} \text{ requirement} = \text{latch} - \text{launch} - \text{output\_delay}$$
  

$$\text{output\_delay} = \text{latch} - \text{launch} - \text{minimum } t_{CO} \text{ requirement}$$

The delay value for the `set_min_delay` command is the **Minimum  $t_{CO}$  Requirement**. [Equation 10](#) shows the derivation of this conversion.

$$\begin{aligned}
 (10) \quad & \text{arrival} - \text{required} > 0 \\
 & \text{arrival} = \text{src.clk} + \text{src.utco} + \text{src.out} \\
 & \text{required} = \text{min\_delay} \\
 & (\text{src.clk} + \text{src.utco} + \text{src.out}) - (\text{set\_min\_delay}) > 0 \\
 \\
 & \text{minimum } t_{CO} - \text{minimum } t_{CO} \text{ requirement} > 0 \\
 & \text{minimum } t_{CO} = \text{src.clk} + \text{src.utco} + \text{src.out} \\
 & (\text{src.clk} + \text{src.utco} + \text{src.out}) - \text{minimum } t_{CO} \text{ requirement} > 0 \\
 \\
 & \text{set\_min\_delay} = \text{minimum } t_{CO} \text{ requirement}
 \end{aligned}$$

[Table 8–9](#) shows the different ways you can make minimum  $t_{CO}$  assignments in the Quartus II Classic Timing Analyzer, and the corresponding options for the `set_min_delay` exception.

| <b>Table 8–9. Minimum <math>t_{CO}</math> Requirement and <code>set_min_delay</code> Equivalence</b> |                                                                                 |
|------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| <b>Minimum <math>t_{CO}</math> Requirement Options</b>                                               | <b><code>set_min_delay</code> Options</b>                                       |
| <code>-to &lt;pin&gt;</code>                                                                         | <code>-from [get_registers *] -to [get_ports &lt;pin&gt;]</code>                |
| <code>-to &lt;clock&gt;</code>                                                                       | <code>-from [get_clocks &lt;clock&gt;] -to [get_ports *]</code>                 |
| <code>-to &lt;register&gt;</code>                                                                    | <code>-from [get_registers &lt;register&gt;] -to [get_ports *]</code>           |
| <code>-from &lt;register&gt; -to &lt;pin&gt;</code>                                                  | <code>-from [get_registers &lt;register&gt;] -to [get_ports &lt;pin&gt;]</code> |
| <code>-from &lt;clock&gt; -to &lt;pin&gt;</code>                                                     | <code>-from [get_clocks &lt;clock&gt;] -to [get_ports &lt;pin&gt;] (1)</code>   |

*Notes to Table 8–9:*

- (1) If the pin in this assignment feeds registers clocked by the same clock, it is equivalent to the first option, `-to <pin>`. If the pin feeds registers clocked by different clocks, you should use `set_output_delay` to constrain the paths properly.

To convert a global **Minimum  $t_{CO}$  Requirement** to an equivalent SDC exception, use the command shown in [Example 8–13](#).

**Example 8–13. Converting a Global minimum  $t_{CO}$  Requirement to an Equivalent SDC Exception**

```
set_min_delay -from [all_registers] -to [all_outputs] <minimum tCO value>
```

## **t<sub>PD</sub> Requirement**

The **t<sub>PD</sub> Requirement** assignment specifies the maximum acceptable input to non-registered output delay, that is, the time required for a signal from an input pin to propagate through combinational logic and appear at an output pin. The QSF variable for the **t<sub>PD</sub> Requirement** assignment is TPD\_REQUIREMENT. You can use the **set\_max\_delay** command in the Quartus II TimeQuest Timing Analyzer as an equivalent constraint as long as you account for input and output delays. The **t<sub>PD</sub> Requirement** assignment does not take into account input and output delays, but the **set\_max\_delay** exception does, so you must modify the **set\_max\_delay** value to take into account input and output delays.

### Combinational Path Delay Scenario

Figure 8-30 shows a simple circuit followed by an example of a **t<sub>PD</sub> Requirement** to **set\_max\_delay** conversion.

**Figure 8-30. t<sub>PD</sub> Example**



Assume the circuit has the following assignments in the Quartus II Classic Timing Analyzer:

- Clock period of 10 ns
- **t<sub>PD</sub> Requirement** from a\_in to comb\_out of 10 ns
- **Input Max Delay** on a\_in relative to clk of 2 ns
- **Output Max Delay** on comb\_out relative to clk of 2 ns

The path from a\_in to comb\_out is not affected by the input and output delays. The slack is equal to the  $< t_{PD} \text{ Requirement from a\_in to comb\_out} > - < \text{path delay from a\_in to comb\_out} >$ .

Assume the circuit has the SDC constraints shown in [Example 8-14](#) in the Quartus II TimeQuest Timing Analyzer:

---

**Example 8-14. SDC Constraints**

```
create_clock -period 10 -name clk [get_ports clk]
set_max_delay -from a_in -to comb_out 10
set_input_delay -clk clk 2 [get_ports a_in]
set_output_delay -clk clk 2 [get_ports comb_out]
```

---

The path from a\_in to comb\_out is affected by the input and output delays. The slack is equal to:

*<set\_max\_delay value from a\_in to comb\_out> - <input delay> - <output delay> - <path delay from a\_in to comb\_out>*

To convert a global **t<sub>PD</sub> Requirement** assignment to an equivalent SDC exception, use the command shown in [Example 8-15](#). You should add the input and output delays to the value of your converted **t<sub>PD</sub> Requirement** (**set\_max\_delay** exception value) to achieve an equivalent SDC exception.

---

**Example 8-15. Converting a Global t<sub>PD</sub> Requirement Assignment to an Equivalent SDC Exception**

```
set_max_delay -from [all_inputs] -to [all_outputs] <value>
```

---

## Minimum t<sub>PD</sub> Requirement

The **Minimum t<sub>PD</sub> Requirement** assignment specifies the minimum acceptable input to non-registered output delay, that is, the minimum time required for a signal from an input pin to propagate through combinational logic and appear at an output pin. The QSF variable for the **Minimum t<sub>PD</sub> Requirement** assignment is MIN\_TPD\_REQUIREMENT. You can use the **set\_min\_delay** command in the Quartus II TimeQuest Timing Analyzer as an equivalent constraint as long as you account for input and output delays. The **Minimum t<sub>PD</sub> Requirement** assignment does not take into account input and output delays, but the **set\_min\_delay** exception does.

Refer to [“Combinational Path Delay Scenario” on page 8-50](#) to see how input and output delays affect minimum and maximum delay exceptions.

To convert a global **Minimum t<sub>PD</sub> Requirement** assignment to an equivalent SDC exception, use the following command:

---

**Example 8-16. Converting a Global Minimum t<sub>PD</sub> Requirement Assignment to an Equivalent SDC Exception**

```
set_min_delay -from [all_inputs] -to [all_outputs] <value>
```

---

## Cut Timing Path

The **Cut Timing Path** assignment in the Quartus II Classic Timing Analyzer is equivalent to the `set_false_path` command in the Quartus II TimeQuest Timing Analyzer. The QSF variable for the **Cut Timing Path** assignment is CUT.

## Maximum Delay

The **Maximum Delay** assignment specifies the maximum required delay for the following types of paths:

- Pins to registers
- Registers to registers
- Registers to pins

The QSF variable for the **Maximum Delay** assignment is MAX\_DELAY. This requirement overwrites the requirement computed from the clock setup relationship and clock skew. There is no equivalent constraint in the Quartus II TimeQuest Timing Analyzer.



The **Maximum Delay** assignment for the Quartus II Classic Timing Analyzer is not related to the `set_max_delay` exception in the Quartus II TimeQuest Timing Analyzer.

## Minimum Delay

The **Minimum Delay** assignment specifies the minimum required delay for the following types of paths:

- Pins to registers
- Registers to registers
- Registers to pins

The QSF variable for the **Minimum Delay** assignment is MIN\_DELAY. This requirement overwrites the requirement computed from the clock hold relationship and clock skew. There is no equivalent constraint in the Quartus II TimeQuest Timing Analyzer.



The **Minimum Delay** assignment for the Quartus II Classic Timing Analyzer is not related to the `set_min_delay` exception in the Quartus II TimeQuest Timing Analyzer.

## Maximum Clock Arrival Skew

The **Maximum Clock Arrival Skew** assignment specifies the maximum clock skew between a set of registers. The QSF variable for the **Maximum Clock Arrival Skew** assignment is `MAX_CLOCK_ARRIVAL_SKEW`. In the Quartus II Classic Timing Analyzer, this assignment is specified between a clock node name and a set of registers. **Maximum Clock Arrival Skew** is not supported in the Quartus II TimeQuest Timing Analyzer.

## Maximum Data Arrival Skew

The **Maximum Data Arrival Skew** assignment specifies the maximum data arrival skew between a set of registers, pins, or both. The QSF variable for the **Maximum Data Arrival Skew** assignment is `MAX_DATA_ARRIVAL_SKEW`. In this case, the data arrival delay represents the  $t_{CO}$  from the clock to the given register, pin, or both. This assignment is specified between a clock node and a set of registers, pins, or both.

The Quartus II TimeQuest Timing Analyzer does not support a constraint to specify maximum data arrival skew, but you can specify setup and hold times relative to a clock port to constrain an interface like this.

**Figure 8-31** shows a simplified source-synchronous interface used in the following example.

**Figure 8-31. Source-Synchronous Interface Diagram**



### Constraining Skew on an Output Bus

This example constrains the interface so that all bits of the `data_out` bus go off-chip between 2 and 3 ns after the `clk_out` signal. Assume that `clock_in` and `clock_out` have a period of 8 ns.

The following equations and example shows how to create timing requirements that satisfy the timing relationships shown in [Figure 8-32](#).

**Figure 8-32. Source-Synchronous Timing Diagram**



[Equation 11](#) shows how to compute the value for the **set\_output\_delay -min** command that creates the 2 ns hold requirement on the destination. For hold requirement calculations in which source and destination clocks are the same,  $\langle \text{latch} \rangle - \langle \text{launch} \rangle = 0$ .

- (11)  $\text{latch} - \text{launch} = 0\text{ns}$   
 $\text{output delay} = \text{latch} - \text{launch} - 2\text{ns}$   
 $\text{output delay} = -2\text{ns}$

[Equation 12](#) shows how to compute the value for the **set\_output\_delay** command that creates the 3 ns setup requirement on the destination. For setup requirement calculations in which source and destination clocks are the same,  $\langle \text{latch} \rangle - \langle \text{launch} \rangle = \text{clock period}$ .

- (12)  $\text{latch} - \text{launch} = 8\text{ns}$   
 $\text{output delay} = \text{latch} - \text{launch} - 3\text{ns}$   
 $\text{output delay} = 5\text{ns}$

Refer to [“I/O Constraints”](#) on page 8-38 for an explanation of the above equations.

Example 8-17 shows the three constraints together.

---

**Example 8-17. Constraining a DDR Interface**

```
set period 8.000
create_clock -period $period \
    -name clock_in \
    clock_in
derive_pll_clocks
set_output_delay -add_delay \
    -clock ddr_pll_1_inst|altpll_component|pll|CLK[0] \
    -reference_pin clk_out \
    -min -2.000 \
    [get_ports data_out*]
set_output_delay -add_delay \
    -clock ddr_pll_1_inst|altpll_component|pll|CLK[0] \
    -reference_pin clk_out \
    -max [expr $period - 3.000] \
    [get_ports data_out*]
```

---

## Conversion Utility

The Quartus II TimeQuest Timing Analyzer includes a conversion utility to help you convert Quartus II Classic timing assignments in a QSF file to SDC constraints in an SDC file. The utility can use information from your project report database (in the \db folder), if it exists, so you should compile your design before the conversion.



The conversion utility ignores all disabled QSF assignments. Disabled assignments say **No** in the **Enabled?** column of the Assignment Editor, and include the **-disable** option in the QSF file.

Refer to “Conversion Utility” on page 8-3 to learn how to run the conversion utility.

## Unsupported Global Assignments

The conversion utility checks whether any of the global timing assignments in [Table 8–10](#) exist in your project. Any global assignments not supported by the conversion utility are ignored during the conversion. Refer to the indicated page for information about each assignment, and how to manually convert these global assignments to SDC commands.

**Table 8–10. Global Timing Assignments**

| Assignment Name              | QSF Variable        | More Information          |
|------------------------------|---------------------|---------------------------|
| $t_{SU}$ Requirement         | TSU_REQUIREMENT     | <a href="#">page 8–40</a> |
| $t_H$ Requirement            | TH_REQUIREMENT      | <a href="#">page 8–43</a> |
| $t_{CO}$ Requirement         | TCO_REQUIREMENT     | <a href="#">page 8–45</a> |
| Minimum $t_{CO}$ Requirement | MIN_TCO_REQUIREMENT | <a href="#">page 8–48</a> |
| $t_{PD}$ Requirement         | TPD_REQUIREMENT     | <a href="#">page 8–50</a> |
| Minimum $t_{PD}$ Requirement | MIN_TPD_REQUIREMENT | <a href="#">page 8–51</a> |

## Recommended Global Assignments

Once any unsupported assignments have been identified, the conversion utility checks the global assignments in [Table 8–11](#) to ensure they match the specified values.

**Table 8–11. Recommended Global Assignments**

| Quartus II Classic Assignment Name      | QSF Variable                            | Value |
|-----------------------------------------|-----------------------------------------|-------|
| Cut off clear and preset signal paths   | CUT_OFF_CLEAR_AND_PRESET_PATHS          | ON    |
| Cut off feedback from I/O pins          | CUT_OFF_IO_PIN_FEEDBACK                 | ON    |
| Cut off read during write signal paths  | CUT_OFF_READ_DURING_WRITE_PATHS         | ON    |
| Analyze latches as synchronous elements | ANALYZE_LATCHES_AS_SYNCHRONOUS_ELEMENTS | ON    |
| Enable Clock Latency                    | ENABLE_CLOCK_LATENCY                    | ON    |
| Display Entity Name                     | PROJECT_SHOW_ENTITY_NAME                | ON    |

The following assignments are checked to ensure the functionality of the Quartus II Classic Timing Analyzer with the specified values corresponds to the behavior of the Quartus II TimeQuest Timing Analyzer.

- **Cut off clear and preset signal paths**—Quartus II The TimeQuest Timing Analyzer does not support this functionality. You should use Recovery and Removal analysis instead to analyze register control paths. The Quartus II Classic Timing Analyzer does not support this option.
- **Cut off feedback from I/O pins**—The Quartus II TimeQuest Timing Analyzer does not match the functionality of the Quartus II Classic Timing Analyzer when this assignment is OFF.
- **Cut off read during write signal paths**—The Quartus II TimeQuest Timing Analyzer does not match the functionality of the Quartus II Classic Timing Analyzer when this assignment is OFF.
- **Analyze latches as synchronous elements**—The Quartus II TimeQuest Timing Analyzer analyzes latches as synchronous elements by default and does not match the functionality of the Quartus II Classic Timing Analyzer when this assignment is OFF. Beginning with version 5.1 of the Quartus II software, the Quartus II Classic Timing Analyzer analyzes latches as synchronous elements by default.
- **Enable Clock Latency**—The Quartus II TimeQuest Timing Analyzer includes clock latency in its calculations. The Quartus II TimeQuest Timing Analyzer does not match the functionality of the Quartus II Classic Timing Analyzer when this assignment is OFF. Latency on a clock can be viewed as a simple delay on the clock path, and affects clock skew. This is in contrast to an offset, which alters the setup and hold relationship between two clocks. Refer to ["Offset and Latency Example" on page 8-15](#) for an example of the different effects of offset and latency. When you turn on **Enable Clock Latency** in the Quartus II Classic Timing Analyzer, it affects the following aspects of timing analysis:
  - **Early Clock Latency** and **Late Clock Latency** assignments are honored
  - The compensation delay of a PLL is analyzed as latency
  - For clock settings where you do not specify an offset, the automatically computed offset is treated as latency.
- **Display Entity Name**—Any entity-specific assignments are ignored in the Quartus II TimeQuest Timing Analyzer because they do not include the entity name when this option is ON.

If your design meets timing requirements in the Quartus II Classic Timing Analyzer without all of the settings recommended in [Table 8-11 on page 8-56](#), you should perform one of the following actions.

- Change the settings and re-constrain and re-verify as necessary.  
*or*
- Add or modify SDC constraints as appropriate because analysis in the Quartus II TimeQuest Timing Analyzer may be different after conversion.

## Clock Conversion

Next, the conversion utility adds the **derive\_pll\_clocks** command to the SDC file. This command creates generated clocks on all PLL outputs in your design each time the SDC file is read. The command does not add a clock on the FPGA port that drives the PLL input.

The conversion utility includes the **derive\_pll\_clocks -use\_tan\_name** command in the SDC file it creates. The **-use\_tan\_name** option overrides the default clock naming behavior (the PLL pin name) so the clock name is the same as the net name in the Quartus II Classic Timing Analyzer.

Including the **-use\_tan\_name** option ensures that the conversion utility converts clock-to-clock exceptions properly. If you remove the **-use\_tan\_name** option, you must also edit references to the clock names in other SDC commands so that they match the PLL pin names.

If your design includes a global  $f_{MAX}$  assignment, the assignment is converted to a **derive\_clocks** command. The behavior of a global  $f_{MAX}$  assignment is different from the behavior of clocks created with the **derive\_clocks** command, and you should use the **report\_clocks** command when you review conversion results to evaluate the clock settings. Refer to “[Automatic Clock Detection](#)” on page 8-19 for an explanation of the differences. As soon as you know the appropriate clock settings, you should use **create\_clock** or **create\_generated\_clock** commands instead of the **derive\_clocks** command.



The conversion utility adds a **post\_message** command before the **derive\_clocks** command to remind you that the clocks are derived automatically. The Quartus II TimeQuest Timing Analyzer displays the reminder the first time it reads the SDC file. Remove or comment out the **post\_message** command to prevent the message from displaying.

Next, the conversion utility identifies and converts clock settings in the QSF file. If a project database exists, the utility also identifies and converts any additional clocks in the report file that are not in the QSF, such as PLL base clocks.



If you change the PLL input frequency, you must modify the SDC constraint manually.

The conversion utility ignores clock offsets on generated clocks. Refer to “[Clock Offset](#)” on page [8-14](#) for information about how to use offset values in the Quartus II TimeQuest Timing Analyzer.

## Instance Assignment Conversion

Next, the conversion utility converts the following instance assignments in [Table 8-12](#). Refer to the indicated page for information about each assignment.

**Table 8-12. Instance Timing Assignments**

| Assignment Name                     | QSF Variable                        | More Information          |
|-------------------------------------|-------------------------------------|---------------------------|
| Late Clock Latency                  | LATE_CLOCK_LATENCY                  | <a href="#">page 8-34</a> |
| Early Clock Latency                 | EARLY_CLOCK_LATENCY                 |                           |
| Clock Setup Uncertainty             | CLOCK_SETUP_UNCERTAINTY             | <a href="#">page 8-34</a> |
| Clock Hold Uncertainty              | CLOCK_HOLD_UNCERTAINTY              |                           |
| Multicycle (1)                      | MULTICYCLE                          |                           |
| Source Multicycle (2)               | SRC_MULTICYCLE                      |                           |
| Multicycle Hold (3)                 | HOLD_MULTICYCLE                     |                           |
| Source Multicycle Hold              | SRC_HOLD_MULTICYCLE                 |                           |
| Clock Enable Multicycle             | CLOCK_ENABLE_MULTICYCLE             |                           |
| Clock Enable Source Multicycle      | CLOCK_ENABLE_SOURCE_MULTICYCLE      |                           |
| Clock Enable Multicycle Hold        | CLOCK_ENABLE_MULTICYCLE_HOLD        | <a href="#">page 8-38</a> |
| Clock Enable Source Multicycle Hold | CLOCK_ENABLE_SOURCE_MULTICYCLE_HOLD |                           |
| Cut Timing Path                     | CUT                                 | <a href="#">page 8-52</a> |
| Input Maximum Delay                 | INPUT_MAX_DELAY                     |                           |
| Input Minimum Delay                 | INPUT_MIN_DELAY                     |                           |
| Output Maximum Delay                | OUTPUT_MAX_DELAY                    | <a href="#">page 8-39</a> |
| Output Minimum Delay                | OUTPUT_MIN_DELAY                    |                           |

*Notes to Table 8-12:*

- (1) A multicycle assignment can also be known as a “destination multicycle setup” assignment.
- (2) A source multicycle assignment can also be known as a “source multicycle setup” assignment.
- (3) A multicycle hold can also be known as a “destination multicycle hold” assignment.

Depending on input and output delay assignments, you may receive a warning message when the SDC file is read. The message warns that the `set_input_delay` commands, `set_output_delay` commands, or both are

missing the `-max` option, `-min` option, or both. Refer to “[Input and Output Delay](#)” on page 8–39 for an explanation of why the warning occurs and how to avoid it.

Beginning in version 7.1 of the Quartus II software, the conversion utility automatically adds multicycle hold exceptions for each multicycle setup assignment. The value of each multicycle hold exception depends on the **Default hold multicycle** assignment value in your project. If the value is **One**, the conversion utility uses a value of 0 (zero) for each multicycle hold exception it adds. If the value is **Same as multicycle**, the conversion utility uses a value one less than the corresponding multicycle setup assignment value for each multicycle hold exception it adds. Refer to “[Hold Multicycle](#)” on page 8–24 for more information on hold multicycle differences between the Quartus II Classic and Quartus II TimeQuest Timing Analyzers.

Next, the conversion utility converts the following instance assignments in [Table 8–13](#). Refer to the indicated page for information about each assignment. If the  $t_{PD}$  and minimum  $t_{PD}$  assignment targets also have input or output delays that apply to them, the  $t_{PD}$  and minimum  $t_{PD}$  conversion values may be incorrect. This is described in more detail on the indicated pages for the appropriate assignments.

**Table 8–13. Instance Timing Assignments**

| Assignment Name                  | QSF Variable        | More Information          |
|----------------------------------|---------------------|---------------------------|
| $t_{PD}$ Requirement (1)         | TPD_REQUIREMENT     | <a href="#">page 8–50</a> |
| Minimum $t_{PD}$ Requirement (1) | MIN_TPD_REQUIREMENT | <a href="#">page 8–51</a> |
| Setup Relationship               | SETUP_RELATIONSHIP  | <a href="#">page 8–33</a> |
| Hold Relationship                | HOLD_RELATIONSHIP   | <a href="#">page 8–34</a> |

**Note to Table 8–13:**

- (1) Refer to “ [\$t\_{PD}\$  and Minimum  \$t\_{PD}\$  Requirement Conversion](#)” on page 8–71 for more information about how the conversion utility converts single-point  $t_{PD}$  and minimum  $t_{PD}$  assignments.

The conversion utility converts Quartus II Classic I/O timing assignments to FPGA-centric SDC constraints. [Table 8-14](#) includes Quartus II Classic assignments, the equivalent FPGA-centric SDC constraints, and recommended system-centric SDC constraints.

**Table 8-14. Quartus II Classic and Quartus II TimeQuest Equivalent Constraints**

| Quartus II Classic                             | FPGA-Centric SDC | System-Centric SDC    | More Information          |
|------------------------------------------------|------------------|-----------------------|---------------------------|
| <a href="#">t<sub>SU</sub> Requirement (1)</a> | set_max_delay    | set_input_delay -max  | <a href="#">page 8-40</a> |
| <a href="#">t<sub>H</sub> Requirement (1)</a>  | set_min_delay    | set_input_delay -min  | <a href="#">page 8-43</a> |
| <a href="#">t<sub>CO</sub> Requirement (2)</a> | set_max_delay    | set_output_delay -max | <a href="#">page 8-45</a> |
| Minimum t <sub>CO</sub> Requirement (2)        | set_min_delay    | set_output_delay -min | <a href="#">page 8-48</a> |

*Notes to Table 8-14:*

- (1) Refer to “[t<sub>PD</sub> and Minimum t<sub>PD</sub> Requirement Conversion](#)” on [page 8-71](#) for more information about how the conversion utility converts this type of assignment.
- (2) Refer to “[t<sub>CO</sub> Requirement Conversion](#)” on [page 8-62](#) for more information about how the conversion utility converts this type of assignment.

The conversion utility can convert Quartus II Classic I/O timing assignments only to the FPGA-centric constraints without additional information about your design. Making system-centric constraints requires information about the external circuitry interfacing with the FPGA such as external clocks, clock latency, board delay, and clocking exceptions. You cannot convert Quartus II Classic timing assignments to system-centric constraints without that information. If you use the conversion utility, you can modify the SDC constraints to change the FPGA-centric constraints to system-centric constraints as appropriate.

### PLL Phase Shift Conversion

The conversion utility does not account for PLL phase shifts when it converts values of the following FPGA-centric I/O timing assignments:

- [t<sub>SU</sub> Requirement](#)
- [t<sub>H</sub> Requirement](#)
- [t<sub>CO</sub> Requirement](#)
- [Minimum t<sub>CO</sub> Requirement](#)

If any of your paths go through PLLs with a phase shift, you must correct the converted values for those paths according to the following formula:

$$(13) \quad \text{<correct value>} = \text{<converted value>} - \frac{(\text{<pll output period>} \times \text{<phase shift>})}{360}$$

**Example 8-18** shows the incorrect conversion result for a  $t_{CO}$  assignment and how to correct it. For the example, assume the PLL output frequency is 200 MHz (period is 5 ns), the phase shift is 90 degrees, the  $t_{CO}$  **Requirement** value is 1 ns, and it is made to `data[0]`. The QSF file contains the following assignment:

---

**Example 8-18. Assignment**

```
set_instance_assignment -name TCO_REQUIREMENT -to data[0] 1.0
```

---

The conversion utility generates the SDC command shown in **Example 8-19**.

---

**Example 8-19. SDC Command**

```
set_max_delay -from [get_registers *] -to [get_ports data[0]] 1.0
```

---

To correct the value, use the formula and values above, as shown in the following example:

$$1.0 - \frac{(5 \times 90)}{360} = -0.25$$

Then, change the value so the SDC command looks like **Example 8-20**.

---

**Example 8-20. SDC Command with Correct Values**

```
set_max_delay -from [get_registers *] -to [get_ports data[0]] -0.25
```

---

### *$t_{CO}$ Requirement Conversion*

The conversion utility uses a special process to convert  $t_{CO}$  **Requirement** and **Minimum  $t_{CO}$  Requirement** assignments. In addition to the `set_max_delay` or `set_min_delay` commands, the conversion utility adds a `set_output_delay` constraint relative to a virtual clock named N/C (Not a Clock). It also creates the virtual clock named N/C with a period of 10 ns. Adding the virtual clock allows you to report timing on the output paths. Without the virtual clock N/C, the clock used for reporting would be blank. **Example 8-21** shows how the conversion utility converts a  $t_{CO}$  **Requirement** assignment of 5.0 ns to `data[0]`.

---

**Example 8-21. Converting a  $t_{CO}$  Requirement Assignment of 5.0 ns to `data[0]`**

```
set_max_delay -from [get_registers *] -to [get_ports data[0]]  
set_output_delay -clock "N/C" 0 [get_ports data[0]]
```

---

## Entity-Specific Assignments

Next, the conversion utility converts the entity-specific assignments listed in [Table 8–15](#) that exist in the **Timing Analyzer Settings** report panel. This usually occurs if you have any timing assignments in your Verilog HDL or VHDL source, which can include MegaCore function files. These entity-specific assignments cannot be automatically converted unless your project is compiled and a `\db` directory exists.

**Table 8–15. Entity-Specific Timing Assignments**

| Quartus II Classic     | QSF Variable        | More Information          |
|------------------------|---------------------|---------------------------|
| Multicycle             | MULTICYCLE          | <a href="#">page 8–37</a> |
| Source Multicycle      | SRC_MULTICYCLE      |                           |
| Multicycle Hold        | HOLD_MULTICYCLE     |                           |
| Source Multicycle Hold | SRC_HOLD_MULTICYCLE |                           |
| Setup Relationship     | SETUP_RELATIONSHIP  | <a href="#">page 8–33</a> |
| Hold Relationship      | HOLD_RELATIONSHIP   | <a href="#">page 8–34</a> |
| Cut Timing Path        | CUT                 | <a href="#">page 8–52</a> |



You must manually convert all other entity-specific timing assignments.

## Paths between Unrelated Clock Domains

Beginning in version 7.1 of the Quartus II software, the conversion utility can create exceptions that cut paths between unrelated clock domains, which matches the default behavior of the Quartus II Classic Timing Analyzer. When **Cut paths between unrelated clock domains** is on, the conversion utility creates clock groups with the `set_clock_groups` command and uses the `-exclusive` option to cut paths between the clock groups.

## Unsupported Instance Assignments

Finally, the conversion utility checks for the following unsupported instance assignments listed in [Table 8–16](#) and warns you if any exist. Refer to the indicated page for information about each assignment.



You can manually convert some of the assignments to SDC constraints.

**Table 8–16. Instance Timing Assignments**

| Assignment Name            | QSF Variable            | More Information          |
|----------------------------|-------------------------|---------------------------|
| Inverted Clock             | INVERTED_CLOCK          | <a href="#">page 8–35</a> |
| Maximum Clock Arrival Skew | MAX_CLOCK_ARRIVAL_SKEW  | <a href="#">page 8–53</a> |
| Maximum Data Arrival Skew  | MAX_DATA_ARRIVAL_SKEW   | <a href="#">page 8–53</a> |
| Maximum Delay              | MAX_DELAY               | <a href="#">page 8–52</a> |
| Minimum Delay              | MIN_DELAY               | <a href="#">page 8–52</a> |
| Virtual Clock Reference    | VIRTUAL_CLOCK_REFERENCE | <a href="#">page 8–36</a> |

## Reviewing Conversion Results

You must review the messages that are generated during the conversion process, and review the SDC file for correctness and completeness. Warning and critical warning messages identify significant differences between the Quartus II Classic Timing Analyzer and Quartus II TimeQuest Timing Analyzer behaviors. In some cases, warning messages indicate that the conversion utility ignored assignments because it could not determine the intended functionality of your design. You must add to or modify the SDC constraints as necessary based on your knowledge of the design.

The conversion utility creates an SDC file with the same name as your current revision, `<revision>.sdc`, and it overwrites any existing `<revision>.sdc` file. If you use the conversion utility to create an SDC file, you should make additions or corrections in a separate SDC file, or a copy of the SDC file created by the conversion utility. That way, you can re-run the conversion utility later without overwriting your additions and changes. If you have constraints in multiple SDC files, refer to “[Constraint File Priority](#)” on page 8–10 to learn how to add constraints to your project.

### Warning Messages

The conversion utility may generate any of the following warning messages. Refer to the information provided for each warning message to learn what to do in that instance.

**Ignored QSF Variable <assignment>**

The conversion utility ignored the specified assignment. Determine whether an equivalent constraint is necessary and manually add one if appropriate. Refer to ["Timing Assignment Conversion" on page 8-33](#) for information about conversions for all QSF timing assignments.

**Global <name> = <value>**

The conversion utility ignored the global assignment <name>. Manually add an equivalent constraint if appropriate. Refer to ["Unsupported Global Assignments" on page 8-56](#) for information about conversions for these assignments.

**QSF: Expected <name> to be set to <expected value> but it is set to <actual value>**

The behavior of the Quartus II TimeQuest Timing Analyzer is closest to the Quartus II Classic Timing Analyzer when the value for the specified assignment is the expected value. Because the actual assignment value is not the expected value in your project, the Quartus II TimeQuest Timing Analyzer analysis may be different from the Quartus II Classic Timing Analyzer analysis. Refer to ["Recommended Global Assignments" on page 8-56](#) for an explanation about the indicated QSF variable names.

**QSF: Found Global Fmax Requirement. Translation will be done using derive\_clocks**

Your design includes a global  $f_{MAX}$  requirement, and the requirement is converted to the **derive\_clocks** command. Refer to ["Default Required  \$f\_{MAX}\$  Assignment" on page 8-35](#) for information about how to convert to an SDC constraint.

**TAN Report Database not found. HDL based assignments will not be migrated**

You did not analyze your design with the Quartus II Classic Timing Analyzer before running the conversion utility. As a result, the conversion utility did not convert any timing assignments in your HDL source code to SDC constraints. If you have timing assignments in your HDL source code, you must find and convert them manually, or analyze your design with the Quartus II Classic Timing Analyzer and rerun the conversion utility.

**Ignored Entity Assignment (Entity <entity>): <variable> = <value> -from <from> -to <to>**

The conversion utility ignored the specified entity assignment because the utility cannot automatically convert the assignment. [Table 8-15 on page 8-63](#) lists the entity-specific assignments the script can convert automatically.

Refer to “[Timing Assignment Conversion](#)” on page 8-33 for information about how to convert the entity assignment manually.

#### **Ignoring `OFFSET_FROM_BASE_CLOCK` assignment for clock *<clock>***

In some cases, this assignment is used to work around a limitation in how the Quartus II Classic Timing Analyzer handles some forms of clock inversion. The conversion script ignores the assignment because it cannot determine whether the assignment is used as a workaround. Review your clock setting and add the assignment in your SDC file if appropriate. Refer to “[Clock Offset](#)” on page 8-14 for more information about converting clock offset.

#### **Clock *<clock>* has no `FMAX_REQUIREMENT` - No clock was generated**

The conversion utility did not convert the clock named *<clock>* because it has no  $f_{MAX}$  requirement. You should add a clock constraint with an appropriate period to your SDC file.

#### **No Clock Settings defined in QSF file**

If your QSF file has no clock settings, ignore this message. You must add clock constraints in your SDC file manually.

### *Clocks*

Ensure that the conversion utility converted all clock assignments correctly. Run `report_clocks`, or double-click **Report Clocks** in the Tasks pane in the Quartus II TimeQuest Timing Analyzer GUI. Make sure that the right number of clocks is reported. If any clock constraints are missing, you must add them manually with the appropriate SDC commands (`create_clock` or `create_generated_clock`). Confirm that each option for each clock is correct.

The Quartus II TimeQuest Timing Analyzer can create more clocks, such as:

- `derive_clocks` selecting ripple clocks
- `derive_pll_clocks`, adding
  - Extra clocks for PLL switchover
  - Extra clocks for LVDS pulse-generated clocks (`~load_reg`)

### *Clock Transfers*

After you confirm that all clock assignments are correct, run `report_clock_transfers`, or double-click **Report Clock Transfers** in the Tasks pane in the Quartus II TimeQuest Timing Analyzer GUI. The

command generates a summary table with the number of paths between each clock domain. If the number of cross-clock domain paths seems high, remember that all clock domains are related in the Quartus II TimeQuest Timing Analyzer. You must cut unrelated clock domains. Refer to “[Related and Unrelated Clocks](#)” on page 8–13 for information about how to cut unrelated clock domains.

### *Path Details*

If you have unexpected differences between the Quartus II Classic and Quartus II TimeQuest Timing Analyzers on some paths, follow these steps to identify the cause of the difference.

1. List the path in the Quartus II Classic Timing Analyzer.
2. Report timing on the path in the Quartus II TimeQuest Timing Analyzer.
3. Compare slack values.
4. Compare source and destination clocks.
5. Compare the launch/latch times in the Quartus II TimeQuest Timing Analyzer to the setup/hold relationship in the Quartus II Classic Timing Analyzer. The times are absolute in the Quartus II TimeQuest Timing Analyzer and relative in the Quartus II Classic Timing Analyzer.
6. Compare clock latency values.

### *Unconstrained Paths*

Next, run `report_ucp`, or double-click **Report Unconstrained Paths** in the Tasks pane in the Quartus II TimeQuest Timing Analyzer GUI. This command generates a series of reports that detail any unconstrained paths in your design. If your design was completely constrained in the Quartus II Classic Timing Analyzer but there are unconstrained paths in the Quartus II TimeQuest Timing Analyzer, some assignments may not have been converted properly. Also, some of the assignments could be ambiguous. The Quartus II TimeQuest Timing Analyzer analyzes more paths than the Quartus II Classic Timing Analyzer does, so any unconstrained paths might be paths you could not constrain in the Quartus II Classic Timing Analyzer.

### *Bus Names*

If your design includes Quartus II Classic Timing Analyzer timing assignments to buses, and the bus names do not include square brackets enclosing an asterisk, such as: address [\*], you should review the SDC constraints to ensure the conversion is correct. Refer to “[Bus Name Format](#)” on page 8–10 for more information.

### *Other*

Review the notes listed in “[Conversion Utility](#)” on page 8–71.

## **Re-Running the Conversion Utility**

You can force the conversion utility to run even if it can find an SDC file according to the priority described in “[Constraint File Priority](#)” on page 8–10. Any method described in “[Conversion Utility](#)” on page 8–3 forces the conversion utility to run even if it can find an SDC file.

## **Notes**

This section describes notes for the Quartus II TimeQuest Timing Analyzer.

### **Output Pin Load Assignments**

The Quartus II TimeQuest Timing Analyzer takes **Output Pin Load** values into account when it analyzes your design. If you change **Output Pin Load** assignments and do not recompile before you analyze timing, you must use the `-force_dat` option when you create the timing netlist. Type the following command at the Tcl console of the Quartus II TimeQuest Timing Analyzer:

```
create_timing_netlist -force_dat ↵
```

If you change **Output Pin Load** assignments and recompile before you analyze timing, do not use the `-force_dat` option when you create the timing netlist. You can create the timing netlist with the `create_timing_netlist` command, or with the **Create Timing Netlist** task in the Tasks pane.

Also note that the SDC `set_output_load` command is not supported, so you must make all output load assignments in the Quartus II Settings File (`.qsf`).

## Constraint Target Types

In version 6.0 of the Quartus II software, the Quartus II TimeQuest Timing Analyzer did not support constraints between clocks and non-clocks. Beginning with version 6.1, the Quartus II TimeQuest Timing Analyzer supports mixed exception types; you can apply an exception of any clock/node combination.

## DDR Constraints with the DDR Timing Wizard

The DDR Timing Wizard (DTW) creates an SDC file that contains constraints for a DDR interface. You can use that SDC file with the Quartus II TimeQuest Timing Analyzer to analyze only the DDR interface part of a design.

You should use the SDC file created by DTW for constraining a DDR interface in the Quartus II TimeQuest Timing Analyzer. Additionally, your QSF should not contain timing assignments for the DDR interface if you plan to use the conversion utility to create an SDC file. You should run the conversion utility before you use DTW, and you should choose not to apply assignments to the QSF.

However, if you used DTW and chose to apply assignments to a QSF, before you used the conversion utility, you should remove the DTW-generated QSF timing assignments and re-run the conversion utility. The conversion utility creates some incompatible SDC constraints from the DTW QSF assignments.

## HardCopy Stratix Device Handoff

If you target the HardCopy device family, you should not use the Quartus II TimeQuest Timing Analyzer. The Quartus II TimeQuest Timing Analyzer is not supported for the HardCopy Stratix design process. The Quartus II TimeQuest Timing Analyzer supports HardCopy II series devices.

## Unsupported SDC Features

Some SDC commands and features are not supported by the current version of the Quartus II TimeQuest Timing Analyzer. The following commands are included:

- The **get\_designs** command, because the Quartus II software supports a single design, so this command is not necessary
- True latch analysis with time-borrowing feature; it can, however, convert latches to negative-edge-triggered registers
- The case analysis feature

- Loads, clock transitions, input transitions, and other features

## Constraint Passing

The Quartus II software can read constraints generated by other EDA software, and write constraints to be read by other EDA software.

Other synthesis software can generate constraints that target the QSF file. If you change timing constraints in synthesis software after creating an SDC file for the Quartus II TimeQuest Timing Analyzer, you must update the SDC constraints. You can use the conversion utility, or update the SDC file manually.

## Optimization

Gate-level re-timing is not supported if you turn on the Quartus II TimeQuest Timing Analyzer as your default timing analyzer.

If you use physical synthesis with the Quartus II TimeQuest Timing Analyzer, the design may have lower performance.

## Clock Network Delay Reporting

In the Quartus II software version 6.0, the Quartus II TimeQuest Timing Analyzer reports delay on the clock network as a single number, rather than node-to-node segments, as the Quartus II Classic Timing Analyzer does. Beginning with version 6.0 SP1, the TimeQuest Timing Analyzer reports delay on the clock network by node-to-node segments.

## PowerPlay Power Analysis

You must perform the following steps to generate an **Early Power Estimator** output file when you use the Quartus II TimeQuest Timing Analyzer and your design targets one of the following device families:

- Cyclone
- Stratix
- HardCopy Stratix

To generate an **Early Power Estimator** output file for designs targeting those families, you must perform the following steps.

1. Turn off the Quartus II TimeQuest Timing Analyzer. Refer to “[Set the Default Timing Analyzer](#)” on page [8-4](#) to learn how to turn off the Quartus II TimeQuest Timing Analyzer.

2. Manually convert your Quartus II TimeQuest Timing Analyzer timing constraints in the SDC file to Quartus II Classic Timing Analyzer timing assignments. You can use the Assignment Editor to enter your Quartus II Classic Timing Analyzer timing assignments in your QSF file.
3. Perform Quartus II Classic timing analysis.
4. Generate an **Early Power Estimator** output file.
5. Turn on the Quartus II TimeQuest Timing Analyzer.

## Project Management

If you use the **project\_open** Tcl command in the Quartus II TimeQuest Timing Analyzer to open a project compiled with an earlier version of the Quartus II software, the Quartus II TimeQuest Timing Analyzer overwrites the compilation results (\db folder) without warning. Opening a project any other way results in a warning, and you can choose not to open the project.

## Conversion Utility

This section describes the notes for the QSF assignment to SDC constraint conversion utility.

### *t<sub>PD</sub> and Minimum t<sub>PD</sub> Requirement Conversion*

The conversion utility treats the targets of single-point t<sub>PD</sub> and minimum t<sub>PD</sub> assignments as device outputs. It does not correctly convert targets of single-point t<sub>PD</sub> and minimum t<sub>PD</sub> assignments that are device inputs. The following QSF assignment applies to an a device input named d\_in:

```
set_instance_assignment -name TPD_REQUIREMENT -to d_in "3 ns"
```

The conversion utility creates the following SDC command, regardless of whether d\_in is a device input or device output:

```
set_max_delay "3 ns" -from [get_ports *] -to [get_ports d_in]
```

You must update any incorrect SDC constraints manually.

## Referenced Documents

This chapter references the following documents:

- *Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*
- *SDC and TimeQuest Tcl API Reference Manual*

## Document Revision History

Table 8–17 shows the revision history for this chapter.

| <b>Table 8–17. Document Revision History (Part 1 of 2)</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                |
|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|
| <b>Date and Version</b>                                    | <b>Changes Made</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <b>Summary of Changes</b>                                                      |
| May 2008<br>v8.0.0                                         | <ul style="list-style-type: none"> <li>● Updated to Quartus II software version 8.0 and date.</li> <li>● Added hyperlinks to referenced Altera documentation throughout the chapter.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | —                                                                              |
| October 2007<br>v7.2.0                                     | No changes were made to the content.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | —                                                                              |
| May 2007<br>v7.1.0                                         | Updated chapter for Quartus II software version 7.1, including: <ul style="list-style-type: none"> <li>● Minor changes to the “Timing Assignment Conversion” section, including:               <ul style="list-style-type: none"> <li>● Updated data on Table 7–6 on page 7–43</li> <li>● Updated data on Table 7–7 on page 7–45</li> <li>● Updated data on Table 7–8 on page 7–47</li> <li>● Updated data on Table 7–9 on page 7–49</li> <li>● Updated data on Table 7–12 on page 7–59</li> <li>● Added multicycle_hold information on pages 7–60 and 7–60</li> </ul> </li> <li>● Added new section “Paths between Unrelated Clock Domains” on page 7–63</li> <li>● Added new section “Ignored Entity Assignment (Entity &lt;entity&gt;: &lt;variable&gt; = &lt;value&gt; -from &lt;from&gt; -to &lt;to&gt;” on page 7–65.</li> </ul> | Changes made to this chapter reflect the software changes made in version 7.1. |
| March 2007<br>v7.0.0                                       | Updated Quartus II software 7.0 revision and date only. No other changes made to chapter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | —                                                                              |

**Table 8-17. Document Revision History (Part 2 of 2)**

| Date and Version        | Changes Made                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Summary of Changes                                                                                                                                                                      |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| November 2006<br>v6.1.0 | <p>Minor changes made to reflect the Quartus II software version 6.1.0, including:</p> <ul style="list-style-type: none"> <li>Changed wording on pages 7-4 and 7-5, regarding setting the default timing analyzer.</li> <li>Changed Figure 7-3 on page 7-10 to reflect that the TimeQuest Timing Analyzer does not create nor convert any constraints.</li> <li>Changed explanation of Figure 7-3 to reflect that TimeQuest does not create nor convert any constraints.</li> <li>Changed wording in “Constraint Target Types” to reflect that the TimeQuest Timing Analyzer now supports mixed exception types.</li> </ul>                                                                                                                                                                                                                                                   | Changes made to this chapter reflect the software changes made in version 6.1, GUI changes that were made to select the default timing analyzer, and support for mixed exception types. |
| July 2006<br>v6.0.1     | <p>Updated for the Quartus II software version 6.0.1:</p> <ul style="list-style-type: none"> <li>Added section on Clock Objects on page 7-24.</li> <li>Added examples of Netlist Names on page 7-29.</li> <li>Replaced figure 7-23 and example 7-9 on page 7-36.</li> <li>Added note 4 to table 7-6 on page 7-43.</li> <li>Added “Display Entity Name” to table 7-11 on page 7-57.</li> <li>Added information to Clock Conversion on pages 7-58 and 7-59.</li> <li>Added note 3 to table 7-12 on page 7-60.</li> <li>Added information to Clocks section on page 7-67.</li> <li>Added Path Details and Unconstrained Paths sections on page 7-68.</li> <li>Added information to Clock Network Delay Reporting on page 7-72.</li> <li>Added hand paragraph in Conversion Utility section on page 7-73.</li> <li>Changed “constraint” to “exception” in many places.</li> </ul> | —                                                                                                                                                                                       |
| May 2006<br>v6.0.0      | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | —                                                                                                                                                                                       |



### Introduction

Static timing analysis is a method for analyzing, debugging, and validating the timing performance of a design. The classic timing analyzer analyzes the delay of every design path and analyzes all timing requirements to ensure correct circuit operation. Static timing analysis, used in conjunction with functional simulation, allows you to verify overall design operation.



For information about switching to the Quartus® II TimeQuest Timing Analyzer, refer to the *Switching to the Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

As part of the compilation flow, the Quartus II software automatically performs a static timing analysis so that you do not need to launch a separate timing analysis tool. The Quartus II Classic Timing Analyzer checks every path in the design against your timing constraints for timing violations and reports results in the Timing Analysis reports, giving you immediate access to the data.

This chapter assumes you have some Tcl expertise; Tcl commands are used throughout this chapter to describe alternative methods for making timing analysis assignments. Refer to *“Timing Analysis Using the Quartus II GUI”* on page 9–43 for GUI-equivalent timing constraints.

This chapter details the following aspects of timing analysis:

- [“Timing Analysis Tool Setup”](#) on page 9–2
- [“Static Timing Analysis Overview”](#) on page 9–2
- [“Clock Settings”](#) on page 9–8
- [“Clock Types”](#) on page 9–9
- [“Clock Uncertainty”](#) on page 9–11
- [“Clock Latency”](#) on page 9–12
- [“Timing Exceptions”](#) on page 9–15
- [“I/O Analysis”](#) on page 9–26
- [“Asynchronous Paths”](#) on page 9–30
- [“Skew Management”](#) on page 9–34
- [“Generating Timing Analysis Reports with report\\_timing”](#) on page 9–36
- [“Other Timing Analyzer Features”](#) on page 9–38
- [“Timing Analysis Using the Quartus II GUI”](#) on page 9–43
- [“Scripting Support”](#) on page 9–52
- [“MAX+PLUS II Timing Analysis Methodology”](#) on page 9–58

## Timing Analysis Tool Setup

The Quartus II software version 6.0 and above supports two static timing analysis tools namely, the classic timing analyzer and the Quartus II TimeQuest Timing Analyzer. Use the **Timing Analysis** option under the Settings menu to set the Timing Analyzer that is used in the compilation process.



Arria GX is not supported by the Quartus II Classic Timing Analyzer. To perform a static timing analysis for Arria GX, the Quartus II TimeQuest Timing Analyzer must be enabled.

The following steps set the classic timing analyzer as the default timing analysis tool in the Quartus II software.

1. On the Assignments menu, click **Settings**. The Settings dialog box appears.
2. In the Category list, click the  icon next to **Timing Analysis Settings** to expand the folder.
3. Select the **Use Classic Timing Analyzer during compilation** radio button.



Refer to the *Quartus II TimeQuest Timing Analyzer* chapter of the *Quartus II Handbook* for more information about the Quartus II TimeQuest Timing Analyzer.

## Static Timing Analysis Overview

This section provides information about static timing analysis concepts used throughout this chapter and used by the Quartus II Classic Timing Analyzer. A complete understanding of the concepts presented in this section allows you to take advantage of the powerful static timing analysis features available in the Quartus II software.

Various paths exist within any given design which connect design elements together, including the path from an output of a register to the input of another register. Timing paths play a significant role during a static timing analysis. Understanding the types of timing paths is important for timing closure and optimization. Some of the commonly analyzed paths are described in this section and are shown in Figure 9–1.

- **Clock paths**—Clock paths are the paths from device pins or internally generated clocks (nodes designated as a clock via a clock setting) to the clock ports of sequential elements such as registers.
- **Data paths**—Data paths are the paths from the data output port of a sequential element to the data input port of another sequential element.

- **Asynchronous paths**—Asynchronous paths are paths from a node to the asynchronous set or clear port of a sequential element.

**Figure 9–1. Path Types**



Once the path types are identified, the classic timing analyzer computes data and clock arrival times for all valid register-to-register paths. Data arrival time is the delay from the source clock to the destination register. The Quartus II Classic Timing Analyzer calculates this delay by adding the clock path delay to the source register, the micro clock-to-out ( $\mu t_{CO}$ ) of the source register, and the data path delay from the source register to the destination register. Clock arrival time is the delay from the destination clock node to the destination register. [Figure 9–2](#) shows a data arrival path and a clock arrival path.

**Figure 9–2. Data Arrival and Clock Arrival**



In addition to identifying various paths within a design, the Quartus II Classic Timing Analyzer analyzes clock characteristics to compute the worst-case requirement between any two registers in a single register-to-register path. You must use timing constraints to specify the characteristics of all clock signals in the design before this analysis occurs.

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

Figure 9–3 shows a single-cycle system that uses consecutive clock edges to transmit 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.

**Figure 9–3. Launch Edge and Latch Edge**



By analyzing specific paths relative to the launch and latch edges, the Quartus II Classic Timing Analyzer performs clock setup and clock hold checks, validating them against your timing assignments.

## Clock Analysis

A comprehensive static timing analysis includes analysis of register-to-register, I/O, and asynchronous reset paths. Static Timing Analysis tools use data required times, data arrival times, and clock arrival times to verify circuit performance and detect possible timing violations. The Quartus II Classic 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 determine if a design meets performance, the Quartus II Classic Timing Analyzer calculates clock timing, timing requirements, and timing exceptions to perform a clock setup check at each destination register based on the source and destination clocks and timing constraints, or exceptions that are applicable to those paths. A clock setup check ensures that data launched by a source register is latched correctly by the destination register. To perform a clock setup check, the Quartus II Classic Timing Analyzer determines the clock arrival time and data arrival time at the destination register by using the longest path for the

data arrival time and the shortest path for the clock arrival time. The Quartus II Classic Timing Analyzer then checks that the difference is greater than or equal to the micro setup ( $t_{SU}$ ) of the destination register as shown in [Equation 1](#).

$$(1) \quad \text{Clock Arrival Time} - \text{Data Arrival Time} \geq \text{micro } t_{SU}$$



By default, the Quartus II Classic Timing Analyzer assumes the launched and latched edges happen on consecutive active clock edges.

The results of clock setup checks are reported in terms of slack. 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, and negative slack indicates the margin by which a requirement is not met. The Quartus II Classic Timing Analyzer determines clock setup slack using [Equations 2 through 5](#).

$$(2) \quad \text{Clock Setup Slack} = \text{Data Required Time} - \text{Data Arrival Time}$$

$$(3) \quad \text{Data Required} = \text{Clock Arrival Time} - \text{micro } t_{SU} - \text{Setup Uncertainty}$$

$$(4) \quad \text{Clock Arrival Time} = \text{Latch Edge} + \text{Shortest Clock Path to Destination Register}$$

$$(5) \quad \text{Data Arrival Time} = \text{Launch Edge} + \text{Longest Clock Path to Source Register} + \text{micro } t_{CO} + \text{Longest Data Delay}$$

The Quartus II Classic Timing Analyzer reports clock setup slack using [Equations 6 through 9](#) (which are equivalent to [Equations 2 through 5](#)).

$$(6) \quad \text{Clock Setup Slack} = \text{Largest Register-to-Register Requirement} - \text{Longest Register-to-Register Delay}$$

$$(7) \quad \text{Largest Register-to-Register Requirement} = \text{Setup Relationship between Source and Destination} + \text{largest clock skew} - \text{micro } t_{CO} \text{ of Source Register} - \text{micro } t_{SU} \text{ of Destination Register}$$

$$(8) \quad \text{Setup Relationship between Source \& Destination Register} = \text{Latch Edge} - \text{Launch Edge} - \text{Setup Uncertainty}$$

$$(9) \quad \text{Largest Clock Skew} = \text{Shortest Clock Path to Destination Register} - \text{Longest Clock Path to Source Register}$$

Both sets of equations can be used to determine the slack value of any path.

### Clock Hold Check

To prevent hold violations, the Quartus II Classic Timing Analyzer calculates clock timing, timing requirements, and timing exceptions to perform a clock hold check at each destination register. A clock hold check ensures data launched from the source register is not captured by an active clock edge earlier than the setup latch edge, and that the destination register does not capture data launched from the next active launch edge. To perform a clock hold check, the Quartus II Classic Timing Analyzer determines the clock arrival time and data arrival time at the destination register using the shortest path for the data arrival time and the longest path for the clock arrival time. The Quartus II Classic Timing Analyzer checks that the difference is greater than or equal to the micro hold time ( $t_H$ ) of the destination register, as shown in [Equation 10](#).

$$(10) \quad \text{Data Arrival Time} - \text{Clock Arrival Time} \geq t_H$$

The Quartus II Classic Timing Analyzer determines clock hold slack using [Equations 11](#) through [14](#).

$$(11) \quad \text{Clock Hold Slack} = \text{Data Arrival Time} - \text{Data Required Time}$$

$$(12) \quad \text{Data Required Time} = \text{Clock Arrival Time} + \text{micro } t_H + \text{Hold Uncertainty}$$

$$(13) \quad \text{Clock Arrival Time} = \text{Latch Edge} + \text{Longest Clock Path to Destination Register}$$

$$(14) \quad \text{Data Arrival Time} = \text{Launch Edge} + \text{Shortest Clock Path to Source Register} + \text{micro } t_{CO} + \text{Shortest Data Delay}$$

The Quartus II Classic Timing Analyzer reports clock hold slack using [Equations 15](#) through [18](#).

$$(15) \quad \text{Clock Hold Slack} = \text{Shortest Register-to-Register Delay} - \text{Smallest Register-to-Register Requirement}$$

$$(16) \quad \text{Smallest Register-to-Register Requirement} = \text{Hold Relationship between Source \& Destination} + \text{Smallest Clock Skew} - \text{micro } t_{CO} \text{ of Source Register} + \text{micro } t_H \text{ of Destination Register}$$

$$(17) \quad \text{Hold Relationship between Source and Destination Register} = \text{Latch} - \text{Launch} + \text{Hold Uncertainty}$$

$$(18) \quad \text{Smallest Clock Skew} = \text{Longest Clock Path from Clock to Destination Register} - \text{Shortest Clock Path from Clock to Source Register}$$

These equations can be used to determine the slack value of any 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 9-4 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.

Refer to “[Multicycle](#)” on page 9-15 for more information about multicycle exceptions.

**Figure 9-4. Example Diagram of a Multicycle Path**



Figure 9-5 shows the default clock setup analysis launch and latch edges where multicycle assignment is equal to 1.

**Figure 9-5. Default Clock Setup Analysis**



Figure 9–6 shows an analysis similar to Figure 9–5, but with a multicycle of 2.

**Figure 9–6. Multicycle = 2 Clock Setup Analysis**



## Clock Settings

You can use individual and default clock settings to define the clocks in your design. You can base these clock settings on other clock settings already defined in your design.



To ensure the Quartus II Fitter achieves the desired performance requirements and the Quartus II Classic Timing Analyzer performs a thorough static timing analysis, you must specify all timing assignments prior to compiling the design.

### Individual Clock Settings

Individual clock settings allow you to specify clock properties including performance requirements, offsets, duty cycles, and other properties for individual clock signals in your design.

You can define individual clock settings using the `create_base_clock` Tcl command. The following example defines an individual clock setting named `sys_clk` with a requirement of 100 MHz (10 ns), and assigns it to clock node `clk`.

```
create_base_clock -fmax 100MHz -target clk sys_clk
```

### Default Clock Settings

You can assign a project-wide clock requirement to constrain all detected clocks in a design that do not have individual clock settings.

The `set_global_assignment -name FMAX_REQUIREMENT` Tcl command specifies a global default requirement assignment. The following example defines a 100 MHz default clock requirement:

```
set_global_assignment -name FMAX_REQUIREMENT "100.0 MHz"
```



For best placement and routing results, apply individual clock settings to all clocks in your design. All clocks adopting the default  $F_{MAX}$  are by default unrelated.

## Clock Types

This section describes the types of clocks recognized by the Timing Analyzer:

- Base clocks
- Derived clocks
- Undefined clocks
- PLL clocks

### Base Clocks

A base clock is independent of other clocks in a design. For example, a base clock is typically a clock signal driven directly by a device pin. A base clock is defined by individual clock settings, or automatically detected using the default clock setting.

You can use the `create_base_clock` Tcl command to define a base clock setting and assign the clock setting to a clock node. The following Tcl command creates a clock setting called `sys_clk` with a requirement of 5 ns (200 MHz) and applies the clock setting to clock node `main_clk`:

```
create_base_clock -fmax 5ns -target main_clk sys_clk
```

### Derived Clocks

A derived clock is based on a previously defined base clock. For a derived clock, you can specify the phase shift, offset, multiplication and division factors, and duty cycle relative to the base clock.

You can use the `create_relative_clock` Tcl command to define and assign a derived clock setting. The following example creates a derived clock setting named `system_clockx2` that is twice as fast as the base clock `system_clock` applied to clock node `clkx2`.

```
create_relative_clock -base_clock system_clock -duty_cycle 50 \
-multiply 2 -target clkx2 system_clockx2
```

## Undefined Clocks

The Quartus II Classic Timing Analyzer detects undeclared clocks in your design and displays a warning similar to the following:

```
Warning: Found pins functioning as undefined clocks and/or memory
enables
Info: Assuming node "clk_src" is an undefined clock
Info: Assuming node "clk_dst" is an undefined clock
```

The Quartus II Classic Timing Analyzer reports actual data delay for undefined clocks, but because no clock requirements exist for undefined clocks, the Quartus II Classic Timing Analyzer does not report slack for any register-to-register paths driven by an undefined clock.

## PLL Clocks

Phase-locked loops (PLLs) are used for clock synthesis in Altera® devices. This device feature is configured and connected to your design using the altpll megafunction included with the Quartus II software. Using the MegaWizard® Plug-In Manager, you can customize the input clock frequency, multiplication factors, division factors, and other parameters of the altpll megafunction.



For more information about using the PLL feature in your design, refer to the [altpll Megafunction User Guide](#) or the handbook for the targeted device family.

For PLLs, the Quartus II Classic Timing Analyzer automatically creates derived clock settings based on the parameterization of the PLL and automatically creates a base clock setting for the input clock pin. For example, if the input clock frequency to a PLL is 100 MHz and the multiplication and division ratio is 5:2, the clock period of the PLL clock is set to 4.0 ns and is automatically calculated by the Quartus II Classic Timing Analyzer.

For the Stratix® and Cyclone® device families, you can override the PLL input clock frequency by applying a clock setting to the input clock pin of the PLL. For example, if the PLL input clock period is set to 10 ns (100 MHz) with a multiplication and division ratio of 5:2, but a clock setting of 20 ns (50 MHz) is applied to the input clock pin of the PLL, the setup relationship is 8.0 ns (125 MHz) and not 4.0 ns (250 MHz). The Quartus II Classic Timing Analyzer issues a message similar to the following:

```
Warning: ClockLock PLL
"mypll_test:inst|altpll:altpll_component|_clk1" input frequency
requirement of 200.0 MHz overrides default required fmax of 100.0
MHz -- Slack information will be reported
```



You cannot override the PLL output clock frequency with a clock setting in the Quartus II Classic Timing Analyzer.

## Clock Uncertainty

You can use **Clock Setup Uncertainty** and **Clock Hold Uncertainty** assignments to model jitter, skew, or add a guard band associated with clock signals.

When a clock uncertainty assignment exists for a clock signal, the Timing Analyzer performs the most conservative setup and hold checks. For clock setup check, the setup uncertainty is subtracted from the data required time. [Figure 9-7](#) shows an example of clock sources with a clock setup uncertainty applied.

**Figure 9-7. Clock Setup Uncertainty**



You can create clock uncertainty assignments using the Tcl command `set_clock_uncertainty`. The `set_clock_uncertainty` assignment used with the switch `-setup` specifies a clock setup uncertainty assignment. The following example creates a **Clock Setup Uncertainty** assignment with a value of 2 ns applied to clock signal `clk`:

```
set_clock_uncertainty -to clk -setup 2ns
```

For the clock hold check, the hold uncertainty is added to the data required time. [Figure 9-8](#) shows an example of clock setup check with a clock setup uncertainty and clock hold uncertainty applied.

**Figure 9–8. Clock Hold Uncertainty**

You can use the `set_clock_uncertainty` Tcl command with the option `-hold` to specify a **Clock Hold Uncertainty** assignment. The following example creates a **Clock Hold Uncertainty** assignment with a value of 2 ns for clock signal `clk`.

```
set_clock_uncertainty -to clk -hold 2ns
```

You can also apply the clock uncertainty assignments between two clock sources. The following example creates a **Clock Setup Uncertainty** assignment for clock setup checks where `clk1` is the source clock and `clk2` is the destination clock:

```
set_clock_uncertainty -from clk1 -to clk2 -setup 2ns
```

## Clock Latency

You can use clock latency assignments to model delays from the clock source. For example, you can use clock latency to model an external delay from an ideal clock source, such as an oscillator, to the clock pin or port of the device.

The **Early Clock Latency** assignment allows you to specify the shortest or earliest delay of the clock source. Conversely, the **Late Clock Latency** assignment allows you to specify the longest or latest delay of the clock source.

During setup analysis, the Quartus II Classic Timing Analyzer adds the **Late Clock Latency** assignment value to the source clock path delay and adds the **Early Clock Latency** assignment value to the destination clock path delay when determining clock skew for the path. During clock hold analysis, the Quartus II Classic Timing Analyzer adds the **Early Clock Latency** assignment value to the source clock path delay and adds the **Late Clock Latency** assignment value to the destination clock path delay when determining clock skew for the path.

The **Early Clock Latency** and **Late Clock Latency** assignments do not change the latch and launch edges defined by the clock setting and therefore does not change the setup or hold relationships between source and destination clocks. The clock latency assignments add only delay to the clock network and therefore only affects clock skew.

Figure 9–9 shows the clock edges used to calculate clock skew for a setup check when the **Early Clock Latency** and **Late Clock Latency** assignments are used.

**Figure 9–9. Clock Setup Check Clock Skew**



Figure 9–10 shows the clock edges used to calculate clock skew for a hold check when the **Early Clock Latency** and **Late Clock Latency** assignments are used.

**Figure 9–10. Clock Hold Check Clock Skew**





The Quartus II Classic Timing Analyzer ignores clock latency if the clock signal at the source and destination registers are the same.

You can use the `set_clock_latency` Tcl command with the switches `-early` or `-late` to specify an **Early Clock Latency** assignment or **Late Clock Latency** assignment, respectively. [Example 9-1](#) specifies that the clock signal at `clk2` arrives as early as 1.8 ns and as late as 2.0 ns.

---

**Example 9-1. Specifying Early or Late Clock Latency at `clk2`**

```
set_clock_latency -early -to clk2 1.8ns
set_clock_latency -late -to clk2 2ns
```

---



The early clock latency default value is the same as the late clock latency delay, and the late clock latency default value is the same as the early clock latency delay, if only one is specified.

The **Enable Clock Latency** option must be set to **ON** for the Quartus II Classic Timing Analyzer to analyze clock latency. When this option is set to **ON**, the Quartus II Classic Timing Analyzer reports clock latency as part of the clock skew calculation for either the source or destination clock path depending upon the analysis performed. To set the **Enable Clock Latency** option to **ON**, you can use the following Tcl command:

```
set_global_assignment -name ENABLE_CLOCK_LATENCY ON
```

When the **Enable Clock Latency** option is enabled, the Quartus II Classic Timing Analyzer automatically calculates latencies for derived clocks instead of automatically calculating offsets; for example, PLL compensation delays. These clock path delays are accounted for as clock skew instead of part of the setup or hold relationship as done with offsets.



For more information about clock latency, refer to [AN 411: Understanding PLL timing for Stratix II Devices](#).

# Timing Exceptions

Timing exceptions allow you to modify the default behavior of the Quartus II Classic Timing Analyzer. This section describes the following timing exceptions:

- Multicycle
- Setup relationship and hold relationship
- Maximum delay and minimum delay
- False paths



Not all timing exceptions presented in this chapter are applicable to the HardCopy® II devices. If you are designing for the HardCopy II device family, refer to the *Timing Constraints for HardCopy II Devices* chapter in the *HardCopy II Handbook*.

## Multicycle

By default, the Quartus II Classic Timing Analyzer performs a single-cycle analysis for all valid register-to-register paths in the design. Multicycle assignments specify the number of clock periods before a source register launches the data or a destination register latches the data. Multicycle assignments adjust the latch or launch edges, which relaxes the required clock setup check or clock hold check between the source and destination register pairs. You can specify multicycles separately for setup and hold, and multicycles can be based on the source clock or destination clock. Apply **Multicycle** exception to time groups, clock nodes, or common clock enables.

### *Destination Multicycle Setup Exception*

A destination multicycle setup, referred to as a **Multicycle** exception, specifies the minimum number of clock cycles required before a register should latch a value. A **Multicycle** exception changes the latch edge by relaxing the required setup relationship. [Figure 9–11](#) shows a timing diagram for a multicycle path that exists in a design with related clocks, and with the latch edge label for a clock setup check.



By default, the **Multicycle** exception value is 1.

**Figure 9–11. Multicycle Setup**

You can apply **Multicycle** exception between any two registers or between any two clock domains. Use the Tcl command `set_multicycle_assignment`, and the switch `-setup` and `-end`. For example, to apply a **Multicycle** exception of 2 between all registers clocked by source clock `clk_src`, and all registers clocked by destination clock `clk_dst`, enter the following Tcl command:

```
set_multicycle_assignment -setup -end -from clk_src -to clk_dst 2
```

To apply a **Multicycle** exception of 2 between the source register `reg1` and the destination register `reg2`, enter the following Tcl command:

```
set_multicycle_assignment -setup -end -from reg1 -to reg2 2
```

#### *Destination Multicycle Hold Exception*

A destination multicycle hold, referred to as a **Multicycle Hold** exception, modifies the latch edge used for a clock hold check for the register-to-register path based on the destination clock. A **Multicycle Hold** exception changes the latch edge by relaxing the required hold relationship. [Figure 9–12](#) shows a timing diagram labeling the latching edge for a clock setup check.



If no **Multicycle Hold** value is specified, the **Multicycle Hold** value defaults to the value of the multicycle exception.

**Figure 9–12. Multicycle Hold**

You can create **Multicycle Hold** exceptions with the Tcl command `set_multicycle_assignment` and the switch `-hold` and `-end`. The following example specifies a **Multicycle Hold** exception of 3 from register `reg1` to register `reg2`:

```
set_multicycle_assignment -hold -end -from reg1 -to reg2 3
```

By default, the hold multicycle is set to equal that of the setup multicycle value along the same path. For example, if a setup multicycle of 2 has been applied to a register-to-register path without a separate hold multicycle, the hold multicycle value would be set to 2. The default hold multicycle value can also be changed to a value of 1. This forces all paths with a setup multicycle assignment to have a default hold multicycle of 1. To change the default hold multicycle value, in the **Settings** dialog box, click the **More Timing Settings** option.

If your design requires a hold multicycle value not equal to the setup multicycle or 1, you must explicitly apply a hold multicycle assignment to the path.

### *Source Multicycle Setup Exception*

A source multicycle setup, referred to as **Source Multicycle Setup** exception, is used to extend the required delay by adjusting the source clock's launch edge rather than the destination clock's latch edge; for example, multicycle setup. **Source Multicycle** exceptions are useful when the source and destination registers are clocked by related clocks at different frequencies. Figure 9–13 shows an example of a **Source Multicycle** exception with the launch edge labeled for a clock setup check.

**Figure 9–13. Source Multicycle**

You can create **Source Multicycle Setup** exceptions with the Tcl command `set_multicycle_assignment` and the switches `-setup` and `-start`. The following example specifies a **Source Multicycle** exception of 3 from register `reg1` to register `reg2`:

```
set_multicycle_assignment -setup -start -from reg1 -to reg2 3
```

By default, the hold multicycle is set to equal that of the setup multicycle value along the same path. For example, if a setup multicycle of 2 has been applied to a register-to-register path without a separate hold multicycle, the hold multicycle value would be set to 2. The default hold multicycle value can also be changed to a value of 1. This forces all paths with a setup multicycle assignment to have a default hold multicycle of 1. To change the default hold multicycle value, in the **Settings** dialog box, click the **More Timing Settings** option.

If your design requires a hold multicycle value not equal to the setup multicycle or 1, you must explicitly apply a hold multicycle assignment to the path.

#### *Source Multicycle Hold Exception*

The **Source Multicycle Hold** exception modifies the latch edge used for a clock hold check for the register-to-register path based on the source clock. **Source Multicycle Hold** exceptions increase the required hold delay by adding source clock cycles. [Figure 9–14](#) shows an example of a source multicycle hold with launch edge labeled for a clock hold check.

**Figure 9–14. Source Multicycle Hold**

You can create **Source Multicycle Hold** exceptions with the Tcl command `set_multicycle_assignment` and the switch `-setup` and `-start`. The following example specifies a **Source Multicycle Hold** exception of 3 from register `reg1` to register `reg2`:

```
set_multicycle_assignment -hold -start -from reg1 -to reg2 3
```

#### *Default Hold Multicycle*

The Quartus II Classic Timing Analyzer sets the hold multicycle value to equal the multicycle value when a multicycle exception has been entered without a corresponding hold multicycle. You can change the behavior with the `DEFAULT_HOLD_MULTICYCLE` assignment. The value of the assignment can either be "ONE" or "SAME AS MULTICYCLE".

The assignment has the following syntax:

```
set_global_assignment -name DEFAULT_HOLD_MULTICYCLE "<value>"
```

#### *Clock Enable Multicycle*

For all enable-driven registers, the setup relationship or hold relationship can be modified with the **Clock Enable Multicycle**, **Clock Enable Multicycle Hold**, **Clock Enable Source Multicycle**, or **Clock Enable Multicycle Source Hold**.

The **Clock Enable Multicycle** modifies the latching edge when a clock setup check is performed for all registers driven by the specified clock enables, and the **Clock Enable Multicycle Hold** modifies the latching edge when a clock hold check is performed for all registers driven by the specified clock enable. The **Clock Enable Source Multicycle** modifies the launching edge when a clock setup check is performed for all enabled driven registers, and the **Clock Enable Source Multicycle Hold** modifies the launching edge when a clock hold check is performed for all enabled driven registers.



Clock enable-based multicycle exceptions apply only to registers using dedicated clock enable circuitry. If the enable is synthesized into a logic cell; for example, due to signal prioritization, the multicycle does not apply.

The **Clock Enable Multicycle**, **Clock Enable Multicycle Hold**, **Clock Enable Source Multicycle**, and **Clock Enable Multicycle Source Hold** can be either a single-point or a point-to-point assignment. Figure 9–15 shows an example of a single-point assignment. In this example, register Reg A has the single-point assignment applied. This has the effect of modifying a register-to-register latching edge whose enable port is driven by register Reg A. All register-to-register paths with enables driven by the single-point assignment are affected, even those driven by different clock sources.

**Figure 9–15. Single-Point Clock Enable Multicycle**



Point-to-point assignments apply to all paths where the source registers' enable ports are driven by the source (from) node and the destination registers' enable ports are driven by the destination (to) node.

Figure 9–16 shows an example of a point-to-point assignment made to different source and destination registers. In this example, register Reg A is specified as the source, and register Reg B is specified as the destination for the assignment. Only register-to-register paths that have their enables driven by the assigned point-to-point registers have their latching edges modified.

**Figure 9–16. Different Source and Destination Point-to-Point Assignment Clock Enable Multicycle**



Figure 9–17 shows an example of a point-to-point assignment made to the same source and destination register. In this example, register Reg A has been specified as both the source and register for the assignment. Only register-to-register paths that have both the source-enable port and destination-enable port has the latching edge modified by the assigned point-to-point assignment.

**Figure 9–17. Same Source and Destination Point-to-Point Assignment Clock Enable Multicycle**



You can use the `set_instance_assignment -name CLOCK_ENABLE_MULTICYCLE` and `set_instance_assignment -name CLOCK_ENABLE_MULTICYCLE_HOLD` Tcl commands to specify either a **Clock Enable Multicycle** or a **Clock Enable Multicycle Hold** assignment, respectively. The following example specifies a single-point **Clock Enable Multicycle** assignment of 2 ns to reg1:

```
set_instance_assignment -name CLOCK_ENABLE_MULTICYCLE 2 -to reg1
```

The following example specifies a point-to-point **Clock Enable Multicycle Hold** assignment of 2 from register reg1 to register reg2:

```
set_instance_assignment -name CLOCK_ENABLE_MULTICYCLE_HOLD 2 \
-from reg1 -to reg2
```

You can use the `set_instance_assignment -name CLOCK_ENABLE_SOURCE_MULTICYCLE` and `set_instance_assignment -name CLOCK_ENABLE_SOURCE_MULTICYCLE_HOLD` Tcl commands to specify either a **Clock Enable Multicycle** or **Clock Enable Multicycle Hold** assignment, respectively. The following example specifies a single-point **Clock Enable Multicycle** assignment of 2 ns to reg1:

```
set_instance_assignment -name CLOCK_ENABLE_SOURCE_MULTICYCLE \
2 -to reg1
```

The following example specifies a point-to-point **Clock Enable Multicycle Hold** assignment of 2 from register reg1 to register reg2:

```
set_instance_assignment -name \
CLOCK_ENABLE_SOURCE_MULTICYCLE_HOLD 2 -from reg1 -to reg2
```

## Setup Relationship and Hold Relationship

By default, the Quartus II Classic Timing Analyzer determines all setup and hold relationships based on clock settings. The **Setup Relationship** and **Hold Relationship** exceptions allow you to override any default setup or hold relationships. [Example 9-2](#) shows the path details of a register-to-register path that has a 10 ns clock setting applied to the clock signal driving the 2 registers.

---

**Example 9–2. Default Setup Relationship with 10 ns Clock Setting**

```
Info: Slack time is 9.405 ns for clock "data_clk" between source register "reg9" and
destination register "reg10"
Info: Fmax is restricted to 500.0 MHz due to tcl and tch limits
Info: + Largest register to register requirement is 9.816 ns
Info: + Setup relationship between source and destination is 10.000 ns
Info: + Latch edge is 10.000 ns
Info: - Launch edge is 0.000 ns
Info: + Largest clock skew is 0.000 ns
Info: - Micro clock to output delay of source is 0.094 ns
Info: - Micro setup delay of destination is 0.090 ns
Info: - Longest register to register delay is 0.411 ns
```

---

In **Example 9–3**, a 15 ns **Setup Relationship** exception is applied to the register-to-register path, overriding the default 10 ns setup relationship.

---

**Example 9–3. Setup Relationship Assignment of 15 ns**

```
Info: Slack time is 14.405 ns for clock "data_clk" between source register "reg9" and
destination register "reg10"
Info: Fmax is restricted to 500.0 MHz due to tcl and tch limits
Info: + Largest register to register requirement is 14.816 ns
Info: + Setup relationship between source and destination is 15.000 ns
Info: Setup Relationship assignment value is 15.000 ns between source "reg9" and
destination "reg10"
Info: + Largest clock skew is 0.000 ns
Info: Total interconnect delay = 1.583 ns ( 51.31 % )
Info: - Micro clock to output delay of source is 0.094 ns
Info: - Micro setup delay of destination is 0.090 ns
Info: - Longest register to register delay is 0.411 ns
```

---

You can create a **Setup Relationship** exception with the Tcl command `set_instance_assignment -name SETUP_RELATIONSHIP`. The following example specifies a **Setup Relationship** exception of 5 ns from register reg1 to register reg2:

```
set_instance_assignment -name SETUP_RELATIONSHIP 5ns -from reg1 \
-to reg2
```

You can use **Hold Relationship** exception to override the default hold relationship of any register-to-register paths.

You can use the `set_instance_assignment -name HOLD_RELATIONSHIP` Tcl command to specify a hold relationship assignment. The following example specifies a **Hold Relationship** exception of 1 ns from register reg1 to register reg2:

```
set_instance_assignment -name HOLD_RELATIONSHIP 1ns -from reg1 \
-to reg2
```

## Maximum Delay and Minimum Delay

You can use **Maximum Delay** and **Minimum Delay** assignments to specify delay requirements for pin-to-register, register-to-register, and register-to-pin paths. The **Maximum Delay** assignment overrides any setup relationship for any path. The **Minimum Delay** assignment overrides any hold relationship for any path.



The Quartus II Classic Timing Analyzer ignores the effects of clock skew when checking a design against **Maximum Delay** and **Minimum Delay** assignments.

You can use the `set_instance_assignment -name MAX_DELAY` and `set_instance_assignment -name -MIN_DELAY` Tcl commands to specify a **Maximum Delay** assignment or a **Minimum Delay** assignment, respectively. The following example specifies a maximum delay of 2 ns between source register `reg1` and destination register `reg2`:

```
set_instance_assignment -name MAX_DELAY 2ns -from reg1 -to reg2
```

The following example specifies a minimum delay of 1 ns between input pin `data_in` to destination register `dst_reg`:

```
set_instance_assignment -name MIN_DELAY 1ns -from data_in -to \
dst_reg
```

## False Paths

A false path is any path that is not relevant to a circuit's operation, such as test logic. There are several global assignments to cut different classes of paths, such as unrelated clock domains and paths through bidirectional pins, but you can also cut an individual timing path to a specific false path.

The Timing Analyzer provides the following three global options that allow you to remove false paths from your design:

- Cut off feedback from I/O pins
- Cut off read-during-write signal paths
- Cut paths between unrelated clock domains

You can use the `set_global_assignment -name CUT_OFF_IO_PIN_FEEDBACK ON` Tcl command to cut the feedback path when a bidirectional I/O pin is connected directly or indirectly to both the input and output of a latch.

You can use the `set_global_assignment -name CUT_OFF_READ_DURING_WRITE_PATHS` ON Tcl command to cut the path from the write-enable register through memory element to a destination register.

You can use the `set_global_assignment -name CUT_OFF_PATHS_BETWEEN_CLOCK_DOMAINS` ON Tcl command to cut paths between register-to-register where the source and destination clocks are different.

You can use the `set_timing_cut_assignment` Tcl command to cut specific timing paths. In [Figure 9-18](#), the path from `inst1` through the multiplexer to `inst2` is used only for design testing. This false path is not required under normal operation and does not need to be analyzed during static timing analysis. [Figure 9-18](#) shows an example of a false path.

**Figure 9-18. False Path Signal**



To cut the timing path from source register `inst1` to destination register `inst2`, enter the following Tcl command:

```
set_timing_cut_assignment -from inst1 -to inst2
```

You can also use the `set_timing_cut_assignment` Tcl command as a single point assignment. When you use the single point assignment, all fanout of the node is cut. For example, the following Tcl command cuts all timing paths originating for node `src_reg`:

```
set_timing_cut_assignment -to src_reg
```

## I/O Analysis

The I/O analysis performed by the Quartus II Classic Timing Analyzer ensures your Altera FPGA design meets all timing specifications for interfacing with external devices. This section describes assignments relevant to I/O analysis and other I/O analysis features and options available with the Quartus II Classic Timing Analyzer.

### External Input Delay and Output Delay Assignments

External input and output delays represent delays from or to external devices or boards traces. You can make **Input Delay** and **Output Delay** assignments to ensure the Quartus II Classic Timing Analyzer can perform a full system analysis. By providing **Input Delays** and **Output Delays**, the Quartus II Classic Timing Analyzer is able to perform clock setup and clock hold checks for these paths. This also allows other timing assignments, such as multicycle or clock uncertainty, to be applied to input and output paths.



Do not combine individual or global  $t_{SU}$ ,  $t_H$ ,  $t_{PD}$ ,  $t_{CO}$ , minimum  $t_{CO}$ , or minimum  $t_{PD}$  assignments with **Input Delay** or **Output Delay** assignments.

#### *Input Delay Assignment*

External input delays are specified with either **Input Maximum Delay** or **Input Minimum Delay** assignments. Make **Input Maximum Delay** assignments to specify the maximum delay of a signal from an external register to a specified input or bidirectional pin on the FPGA relative to a specified clock source. Make **Input Minimum Delay** assignments to specify the minimum delay of a signal from an external register to a specified input or bidirectional pin on the FPGA relative to a specified clock source.

When performing a clock setup check, the Quartus II Classic Timing Analyzer adds the **Input Maximum Delay** assignment value to the data arrival time (or subtracts the assignment value from the point-to-point requirement).

When performing a clock hold check, the Quartus II Classic Timing Analyzer adds the **Input Minimum Delay** assignment value to the data arrival time (or subtracts the assignment value from the point-to-point requirement).

The value of the input delay assignment usually represents the sum of the  $t_{CO}$  of the external device, the actual board delay to the input pin of the Altera device, and the board clock skew.



The **Input Minimum Delay** defaults to the **Input Maximum Delay** and the **Input Maximum Delay** defaults to the **Input Minimum Delay** if only one is specified.

For example, the Input Maximum Delay and Input Minimum Delay can be used to model the delay associated with an external device driving into an Altera FPGA. Figure 9–19 shows an example of the input delay path. For Figure 9–19, the Input Maximum Delay can be calculated as shown in Equation 19.

$$(19) \quad \text{Input Maximum Delay} = \text{External Device Board Clock Path} + \text{External Device } t_{CO} + \text{External Device to Altera Device Board Delay} - \text{External Clock Path to Altera Device}$$

**Figure 9–19. Input Delay**



Use the Tcl command `set_input_delay` to specify an input delay. The following example specifies an **Input Maximum Delay** assignment of 1.5 ns from clock node `clk` to input pin `data_in`:

```
set_input_delay -clk_ref clk -to "data_in" -max 1.5ns
```

The following example specifies an **Input Minimum Delay** assignment of 1 ns from clock node `clk` to input pin `data_in`:

```
set_input_delay -clk_ref clk -to "data_in" -min 1ns
```

When using **Input Delay** assignments, specify a particular clock reference. The clock reference is the clock that feeds the external register's clock port that feeds the Altera device. This allows the Quartus II Classic Timing Analyzer to perform the proper analysis for the input path.



The  $t_{SU}$ ,  $t_H$ ,  $t_{PD}$ , and  $\min t_{PD}$  timing paths reported for input pins, where input delay internal to the Altera FPGA assignments has been applied, include only the data delay from these pins and do not account for any clock setup relationships, clock hold relationships, or slack.

### *Output Delay Assignment*

You can specify external output delays with either **Output Maximum Delay** or **Output Minimum Delay** assignments. Make **Output Maximum Delay** assignments to specify the maximum delay of a signal from the specified FPGA output pin to an external register, relative to a specified clock source. Make **Output Minimum Delay** assignments to specify the minimum delay of a signal from the specified FPGA output pin to an external register relative to a specified clock source.

When performing a clock setup check, the Quartus II Classic Timing Analyzer subtracts the **Output Maximum Delay** assignment value from the data required time (or subtracts the assignment value from the point-to-point requirement).

When performing a clock hold check, the Quartus II Classic Timing Analyzer subtracts the **Output Minimum Delay** assignment value from the data required time (or subtracts the assignment value from the point-to-point requirement).

The value of this assignment usually represents the sum of the  $t_{SU}$  of the external device, the actual board delay from the output pin of the Altera device, and the board clock skew.

 The **Output Minimum Delay** default value is the same as the **Output Maximum Delay**, and the **Output Maximum Delay** default value is the same as the **Output Minimum Delay** if only one is specified.

For example, use the **Output Maximum Delay** and **Output Minimum Delay** to model the delay associated with outputs for an Altera FPGA driving into an external device. [Figure 9–20](#) shows an example of an output delay path. For [Figure 9–20](#) the **Output Maximum Delay** can be calculated, as shown in [Equation 20](#).

$$(20) \quad \text{Output Maximum Delay} = \text{Altera Device to External Device Board Delay} + \\ \text{External Device } t_{SU} + \text{External Clock Path to Altera Device} - \\ \text{External Device Board Clock Path}$$

**Figure 9–20. Output Delay**

The Tcl command `set_output_delay` specifies an **Output Delay** assignment. The following example specifies an **Output Maximum Delay** assignment of 2 ns from clock `clk` to output pin `data_out`:

```
set_output_delay -clk_ref clk -to data_out -max 2ns
```

The following example specifies an **Output Minimum Delay** assignment of 1 ns from clock `clk` to output pin `data_out`:

```
set_output_delay -clk_ref clk -to data_out -min 1ns
```

When using output delay assignments, specify a specific clock reference. The clock reference is the clock that feeds the external register's clock port that is fed by the Altera device. This allows the Quartus II Classic Timing Analyzer to perform the correct static timing analysis on the output path.



The  $t_{CO}$ , minimum  $t_{CO}$ ,  $t_{PD}$ , and minimum  $t_{PD}$  timing paths reported for output pins, where output delay assignments have been applied include only the data delay internal to the Altera FPGA to those pins, and do not account for any clock setup relationships, clock hold relationships, or slack.

## Virtual Clocks

You can use virtual clocks to model clock signals outside of the Altera FPGA, that is, clocks that do not directly drive anything within the Altera FPGA. For example, you can use a virtual clock to model a clock signal feeding an external output register that feeds the Altera FPGA.

Using the `-virtual` option of the `create_base_clock` Tcl command specifies a virtual clock assignment.



Before you can use virtual clock for either an input or output delay assignment, the virtual clock must have the **Virtual Clock Reference** assignment enabled for the virtual clock setting.

The code in [Example 9-4](#) creates a virtual clock named `virt_clk`, with a 200 MHz requirement, and uses the virtual clock setting as the clock reference for the input delay assignment.

---

#### **Example 9-4. Creating a Virtual Clock Named `virt_clk`**

```
#create the virtual clock setting
create_base_clock -fmax 200MHz -virtual virt_clk

#enable the virtual clock reference for the virtual clock setting
set_instance_assignment -name VIRTUAL_CLOCK_REFERENCE On -to virt_clk

#use the virtual clock setting as the clock reference for the input delay assignment
set_input_delay -clk_ref virt_clk -to data_in -max 2ns
```

---

## **Asynchronous Paths**

The Quartus II Classic Timing Analyzer can analyze asynchronous signals that connect to the clear, preset, or load ports of a register. This section explains how the Quartus II Classic Timing Analyzer analyzes asynchronous paths.

### **Recovery and Removal**

Recovery time is the minimum length of time an asynchronous control signal; for example, clear and preset, must be stable before the active clock edge. Removal time is the minimum length of time an asynchronous control signal must be stable after the active clock edge. The **Enable Recovery/Removal** analysis option reports the results of recovery and removal checks for paths that end at an asynchronous clear, preset, or load signal of a register.

Enable the recovery and removal analysis with the following Tcl command:

```
set_global_assignment -name ENABLE_RECOVERY_REMOVAL_ANALYSIS ON
```

With this option enabled, the Quartus II Classic Timing Analyzer reports the result of the recovery analysis and removal analysis.



By default, the recovery and removal analysis is disabled. You should enable this option for all designs that contain asynchronous control signals.

### Recovery Report

When you set `ENABLE_RECOVERY_REMOVAL_ANALYSIS` to **ON**, the Quartus II Classic Timing Analyzer determines the recovery time as the minimum amount of time required between an asynchronous control signal becoming inactive and the next active clock edge, compares this to your design, and reports the results as slack. The Recovery report alerts you to conditions where an active clock edge occurs too soon after the asynchronous input becomes inactive, rendering the register's data uncertain.

The recovery slack time calculation is similar to the calculation for clock setup slack, which is based on data arrival time and data required time except for asynchronous control signals. If the asynchronous control is registered, the Quartus II Classic Timing Analyzer calculates the recovery slack time using [Equations 21](#) through [23](#).

$$(21) \quad \text{Recovery Slack Time} = \text{Data Required Time} - \text{Data Arrival Time}$$

$$(22) \quad \text{Data Arrival Time} = \text{Launch Edge} + \text{Longest Clock Path to Source Register} + \text{micro } t_{CO} \text{ of Source Register} + \text{Longest Register-to-Register Delay}$$

$$(23) \quad \text{Data Required Time} = \text{Latch Edge} + \text{Longest Clock Path to Source Register} + \text{micro } t_{SU} \text{ of Destination Register}$$

[Example 9-5](#) shows recovery time as reported by the Timing Analyzer.

---

#### Example 9-5. Recovery Time Reporting for a Registered Asynchronous Reset Signal

```
Info: Slack time is 8.947 ns for clock "a_clk" between source register "async_reg1" and destination register "reg_1"
Info: Requirement is of type recovery
Info: - Data arrival time is 4.028 ns
Info: + Launch edge is 0.000 ns
Info: + Longest clock path from clock "a_clk" to source register is 3.067 ns
Info: + Micro clock to output delay of source is 0.094 ns
Info: + Longest register to register delay is 0.867 ns
Info: + Data required time is 12.975 ns
Info: + Latch edge is 10.000 ns
Info: + Shortest clock path from clock "a_clk" to destination register is 3.065 ns
Info: - Micro setup delay of destination is 0.090 ns
```

---

If the asynchronous control is not registered, the Quartus II Classic Timing Analyzer uses [Equations 24](#) through [Equations 26](#) to calculate the recovery slack time.

- (24) Recovery Slack Time = Data Required Time – Data Arrival Time
- (25) Data Arrival Time = Launch Edge + Maximum Input Delay + Maximum Pin-to-Register Delay
- (26) Data Required Time = Latch Edge + Shortest Clock Path to Destination Register Delay –  
micro  $t_{SU}$  of Destination Register

[Example 9–6](#) shows recovery time as reported by the Timing Analyzer.

---

#### **Example 9–6. Recovery Time Reporting for a Non-Registered Asynchronous Reset Signal**

```
Info: Slack time is 8.744 ns for clock "a_clk15" between source pin "a_arst2" and
destination register "inst5"
Info: Requirement is of type recovery
Info: - Data arrival time is 4.787 ns
Info: + Launch edge is 0.000 ns
Info: + Max Input delay of pin is 1.500 ns
Info: + Max pin to register delay is 3.287 ns
Info: + Data required time is 13.531 ns
Info: + Latch edge is 10.000 ns
Info: + Shortest clock path from clock "a_clk15" to destination register
is 3.542 ns
Info: - Micro setup delay of destination is 0.011 ns
```

---



If the asynchronous reset signal is from a device pin, an **Input Maximum Delay** assignment must be made to the asynchronous reset pin for the Quartus II Classic Timing Analyzer to perform recovery analysis on that path.

#### *Removal Report*

When you set `ENABLE_RECOVERY_REMOVAL_ANALYSIS` to **ON**, the Quartus II Classic Timing Analyzer determines the removal time as the minimum amount of time required between an active clock edge that occurs while an asynchronous input is active, and the deassertion of the asynchronous control signal. The Quartus II Classic Timing Analyzer then compares this to your design and reports the results as slack. The Removal report alerts you to a condition in which an asynchronous input signal goes inactive too soon after a clock edge, thus rendering the register's data uncertain.

The removal time slack calculation is similar to the one used to calculate clock hold slack, which is based on data arrival time and data required time except for asynchronous control signals. If the asynchronous control is registered, the Quartus II Classic Timing Analyzer uses Equations 27 through 29 to calculate the removal slack time.

$$(27) \quad \text{Removal Slack Time} = \text{Data Arrival Time} - \text{Data Required Time}$$

$$(28) \quad \text{Data Arrival Time} = \text{Launch Edge} + \text{Shortest Clock Path from Source Register Delay} + \text{micro } t_{C0} \text{ of Source Register} + \text{Shortest Register-to-Register Delay}$$

$$(29) \quad \text{Data Required Time} = \text{Latch Edge} + \text{Longest Clock Path to Destination Register Delay} + \text{micro } t_H \text{ of Destination Register}$$

**Example 9-7.** Removal Time Reporting for a Registered Asynchronous Reset Signal

```
Info: Minimum slack time is 814 ps for clock "a_clk" between source register "async_reg1" and destination register "reg_1"
Info: Requirement is of type removal
Info: + Data arrival time is 4.028 ns
Info: + Launch edge is 0.000 ns
Info: + Shortest clock path from clock "a_clk" to source register is 3.067 ns
Info: + Micro clock to output delay of source is 0.094 ns
Info: + Shortest register to register delay is 0.867 ns
Info: - Data required time is 3.214 ns
Info: + Latch edge is 0.000 ns
Info: + Longest clock path from clock "a_clk" to destination register is 3.065 ns
Info: + Micro hold delay of destination is 0.149 ns
```

If the asynchronous control is not registered, the Quartus II Classic Timing Analyzer uses Equations 30 through 32 to calculate the removal slack time.

$$(30) \quad \text{Removal Slack Time} = \text{Data Arrival Time} - \text{Data Required Time}$$

$$(31) \quad \text{Data Arrival Time} = \text{Launch Edge} + \text{Input Minimum Delay of Pin} + \text{Minimum Pin-to-Register Delay}$$

$$(32) \quad \text{Data Required Time} = \text{Latch Edge} + \text{Longest Clock Path to Destination Register Delay} + \text{micro } t_H \text{ of Destination Register}$$

Example 9-8 shows removal time as reported by the Quartus II Classic Timing Analyzer.

#### Example 9-8. Removal Time Reporting for a Non-Registered Asynchronous Reset Signal

```
Info: Minimum slack time is 1.131 ns for clock "a_clk15" between source pin "a_arst2" and destination register "inst5"
      Info: Requirement is of type removal
      Info: + Data arrival time is 4.787 ns
      Info: + Launch edge is 0.000 ns
      Info: + Min Input delay of pin is 1.500 ns
      Info: + Min pin to register delay is 3.287 ns
      Info: - Data required time is 3.656 ns
      Info: + Latch edge is 0.000 ns
      Info: + Longest clock path from clock "a_clk15" to destination register is 3.542 ns
      Info: + Micro hold delay of destination is 0.114 ns
```



If the asynchronous reset signal is from a device pin, an **Input Minimum Delay** assignment must be made to the asynchronous reset pin for the Quartus II Classic Timing Analyzer to perform a removal analysis on this path.

## Skew Management

Clock skew is the difference in the arrival times of a clock signal at two different registers, which can be caused by path length differences between two clock paths, or by using gated or rippled clocks. As clock periods become shorter and shorter, the skew between data arrival times and clock arrival times becomes more significant. The Quartus II Classic Timing Analyzer provides two assignments for analyzing and constraining skew for data and clock signals.

### Maximum Clock Arrival Skew

Make **Maximum Clock Arrival Skew** assignments to specify the maximum allowable clock arrival skew between a clock signal and various destination registers. The Quartus II Classic Timing Analyzer compares the longest clock path to the registers' clock port and the shortest clock path to the registers' clock port to determine if your maximum clock arrival skew is achieved. Maximum clock arrival skew is calculated using [Equation 33](#).

$$(33) \quad \text{Maximum Clock Arrival Skew} = \text{Longest Clock Path} - \text{Shortest Clock Path}$$

For example, if the delay from clock pin `clk` to the clock port of register `reg1` is 1.0 ns, and the delay from clock pin `clk` to the clock port of register `reg2` is 3.0 ns, as shown in [Figure 9-21](#), the Quartus II Classic Timing Analyzer provides a clock skew slack time of 2.0 ns.

---

**Figure 9–21. Clock Arrival Paths**

You should apply the **Maximum Clock Arrival Skew** assignment to a clock node and a group of registers. When you make a **Maximum Clock Arrival Skew** assignment, the Fitter attempts to satisfy the skew requirement.

You can use the `set_instance_assignment -name max_clock_arrival_skew 1ns -from clk -to reg*` Tcl command to specify a **Maximum Clock Arrival Skew** assignment. The following example specifies a maximum clock arrival skew of 1 ns from clock signal `clk` to the bank of registers matching `reg*`:

```
set_instance_assignment -name max_clock_arrival_skew 1ns -from clk -to reg*
```

## Maximum Data Arrival Skew

Make **Maximum Data Arrival Skew** assignments to specify the maximum allowable data arrival skew to various destination registers or pins. The Quartus II Classic Timing Analyzer compares the longest data arrival path to the shortest data arrival path to determine if your specified maximum data arrival skew is achieved. Maximum data arrival skew is calculated using [Equation 34](#).

$$(34) \quad \text{Maximum Data Arrival Skew} = \text{Longest Data Arrival Path} - \text{Shortest Data Arrival Path}$$

For example, if the data arrival time to output pin `out1` is 2.0 ns, the data arrival time to output pin `out2` is 1.5 ns, and the data arrival time to output pin `out3` is 1.0 ns, as shown in [Figure 9–22](#), the Quartus II Classic Timing Analyzer provides a maximum data arrival skew slack time of 1.0 ns.

**Figure 9–22. Data Arrival Paths**

When you make a **Maximum Data Arrival Skew** assignment, the Fitter attempts to satisfy the skew requirement.

You can use the `set_instance_assignment -name max_data_arrival_skew 1ns -from clk -to dout[*]` Tcl command to specify a maximum data arrival skew value. The following example specifies a maximum data arrival skew of 1 ns from clock signal `clk` to the bank of output pins `dout`:

```
set_instance_assignment -name max_data_arrival_skew 1ns -from clk -to dout[*]
```

## Generating Timing Analysis Reports with `report_timing`

The Quartus II Classic Timing Analyzer includes the `report_timing` Tcl command for generating text-based timing analysis reports. You can customize the output of `report_timing` using multiple switches that allow the generation of both detailed and general timing reports on any path in the design.



The `report_timing` Tcl command is available in the `quartus_tan` executable.

Prior to using the `report_timing` Tcl command, you must open a Quartus II project and create a timing netlist. For example, the following two Tcl commands accomplish this:

```
project_open my_project
create_timing_netlist
```

The report\_timing Tcl command provides -from and -to switches for filtering specific source and destination nodes. For example, the following report\_timing Tcl command reports all clock setup paths, with the switch -clock\_setup, between registers src\_reg\* and dst\_reg\*. The -npaths 20 switch limits the report to 20 paths.

```
report_timing -clock_setup -from src_reg* -to dst_reg* -npaths 20
```

The switches -clock\_filter and -src\_clock\_filter are also available for filtering based on specific clock sources. For example, the following report\_timing Tcl command reports all clock setup paths where the destination registers are clocked by clk:

```
report_timing -clock_setup -clock_filter clk
```

The following example reports clock setup paths where the destination registers are clocked by clk, and the source registers are clocked by src\_clock.

```
report_timing -clock_setup -clock_filter clk -src_clock_filter \
src_clk
```

**Example 9-9** is an example script that can be sourced by the quartus\_tan executable:

---

**Example 9-9. Source for the quartus\_tan Executable**

```
# Open a project
project_open my_project
# Always create the netlist first
create_timing_netlist
# List clock setup paths for clock clk
# from registers abc* to registers xyz*
report_timing -clock_setup -clock_filter clk -from abc* -to xyz*
# List the top 5 pin-to-pin combinational paths
report_timing -tpd -npaths 5
# List the top 5 pin-to-pin combinational paths and
# write output to an out.tao file
report_timing -tpd -npaths 5 -file out.tao
# Compute min tpd and append results to existing out.tao
report_timing -min_tpd -npaths 5 -file out.tao -append
# Show longest path (register to register data path) between a* and b*
report_timing -longest_paths -npaths 1
delete_timing_netlist
project close
```

---

## Other Timing Analyzer Features

The Quartus II Classic Timing Analyzer provides many features for customizing and increasing the efficiency of static timing analysis, including:

- Wildcard assignments
- Assignment groups
- Fast corner analysis
- Early timing estimation
- Timing constraint checker
- Latch analysis

### Wildcard Assignments

To simplify the tasks of making assignments to many node assignments, the Quartus II software accepts the \* and ? wildcard characters. Use these wildcard characters to reduce the number of individual assignments you need to make for your design.

The “\*” wildcard character matches any string. For example, given an assignment made to a node specified as `reg*`, the Quartus II Classic Timing Analyzer searches 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 Classic Timing Analyzer searches and applies the assignment to all design nodes that match the prefix `reg` and any single character following, such as `reg1`, `rega`, and `reg4`.

### Assignment Groups

Assignment groups, also known as time groups, allow you to define a custom group of nodes to which you can assign timing assignments. You can also exclude specific nodes, wildcards, and time groups from a time group.

Use the `timegroup` Tcl command to create an assignment group. The following example creates an assignment group `srcgrp` and adds nodes with names that match `src1*` to the group:

```
timegroup srcgrp -add_member src1*
```

For example, Figure 9-23 has false paths between source register `reg1` and destination register bank `sram_reg`, `external_reg`, `internal_reg`, and `cam_reg` that need to be cut. Without the use of assignment groups, the assignments required are:

```
set_timing_cut_assignment -from reg1 to sram_reg
set_timing_cut_assignment -from reg1 to external_reg
set_timing_cut_assignment -from reg1 to internal_reg
set_timing_cut_assignment -from reg1 to cam_reg
```

**Figure 9-23. False Path**



With an assignment group called `dst_reg_bank`, the assignments required are:

```
#create a time group called dst_reg
timegroup dst_reg_bank -add_member sram_reg
timegroup dst_reg_bank -add_member external_reg
timegroup dst_reg_bank -add_member internal_reg
timegroup dst_reg_bank -add_member cam_reg
#cut timing paths
set_timing_cut_assignment -from reg1 to dst_reg_bank
```

Once an assignment group has been defined, applicable timing assignment can be made to the time group without redefining the assignment group.



Assigning individual nodes to time groups and applying timing assignments to these time groups can improve the performance of the Quartus II Classic Timing Analyzer.

## Fast Corner Analysis

Fast Corner Analysis uses timing models generated under best-case conditions (voltage, process, and temperature) for the fastest speed-grade device.



Both Fast Corner and Slow Corner static timing analysis reports are saved to the `<project name>.tan.rpt` file, potentially overwriting previous timing analysis reports. To preserve a copy of your reports, save the file with a new name before the next compilation or static timing analysis, or use the Combined Fast/Slow Analysis report feature.

The Quartus II software also reports minimum delay checks after a slow corner (default) analysis. These results are generated by reporting minimum delay checks using worst-case timing models.

To perform fast corner static timing analysis with the best-case timing models, you can use the `switch --fast_model=on` with the `quartus_tan` executable. The following Tcl command enables the fast timing models:

```
quartus_tan <project_name> --fast_model=on
```

## Early Timing Estimation

The majority of Quartus II software compilation time is consumed by the place-and-route process used to obtain optimal design results. To accelerate the design process for large designs, the Quartus II software provides **Early Timing Estimation**. This feature provides a quick static timing analysis in a fraction of the time required for a full compilation by performing a preliminary place-and-route on the design without full optimizations, which reduces total compile time by up to five times compared to a fully fitted design.



An **Early Timing Estimate** fit is not fully optimized or legally routed. The timing delay report is only an estimate. Typically, the estimated delays are within 10% of those obtained with a full fit when the realistic setting is used.

The **Early Timing Estimate** has three settings for generating timing estimates: Realistic, Optimistic, and Pessimistic. [Table 9–1](#) describes these settings.

| <b>Table 9–1. Early Timing Estimate Setting Options</b>                           |                                                                                       |
|-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|
| <b>Setting</b>                                                                    | <b>Description</b>                                                                    |
| <b>Realistic</b> (default setting: estimates final timing using standard fitting) | Generates timing estimates that are likely to be closest to full compilation results. |
| <b>Optimistic</b> (estimates best-case final timing)                              | Generates timing estimates that are unlikely to be exceeded by full compilation.      |
| <b>Pessimistic</b> (estimates worst-case final timing)                            | Generates timing estimates that are likely to be exceeded by full compilation.        |

To use the **Early Timing Estimate** feature, enter the following Tcl command when performing a fit:

```
quartus_fit --early_timing_estimate[=<realistic|optimistic|pessimistic>]
```

After **Early Timing Estimate** is complete, a full timing report is generated based on the early placement and routing delays. In addition, you can view the preliminary logic placement in the Timing Closure floorplan. The early timing placement allows you to perform initial placement and view the timing interaction of various placement topology.

## Timing Constraint Checker

Altera recommends that you enter all timing constraints into the Quartus II software prior to performing a full compilation. This ensures that the Fitter targets the correct timing requirements and ensures that the Quartus II Classic Timing Analyzer reports the correct violations for all timing paths in the design. To ensure that all constraints have been applied to design nodes, the **Timing Constraint Check** feature reports all unconstraint paths in your design. [Example 9–10](#) shows the timing constraint check summary generated after a full compilation.

---

**Example 9–10. Timing Constraint Check Summary**

```
+
; Timing Constraint Check Summary
+
; Timing Constraint Check Status      ; Analyzed - Tue Feb 28 11:42:31 2006      ;
; Quartus II Version                 ; 6.1 Internal Build 143 02/20/2006 SJ Full Version  ;
; Revision Name                     ; test
; Top-level Entity Name             ; Block1
; Unconstrained Clocks             ; 0
; Unconstrained Paths (Setup)      ; 22
; Unconstrained Reg-to-Reg Paths (Setup) ; 0
; Unconstrained I/O Paths (Setup)   ; 22
; Unconstrained Paths (Hold)       ; 12
; Unconstrained Reg-to-Reg Paths (Hold) ; 0
; Unconstrained I/O Paths (Hold)   ; 12
+
```

---

To perform a timing constraint check, use the `switch --check_constraints` with the `quartus_tan` executable. The following Tcl command performs a timing constraint check on both setup and hold on the design system:

```
quartus_tan block1 --check_constraints=both
```

## Latch Analysis

Latches are implemented in the Quartus II software as look-up-tables (LUTs) feeding back onto themselves. The Quartus II Classic Timing Analyzer can analyze these latches as synchronous elements rather than as combinational elements. The clock enables are analyzed as inverted clocks. The Quartus II Classic Timing Analyzer reports the results of setup and hold analysis on these latches.

You can turn on the **Analyze Latches As Synchronous Elements** option with the following Tcl command:

```
set_global_assignment -name ANALYZE_LATCHES_AS_SYNCHRONOUS_ELEMENTS ON
```

## Timing Analysis Using the Quartus II GUI

In addition to the extensive scripting support available in the Quartus II Classic Timing Analyzer, the Quartus II software provides the Assignment Editor and other user interface tools, giving you access to the Quartus II Classic Timing Analyzer features and assignments.

### Assignment Editor

The Assignment Editor is a spreadsheet-style interface used for adding, modifying, and deleting timing assignments.

To make timing assignments in the Assignment Editor, choose **Timing** from the category list to cause the Assignment Name column to display only timing assignments. Double-click <<new>> in the **Assignment Name** field, the **Assignment Name** list displays. [Figure 9–24](#) shows the Assignment Editor with the Assignment Name list displaying timing assignment types.

**Figure 9–24. Assignment Editor**



For more information about the Assignment Editor, refer to the [Assignment Editor](#) chapter in volume 2 of the [Quartus II Handbook](#).

## Timing Settings

You can specify delay requirements and clock settings with the **Timing Analysis Settings** page of the **Settings** dialog box.

To access this page, on the Assignments menu, click **Settings**. In the Category list, click the  icon next to **Timing Analysis Settings** to expand the folder. (Be sure that the **Use Classic Timing Analyzer during compilation** radio button is turned on.) Click **Classic Timing Analyzer Settings**. The **Classic Timing Analysis Settings** page displays (Figure 9–25).

**Figure 9–25. Timing Analysis Settings Dialog Box**



### Clock Settings Dialog Box

You can create or modify base clock settings or derived clock settings using the **Clock Settings** dialog box. To access this page, on the Assignments menu, click **Settings**. In the Category list, click the  icon next to **Timing Analysis Settings** to expand the folder. (Be sure that the **Use Classic Timing Analyzer during compilation** radio button is turned on.) Click on **Classic Timing Analyzer Settings**. The **Timing Analysis Settings** page displays. Under **Clock Settings**, click **Individual Clocks**. The **Individual Clock** dialog box is shown (Figure 9–26).

**Figure 9–26. Individual Clocks Dialog Box**



Click the **New** button in the **Individual Clocks** dialog box to access the **New Clock Settings** dialog box and create a base or derived clock setting (Figure 9–27).

---

**Figure 9–27. New Settings Dialog Box**

---

### More Timing Settings Dialog Box

On the **Timing Analysis Settings** page of the **Settings** dialog box, click **More Settings** to display the **More Timing Settings** dialog box (Figure 9–28). The **More Timing Settings** dialog box provides access to many global timing analysis options.

**Figure 9–28. More Timing Settings Dialog Box**

## Timing Reports

The Quartus II Classic Timing Analyzer report is a section of the Compilation Report containing the static timing analysis results. The Quartus II Classic Timing Analyzer report includes clock setup and clock hold measurements for all clock sources. The report also shows  $t_{CO}$  for all output pins,  $t_{SU}$  and  $t_H$  for all input pins, and  $t_{PD}$  for any pin-to-pin combinational paths in the design. Other reports are created for different analyses and device features.

In the **Settings** dialog box, you can specify the range of information to be reported in the timing analysis of the Compilation Report. To access this page, on the Assignments menu, click **Settings**. In the Category list, click the **⊕** icon next to **Timing Analysis Settings** to expand the folder. (Be sure that the **Use Classic Timing Analyzer during compilation** radio button is turned on.) Click the **⊕** icon next to **Classic Timing Analyzer Settings** to expand the folder. Click **Classic Timing Analyzer Reporting**. The **Classic Timing Analyzer Reporting** dialog box (Figure 9–29) appears.

Figure 9–29. Classic Analyzer Reporting



If there are no timing assignments for the design, the Quartus II Classic Timing Analyzer does not generate slack reports for any detected clock nodes. The Quartus II Classic Timing Analyzer only reports slack measurements for pins with individual or global  $t_{SU}$ ,  $t_H$ , or  $t_{CO}$  assignments. A positive slack indicates the margin by which the path surpasses the clock timing requirements. A negative slack indicates the margin by which the path fails the clock timing requirements.



This Timing Analysis report is also available in text format located in the design directory with the file name *<revision name>.tan.rpt*.

In the Compilation Report, select an analysis type under the Timing Analyzer folder to display the analysis report; for example, Clock Setup or Clock Hold. [Figure 9–30](#) shows an example of a Clock Setup report for clock signal `clk`.

**Figure 9–30. Timing Analysis Report**


|    | Slack     | Actual fmax<br>(period)          | From                       | To                        | From Clock | To Clock | Required Setup Relationship | Required Longest P2P Time |
|----|-----------|----------------------------------|----------------------------|---------------------------|------------|----------|-----------------------------|---------------------------|
| 1  | 9.049 ns  | 91.32 MHz ( period = 10.951 ns ) | state_m_inst1\$filter.tap4 | acc:inst3\$result[11].clk | clk        | clk      | 20.000 ns                   | 19.798 ns                 |
| 2  | 9.664 ns  | 96.75 MHz ( period = 10.336 ns ) | state_m_inst1\$filter.tap3 | acc:inst3\$result[11].clk | clk        | clk      | 20.000 ns                   | 19.798 ns                 |
| 3  | 9.796 ns  | 98.00 MHz ( period = 10.204 ns ) | state_m_inst1\$filter.tap2 | acc:inst3\$result[11].clk | clk        | clk      | 20.000 ns                   | 19.798 ns                 |
| 4  | 10.239 ns | 102.45 MHz ( period = 9.761 ns ) | tags:instbn[2]             | acc:inst3\$result[11].clk | clk        | clk      | 20.000 ns                   | 19.798 ns                 |
| 5  | 10.283 ns | 102.91 MHz ( period = 9.717 ns ) | tags:instbn[5]             | acc:inst3\$result[11].clk | clk        | clk      | 20.000 ns                   | 19.798 ns                 |
| 6  | 10.319 ns | 103.30 MHz ( period = 9.681 ns ) | state_m_inst1\$filter.tap4 | acc:inst3\$result[10].clk | clk        | clk      | 20.000 ns                   | 19.798 ns                 |
| 7  | 10.391 ns | 104.07 MHz ( period = 9.609 ns ) | tags:instbn[0]             | acc:inst3\$result[11].clk | clk        | clk      | 20.000 ns                   | 19.773 ns                 |
| 8  | 10.480 ns | 105.04 MHz ( period = 9.520 ns ) | tags:instbn_2[0]           | acc:inst3\$result[11].clk | clk        | clk      | 20.000 ns                   | 19.798 ns                 |
| 9  | 10.523 ns | 105.52 MHz ( period = 9.477 ns ) | tags:instbn[1]             | acc:inst3\$result[11].clk | clk        | clk      | 20.000 ns                   | 19.798 ns                 |
| 10 | 10.757 ns | 108.19 MHz ( period = 9.243 ns ) | tags:instbn_1[2]           | acc:inst3\$result[11].clk | clk        | clk      | 20.000 ns                   | 19.798 ns                 |
| 11 | 10.768 ns | 108.32 MHz ( period = 9.232 ns ) | tags:instbn[4]             | acc:inst3\$result[11].clk | clk        | clk      | 20.000 ns                   | 19.798 ns                 |
| 12 | 10.851 ns | 109.30 MHz ( period = 9.149 ns ) | tags:instbn_2[2]           | acc:inst3\$result[11].clk | clk        | clk      | 20.000 ns                   | 19.798 ns                 |
| 13 | 10.934 ns | 110.30 MHz ( period = 9.066 ns ) | state_m_inst1\$filter.tap3 | acc:inst3\$result[10].clk | clk        | clk      | 20.000 ns                   | 19.798 ns                 |
| 14 | 10.996 ns | 111.06 MHz ( period = 9.004 ns ) | tags:instbn_1[4]           | acc:inst3\$result[11].clk | clk        | clk      | 20.000 ns                   | 19.798 ns                 |
| 15 | 11.066 ns | 111.93 MHz ( period = 8.934 ns ) | state_m_inst1\$filter.tap2 | acc:inst3\$result[10].clk | clk        | clk      | 20.000 ns                   | 19.798 ns                 |
| 16 | 11.110 ns | 112.49 MHz ( period = 8.890 ns ) | tags:instbn[3]             | acc:inst3\$result[11].clk | clk        | clk      | 20.000 ns                   | 19.798 ns                 |

## Advanced List Path

The **Advanced List Paths** dialog box provides detailed information about a specific path, such as interconnect and cell delays between any two valid register-to-register paths (Figure 9–31).

The **Advanced List Paths** dialog box allows you to select the type of paths you want listed. For example, you can obtain detailed information for Clock Setup and Clock Hold for a specific clock. In addition, the Tcl command field in the window matches the equivalent Tcl command you can use in either a custom Tcl script or in the Tcl console.

**Figure 9–31. Advanced List Paths Dialog Box**

You can perform a list path command directly from the Timing Analysis report. To do this, right click a path and click **List Path** (Figure 9–32). To launch the **Advanced List Paths** dialog box, right-click a path and in the menu that appears, and select **Advanced List Paths**.

The **Advanced List Paths** dialog box displays only paths that are visible in the Timing Analysis report. To increase the amount of paths reported by the Quartus II Classic Timing Analyzer, on the Assignments menu, click **Timing Analysis Settings**. In the **Category** list, expand **Timing Analysis Settings** and select **Timing Analyzer Reporting**. In the **Timing Analyzer Reporting** page, specify the range of information to be reported by the Quartus II Classic Timing Analyzer.



Both the **Advanced List Paths** and the **List Path** commands display the path information in the **System** message window.

**Figure 9–32. List Path in the Message Window**

```

[+] Info: Slack time is 8.064 ns for clock "clk3" between source register "reg1" and destination register "reg2"
  [+] Info: Fmax is restricted to 275.03 MHz due to tcl and tch limits
  [+] Info: + Largest register to register requirement is 8.891 ns
  [+] Info: + Setup relationship between source and destination is 10.000 ns
  [+] Info: + Largest clock skew is -0.848 ns
  [+] Info: - Micro clock to output delay of source is 0.224 ns
  [+] Info: - Micro setup delay of destination is 0.037 ns
  [+] Info: - Longest register to register delay is 0.827 ns
    [+] Info: 1: + IC(0.000 ns) + CELL(0.000 ns) = 0.000 ns; Loc. = LC_X33_Y20_N6; Fanout = 1; REG Node = 'reg1'
    [+] Info: 2: + IC(0.518 ns) + CELL(0.309 ns) = 0.827 ns; Loc. = LC_X33_Y20_N2; Fanout = 2; REG Node = 'reg2'
    [+] Info: Total cell delay = 0.309 ns ( 37.36 % )
    [+] Info: Total interconnect delay = 0.518 ns ( 62.64 % )

```



If the **Combined Fast/Slow Timing** option is enabled, the List Path Tcl command displays only path delays reported in the Slow Model section.

## Early Timing Estimate

To start an Early Timing Estimate, on the Processing menu, point to Start and click **Start Early Timing Estimate**. To specify the **Early Timing Estimate** mode, on the Assignments menu, click **Settings**. In the **Category** list, select **Compilation Processes Settings**, select **Early Timing Estimate** and click the desired timing estimate mode. For more information about the Early Timing Estimate feature, refer to “[Early Timing Estimation](#)” on page 9–40.

## Assignment Groups

To define, modify, and delete assignment groups, also known as time groups, from a single dialog box, on the Assignments menu, click **Assignment (Time) Groups**. The **Assignment Groups** dialog box displays (Figure 9–33).

Figure 9–33. Assignment Groups Dialog Box



## Scripting Support

You can run procedures and make settings described in this chapter in a Tcl script. You can also run some procedures at a command prompt. For detailed information about scripting command options, refer to the Quartus II Command-Line and Tcl API Help browser. To run the Help browser, type the following command at the command prompt:

```
quartus_sh --qhelp
```



Refer to the *Quartus II Scripting Reference Manual* to view this information in PDF form.



For more information about Tcl scripting, refer to the *Tcl Scripting* chapter in **volume 2** of the *Quartus II Handbook*.



Refer to the *Quartus II Settings File Reference Manual* for information about all settings and constraints in the Quartus II software.



For more information about command-line scripting, refer to the *Command-Line Scripting* chapter in **volume 2** of the *Quartus II Handbook*.

## Creating Clocks

There are two Tcl commands that allow you to define clocks in a design, `create_base_clock` and `create_relative_clock`.

### Base Clocks

Use the `create_base_clock` Tcl command to define a base clock:

```
create_base_clock [-h | -help] [-long_help] -fmax <fmax> [-duty_cycle <integer>] \
[-virtual] [-target <name>] [-no_target] [-entity <entity>] [-disable] \
[-comment <comment>] <clock_name>
```

To define a base clock setting named `sys_clk` with a 100 MHz requirement applied to node `clk_src`, enter the following Tcl command:

```
create_base_clock -fmax 100MHz -target clk_src sys_clk
```

### Derived Clocks

Use the `create_relative_clock` Tcl command to define a relative clock:

```
create_relative_clock [-h | -help] [-long_help] -base_clock <Base clock> \
[-duty_cycle <integer>] [-multiply <integer>] [-divide <integer>] [-offset <offset>] \
[-phase_shift <integer>] [-invert] [-virtual] [-target <name>] [-no_target] \
[-entity <entity>] [-disable] [-comment <comment>] <clock_name>
```

To define a relative clock named `aux_clk` based upon base clock setting `sys_clk` with a multiplication factor of 2 applied to node `rel_clk`, enter the following Tcl command:

```
create_relative_clock -base_clock sys_clk -multiply 2 -target rel_clk aux_clk
```

## Clock Latency

You can use the `set_clock_latency` Tcl command to create either an early or late clock latency assignment:

```
set_clock_latency [-h | -help] [-long_help] [-early] [-late] -to <to> [<value>]
```

To apply an early clock latency of 1 ns and a late clock latency of 2 ns to clock node `clk`, enter the following Tcl commands:

```
set_clock_latency -early -to clk 1ns
```

## Clock Uncertainty

You can use the `set_clock_uncertainty` Tcl command to create clock uncertainty assignments as shown in the following example:

```
set_clock_uncertainty [-h] [-help] [-long_help] [-from <source_clock_name>] -to <destination_clock_name> [-setup] [-hold] [-remove] [-disable] [-comment <comment>] <value>
```

To apply a clock setup uncertainty of 50 ps between source clock node `clk_src` and destination clock node `clk_dst`, enter the following Tcl command:

```
set_clock_uncertainty -from clk_src -to clk_dst -setup 50ps
```

To apply a clock hold uncertainty of 25 ps between to clock node `clk_sys`, enter the following Tcl command:

```
set_clock_uncertainty -to clk_sys -setup 25ps
```

## Cut Timing Paths

You can use the `set_timing_cut_assignment` Tcl command to create cut timing assignments:

```
set_timing_cut_assignment [-h | -help] [-long_help] [-from <from_node_list>] [-to <to_node_list>] [-remove] [-disable] [-comment <comment>]
```

To cut the timing path from source register `reg1` to destination register `reg2`, enter the following Tcl command:

```
set_timing_cut_assignment -from reg1 -to reg2
```

## Input Delay Assignment

You can use the Tcl command `set_input_delay` to create input delay assignments:

```
set_input_delay [-h | -help] [-long_help] [-clk_ref <clock>] -to <input_pin> [-min] [-max] [-clock_fall] [-remove] [-disable] [-comment <comment>] [<value>]
```

To apply an input maximum delay of 2 ns to an input pin named `data_in` that feeds a register clocked by clock source `clk`, enter the following Tcl command:

```
set_input_delay -clk_ref clk -to data_in -max 2ns
```

## Maximum and Minimum Delay

The following Tcl commands create the **Maximum Delay** and **Minimum Relationship** assignments, respectively:

```
set_instance_assignment -name MAX_delay <value> -from <node> -to <node>
set_instance_assignment -name MIN_delay <value> -from <node> -to <node>
```

To apply a **Maximum Delay** of 8 ns and a minimum of 5 ns between source register `reg1` and destination register `reg2`, enter the following Tcl command:

```
set_instance_assignment -name MAX_DELAY 8ns -from reg1 -to reg2
set_instance_assignment -name MIN_DELAY 5ns -from reg1 -to reg2
```

To apply a **Maximum Delay** of 10 ns for all paths from source clock `clk_src` to destination clock `clk_dst`, enter the following Tcl command:

```
set_instance_assignment -name MAX_DELAY 10ns -from clk_src -to clk_dst
```

## Maximum Clock Arrival Skew

The following Tcl command defines the **Maximum Clock Arrival Skew** assignment:

```
set_instance_assignment -name max_clock_arrival_skew <value> -from <clock> -to <node>
```

To apply a **Maximum Clock Arrival Skew** of 1 ns for clock source `clk` to a predefined timegroup called `reg_group`, enter the following Tcl command:

```
set_instance_assignment -name max_clock_arrival_skew 1ns -from clk -to reg_group
```

## Maximum Data Arrival Skew

To create **Maximum Data Arrival Skew** assignments, use the Tcl command `set_instance_assignment -name max_data_arrival:`

```
set_instance_assignment -name max_data_arrival_skew <value> -from <clock> -to <node>
```

To apply a **Maximum Data Arrival Skew** of 1 ns for clock source `clk` to a predefined timegroup of pins called `pin_group`, enter the following Tcl command:

```
set_instance_assignment -name max_data_arrival_skew 1ns -from clk -to pin_group
```

## Multicycle

Use the `set_multicycle_assignment` Tcl command to create **Multicycle** assignments:

```
set_multicycle_assignment [-h | -help] [-long_help] [-setup] [-hold] [-start] [-end]
[-from <from_list>] [-to <to_list>] [-remove] [-disable] [-comment <comment>]
<path_multiplier>
```

To apply a **Multicycle Setup** of 2 and a **Hold Multicycle** of 1 between source register `reg1` and destination register `reg2`, enter the following Tcl commands:

```
set_multicycle_assignment -setup -end -from reg1 -to reg2 2
set_multicycle_assignment -hold -end -from reg1 -to reg2 1
```

To apply a **Source Multicycle Setup** of 2 between source register `reg1` and destination register `reg2`, enter the following Tcl command:

```
set_multicycle_assignment -setup -start -from reg1 -to reg2 1
```

To apply a **multicycle setup** of 2 for all paths from source clock `clk_src` to destination clock `clk_dst`, enter the following Tcl command:

```
set_multicycle_assignment -setup -end -from clk_src -to clk_dst 2
```

## Output Delay Assignment

Use the Tcl command `set_output_delay` to create **Output Delay** assignments:

```
set_output_delay [-h | -help] [-long_help] [-clk_ref <clock>] -to <output_pin> [-min]
[-max] [-clock_fall] [-remove] [-disable] [-comment <comment>] [<value>]
```

To apply an **Output Maximum Delay** of 3 ns to an output pin named `data_out` that is fed to a register clocked by clock source `clk`, enter the following Tcl command:

```
set_output_delay -clk_ref clk -to data_out -max 3ns
```

## Report Timing

Use the `report_timing` Tcl command to generate timing reports:

```
report_timing [-h | -help] [-long_help] [-npaths <number>] [-tsu] [-th] [-tco] [-tpd] \
[-min_tco] [-min_tpd] [-clock_setup] [-clock_hold] [-clock_setup_io] [-clock_hold_io] \
[-clock_setup_core] [-clock_hold_core] [-recovery] [-removal] [-dqs_read_capture] \
[-stdout] [-file <name>] [-append] [-table <name>] [-from <names>] [-to <names>] \
[-clock_filter <names>] [-src_clock_filter <names>] [-longest_paths] [-shortest_paths] \
[-all_failures]
```

The following example generates a list of all clock setup paths for clock source `clk` from registers `src_reg*` to registers `dst_reg*`:

```
report_timing -clock_setup -clock_filter clk -from src_reg* -to dst_reg*
```

## Setup and Hold Relationships

The following Tcl commands create **Setup Relationship** and **Hold Relationship** assignments, respectively:

```
set_instance_assignment -name SETUP_RELATIONSHIP <value> -from <node> -to <node>
set_instance_assignment -name HOLD_RELATIONSHIP <value> -from <node> -to <node>
```

To apply a **Setup Relationship** of 12 ns and a **Hold Relationship** of 2 ns between source register `reg1` and destination registers `reg2`, enter the following Tcl command:

```
set_instance_assignment -name SETUP_RELATIONSHIP 12ns -from reg1 -to reg2
set_instance_assignment -name HOLD_RELATIONSHIP 2ns -from reg1 -to reg2
```

To apply a setup relationship of 10 ns for all paths from source clock `clk_src` to destination clock `clk_dst`, enter the following Tcl command:

```
set_instance_assignment -name SETUP_RELATIONSHIP 10ns -from clk_src -to clk_dst
```

## Assignment Group

Use the `timegroup` Tcl command to create assignment groups:

```
timegroup [-h | -help] [-long_help] [-add_member <name>] [-add_exception <name>] \
[-remove_member <name>] [-remove_exception <name>] [-get_members] [-get_exceptions] \
[-overwrite] [-remove] [-comment <comment>] <group_name>
```

The following example creates an assignment group called `reg_bank` with members `dst_reg*`, and excludes register `dst_reg5`.

```
timegroup reg_bank -add_member dst_reg* -add_exception dst_reg5
```

## Virtual Clock

Use the `create_relative_clock` with the `-virtual` switch to create **Virtual Clock** assignments:

```
create_relative_clock [-h | -help] [-long_help] -base_clock <Base clock> \
[-duty_cycle <integer>] [-multiply <integer>] [-divide <integer>] [-offset <offset>] \
[-phase_shift <integer>] [-invert] [-virtual] [-target <name>] [-no_target] \
[-entity <entity>] [-disable] [-comment <comment>] <clock_name>
```

To define a virtual clock derived from the base clock setting `clk_aux` named `brd_sys`, enter the following Tcl command:

```
create_relative_clock -base_clock clk_aux -virtual brd_sys
```

## MAX+PLUS II Timing Analysis Methodology

This section describes the basic static timing analysis and assignments available in the Quartus II software that originated in the MAX+PLUS® II design software.

### $f_{MAX}$ Relationships

Maximum clock frequency is the fastest speed at which the design clock can run without violating internal setup and hold time requirements. The Quartus II software performs static timing analysis on both single- and multiple-clock designs.



Apply clock settings to all clock nodes in a design to ensure that you meet all performance requirements. Refer to “[Clock Settings](#)” on page [9-8](#) for more information.

### Slack

Slack is the margin by which a timing requirement such as  $f_{MAX}$  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 software determines slack using [Equations 35](#) through [38](#).

$$(35) \quad \text{Clock Setup Slack} = \text{Longest Register-to-Register Requirement} - \text{Longest Register-to-Register Delay}$$

$$(36) \quad \text{Register-to-Register Requirement} = \text{Setup Relationship} + \text{Largest Clock Skew} - \text{micro } t_{CO} \text{ of Source Register} - \text{micro } t_{SU} \text{ of Destination Register}$$

$$(37) \quad \text{Clock Hold Slack} = \text{Shortest Register-to-Register Delay} - \text{Smallest Register-to-Register Requirement}$$

$$(38) \quad \text{Shortest Register-to-Register Requirement} = \text{Hold Relationship} + \text{Smallest Clock Skew} - \text{micro } t_{CO} \text{ of Source Register} - \text{micro } t_H \text{ of Destination Register}$$

Figure 9–34 shows a slack calculation diagram.

**Figure 9–34. Slack Calculation Diagram**



## I/O Timing

This section describes the basic measurements made for I/O timing in the Quartus II software.

### $t_{SU}$ Timing

$t_{SU}$  specifies the length of time data needs to arrive and be stable at an external input pin prior to a clock transition on an associated clock I/O pin. A  $t_{SU}$  requirement describes this relationship for an input register relative to the I/O pins of the FPGA. [Figure 9–35](#) shows a diagram of clock setup time.

**Figure 9–35. Clock Setup Time ( $t_{SU}$ )**



Micro  $t_{SU}$  is the internal setup time of the register. It is a characteristic of the register and is unaffected by the signals feeding the register. [Equation 39](#) calculates the  $t_{SU}$  of data with respect to  $clk$  for the circuit shown in [Figure 9–35](#).

$$(39) \quad t_{SU} = \text{Longest Data Delay} - \text{Shortest Clock Delay} + \text{micro } t_{SU} \text{ of Input Register}$$

### $t_H$ Timing

$t_H$  specifies the length of time data needs to be held stable on an external input pin after a clock transition on an associated clock I/O pin. A  $t_H$  requirement describes this relationship for an input register relative to the I/O pins of the FPGA. [Figure 9–36](#) shows a diagram of clock hold time.

---

**Figure 9–36. Clock Hold Time ( $t_H$ )**

Micro  $t_H$  is the internal hold time of the register. [Equation 40](#) calculates the  $t_H$  of data with respect to  $clk$  for the circuit shown in [Figure 9–36](#).

$$(40) \quad t_H = \text{Longest Clock Delay} - \text{Shortest Data Delay} + \text{micro } t_H \text{ of Input Register}$$

### $t_{CO}$ Timing

Clock-to-output delay is the maximum time required to obtain a valid output at an output pin fed by a register, after a clock transition on the input pin that clocks the register. Micro  $t_{CO}$  is the internal clock-to-output delay of the register. [Figure 9–37](#) shows a diagram of clock-to-output delay.

---

**Figure 9–37. Clock-to-Output Delay ( $t_{CO}$ )**

[Equation 41](#) calculates the  $t_{CO}$  for output pin  $data\_out$  with respect to clock node  $clk$  for the circuit shown in [Figure 9–37](#).

$$(41) \quad t_{CO} = \text{Longest Clock Delay} + \text{micro } t_{CO} \text{ of Output Register}$$

*Minimum  $t_{CO}$  (min  $t_{CO}$ )*

Minimum clock-to-output delay is the minimum time required to obtain a valid output at an output pin fed by a register, after a clock transition on the input pin that clocks the register. Micro  $t_{CO}$  is the internal clock-to-output delay of registers in Altera FPGAs. Unlike the  $t_{CO}$  assignment, the min  $t_{CO}$  assignment looks at the shortest delay paths (Equation 42).

$$(42) \quad \text{min } t_{CO} = \text{Shortest Clock Delay} + \text{Shortest Data Delay} + \text{micro } t_{CO} \text{ of Output Register}$$

 *$t_{PD}$  Timing*

Pin-to-pin delay ( $t_{PD}$ ) is the time required for a signal from an input pin to propagate through combinational logic and appear at an external output pin (Equation 43).

$$(43) \quad t_{PD} = \text{Longest Pin-to-Pin Delay}$$

 In the Quartus II software, you can make  $t_{PD}$  assignments between an input pin and an output pin.

*Minimum  $t_{PD}$  (min  $t_{PD}$ )*

The minimum pin-to-pin delay ( $t_{PD}$ ) is the time required for a signal from an input pin to propagate through combinational logic and appear at an external output pin. Unlike the  $t_{PD}$  assignment, the min  $t_{PD}$  assignment applies to the shortest pin-to-pin delay (Equation 44).

$$(44) \quad \text{min } t_{PD} = \text{Shortest Pin-to-Pin Delay}$$

**The Timing Analyzer Tool**

To facilitate the classic static timing analysis flow and constraint, the Quartus II software provides a MAX+PLUS II-style Timing Analyzer Tool available on the Tools menu. The Timing Analyzer Tool provides a simple interface, similar to the Timing Analyzer tool in MAX+PLUS II, that reports register-to-register performance, I/O timing, and custom delay values (Figure 9-38).

**Figure 9–38. Timing Analyzer Tool**

## Conclusion

Evolving design and aggressive process technologies require larger and higher-performance FPGA designs. Increasing design complexity demands enhanced static timing analysis tools that aid designers in verifying design timing requirements. Without advanced static timing analysis tools, you risk circuit failure in complex designs. The Quartus II Classic Timing Analyzer incorporates a set of powerful static timing analysis features critical in enabling system-on-a-programmable-chip (SOPC) designs.

## Referenced Documents

This chapter references the following documents:

- *altpll Megafunction User Guide*
- *AN 411: Understanding PLL timing for Stratix II Devices*
- *Assignment Editor* chapter in volume 2 of the *Quartus II Handbook*
- *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*
- *Quartus II Scripting Reference Manual*
- *Quartus II Settings File Reference Manual*
- *Quartus II TimeQuest Timing Analyzer* chapter of the *Quartus II Handbook*
- *Switching to the Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*
- *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*

## Document Revision History

Table 9–2 shows the revision history for this chapter.

| <b>Table 9–2. Document Revision History (Part 1 of 2)</b> |                                                                                                                                                                                                                                                        |                                                                              |
|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| <b>Date and Version</b>                                   | <b>Changes Made</b>                                                                                                                                                                                                                                    | <b>Summary of Changes</b>                                                    |
| May 2008<br>v8.0.0                                        | Added hyperlinks to referenced documents throughout the chapter.<br>No other substantive changes were made.                                                                                                                                            | —                                                                            |
| October 2007<br>v7.2.0                                    | Reorganized “Referenced Documents” on page 8–63.                                                                                                                                                                                                       | —                                                                            |
| May 2007<br>v7.1.0                                        | <ul style="list-style-type: none"> <li>Updated Quartus II software 7.1 revision and date</li> <li>Added information about Arria GX</li> <li>Added Referenced Document</li> <li>No new screenshots were taken</li> </ul>                                | Very minor update pertaining to Arria GX.                                    |
| March 2007 v7.0.0                                         | Updated Quartus II software 7.0 revision and date only. No other changes made to chapter.                                                                                                                                                              | —                                                                            |
| November 2006<br>v6.1.0                                   | <ul style="list-style-type: none"> <li>Added paragraphs about multicycle assignments on page 8–17 and page 8–18</li> <li>Updated Figure 8–24 on page 8–42 (screenshot update)</li> <li>Updated Figure 8–25 on page 8–43 (screenshot update)</li> </ul> | Minor clarification of text referring to input and output delay assignments. |
| May 2006<br>v6.0.0                                        | Chapter title changed to <i>Classic Timing Analyzer</i> .<br>Updated for the Quartus II software version 6.0.0: <ul style="list-style-type: none"> <li>Updated GUI information.</li> </ul>                                                             | —                                                                            |
| October 2005<br>v5.1.0                                    | Updated for the Quartus II software version 5.1.                                                                                                                                                                                                       | —                                                                            |
| August 2005<br>V5.0.1                                     | Document revision 1.0.                                                                                                                                                                                                                                 | —                                                                            |
| May 2005<br>V5.0.0                                        | New functionality for Quartus II software 5.0                                                                                                                                                                                                          | —                                                                            |
| Jan. 2005<br>v2.2                                         | Updated information pertaining to realistic, optimistic, and pessimistic settings                                                                                                                                                                      | —                                                                            |
| Dec. 2004<br>v2.1                                         | <ul style="list-style-type: none"> <li>Chapter 5 was formerly Chapter 4.</li> <li>Updates to tables and figures.</li> <li>New functionality for Quartus II software 4.2.</li> </ul>                                                                    | —                                                                            |
| June 2004<br>v2.0                                         | <ul style="list-style-type: none"> <li>Updates to tables and figures.</li> <li>New functionality for Quartus II software 4.1.</li> </ul>                                                                                                               | —                                                                            |
| Feb. 2004<br>v1.0                                         | Initial release.                                                                                                                                                                                                                                       | —                                                                            |

**Table 9–2. Document Revision History (Part 2 of 2)**

| Date and Version       | Changes Made                                                                                                                                                                               | Summary of Changes |
|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| May 2006<br>v6.0.0     | Chapter title changed to <i>Classic Timing Analyzer</i> .<br>Updated for the Quartus II software version 6.0.0: <ul style="list-style-type: none"><li>• Updated GUI information.</li></ul> | —                  |
| October 2005<br>v5.1.0 | Updated for the Quartus II software version 5.1.                                                                                                                                           | —                  |



## Introduction

PrimeTime is an industry standard sign-off tool that performs static timing analysis on ASIC designs. The Quartus® II software makes it easy for designers to analyze their Quartus II projects using the PrimeTime software. The Quartus II software exports a netlist, design constraints (in the PrimeTime format), and libraries to the PrimeTime software environment. [Figure 10–1](#) shows the PrimeTime flow diagram.

**Figure 10–1. The PrimeTime Software Flow Diagram**



This chapter contains the following sections:

- “[Quartus II Settings for Generating the PrimeTime Software Files](#)” on [page 10–2](#)
- “[Files Generated for the PrimeTime Software Environment](#)” on [page 10–3](#)
- “[Running the PrimeTime Software](#)” on [page 10–10](#)
- “[PrimeTime Timing Reports](#)” on [page 10–12](#)
- “[Static Timing Analyzer Differences](#)” on [page 10–23](#)

## Quartus II Settings for Generating the PrimeTime Software Files

To set the Quartus II software to generate files for the PrimeTime software, perform the following steps:

1. In the Quartus II software, on the Assignments menu, click **EDA Tool Settings**.
2. In the **Category** list, under **EDA Tool Settings**, select **Timing Analysis**.
3. In the **Tool name** drop-down list, select **PrimeTime**, and in the **Format for output netlist** drop-down list, select either **Verilog** or **VHDL**, depending on the HDL language you chose for use with the PrimeTime software (Figure 10-2).

**Figure 10-2. Setting the Quartus II Software to Generate the PrimeTime Software Files**



When you compile your project after making these settings, the Quartus II software runs the EDA Netlist Writer to create three files for the PrimeTime software. These files are saved in the `<revision_name>/timing/primetime` directory by default, where `<revision_name>` is the name of your Quartus II software revision. If it is not, you have used the wrong variable name.

## Files Generated for the PrimeTime Software Environment

The Quartus II software generates a flattened netlist, a Standard Delay Output File (.sdo), and a Tcl script that prepares the PrimeTime software for timing analysis of the Quartus II project. These files are saved in the `<project_directory>/timing/primetime` directory.

The Quartus II software uses the EDA Netlist Writer to generate PrimeTime files based on either the Quartus II Classic Timing Analyzer or the Quartus II TimeQuest Timing Analyzer static timing analysis results. When you run the EDA Netlist Writer, the PrimeTime SDO files are based on delays generated by the currently selected timing analysis tool in the Quartus II software.

To specify the timing analyzer, on the Assignments menu, click **Settings**. The **Settings** dialog box appears. Under **Category**, click **Timing Analysis Settings**. Select the timing analyzer of your choice.



For more information about specifying the Quartus II timing analyzers, refer to either the *Quartus II Classic Timing Analyzer* or the *Quartus II TimeQuest Timing Analyzer* chapters in volume 3 of the *Quartus II Handbook*. Also, refer to the *Switching to the Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook* to help you decide which timing analyzer is most appropriate for your design.

### The Netlist

Depending on whether **Verilog** or **VHDL** is selected as the **Format for output netlist** option, in the **Tool name** list on the **Timing Analysis** page of the **Settings** dialog box, the netlist is written and saved as either `<project name>.vo` or `<project name>.vho`, respectively. This file contains the flattened netlist representing the entire design.



When the Quartus II TimeQuest Timing Analyzer is selected, only a Verilog PrimeTime netlist is generated.

## The SDO File

The Quartus II software saves the Standard Delay Format Output (**.sdo**) File as either `<revision_name>_v.sdo` or `<revision_name>_vhdl.sdo`, depending on whether you selected **Verilog** or **VHDL** in the **Tool name** list on the **Timing Analysis** page of the **Settings** dialog box.

This file contains the timing information for each timing path between any two nodes in the design.

When the Quartus II Classic Timing Analyzer is enabled, the slow-corner (worst case) timing models are used by default when generating the SDO file. To generate the SDO file using the fast-corner (best case) timing models, perform the following steps:

1. In the Quartus II software, on the Processing menu, point to Start and click **Start Classic Timing Analyzer (Fast Timing Model)**.
2. After the fast-corner timing analysis is complete, on the Processing menu, point to Start and click **Start EDA Netlist Writer** to create a `<revision_name>_v_fast.sdo` or `<revision_name>_vhdl_fast.sdo` file, which contains the best-case delay values for each timing path.



If you are running a best-case timing analysis, the Quartus II software generates a Tcl script similar to the following:  
`<revision_name>_pt_v_fast.tcl`.

When TimeQuest is run with the fast-corner netlist or when the **Optimize fast-corner timing** check box is selected in the **Fitter Settings** dialog box, the fast-corner SDC file is generated.

After the EDA Netlist Writer has finished, two SDO files are created: `<revision_name>_v.sdo` (slow-corner) or `<revision_name>_v_fast.sdo` (fast-corner).

### *Generating Multiple Operating Conditions with TimeQuest*

Different operating conditions can be specified to the EDA Netlist Writer for PrimeTime analysis. The different operating conditions are reflected in the **.sdo** file generated by the EDA Netlist Writer.

Table 10–1 shows the available operating conditions that can be set for a few of Altera's device families.

| <b>Table 10–1. Available Operating Condition Combinations</b> |                                                                            |
|---------------------------------------------------------------|----------------------------------------------------------------------------|
| <b>Device Family</b>                                          | <b>Available Conditions<br/>(Model, Voltage, Temperature)</b>              |
| Stratix III                                                   | (slow, 1100 mV, 85° C),<br>(slow, 1100 mV, 0° C),<br>(fast, 1100 mV, 0° C) |
| Cyclone III                                                   | (slow, 1200 mV, 85° C),<br>(slow, 1200 mV, 0° C),<br>(fast, 1200 mV, 0° C) |
| Stratix II                                                    | (slow, N/A, N/A), (fast, N/A, N/A)                                         |
| Cyclone II                                                    | (slow, N/A, N/A), (fast, N/A, N/A)                                         |



From the TimeQuest Console pane, use the command `get_available_operating_conditions` to obtain a list of available operating conditions for the target device.

The following steps shows how to generate the `.sdo` files for the three different operating conditions for a Stratix III design. Each command must be entered at the command prompt.



The `-tq2pt` option for `quartus_sta` is required only if the project doesn't specify that PrimeTime tool will be used as the timing analysis tool.

1. Generate the first slow corner model at the operating conditions: slow, 1100 mV, and 85° C.

```
quartus_sta --model=slow --voltage=1100 --
temperature=85 <project name>
```

2. Generate the fast corner model at the operating conditions: fast, 1100 mV, and 0° C.

```
quartus_sta --model=fast --voltage=1100 --
temperature=0 --tq2pt <project name>
```

3. Generate the PrimeTime output files for the corners specified above. The output files will be generated in the **primetime\_two\_corner\_files** directory.

```
quartus_eda --timing_analysis --tool=primetime
--format=verilog --
output_directory=primetime_two_corner_files --
write_settings_files=off <project name>
```

4. Generate the second slow corner model at the operating conditions: slow, 1100 mV, and 0° C.

```
quartus_sta --model=slow --voltage=1100 --
temperature=0 --tq2pt <project name>
```

5. Generate the PrimeTime output files for the second slow corner. The output files will be generated in the **primetime\_one\_slow\_corner\_files** directory.

```
quartus_eda --timing_analysis --tool=primetime --
format=verilog --
output_directory=primetime_one_slow_corner_files -
-write_settings_files=off $revision
```

To summarize, the previous steps generate the following files for the three operating conditions:

- First slow corner (slow, 1100 mV, 85° C):  
VO File—**primetime\_two\_corner\_files/<project name>.vo**  
SDO File—**primetime\_two\_corner\_files/<project name>\_v.sdo**
- Fast corner (fast, 1100 mV, 0° C):  
VO File—**primetime\_two\_corner\_files/<project name>.vo**  
SDO File—**primetime\_two\_corner\_files/<project name>\_v\_fast.sdo**
- Second slow corner (slow, 1100 mV, 0° C):  
VO File—**primetime\_one\_slow\_corner\_files/<project name>.vo**  
SDO File—**primetime\_one\_slow\_corner\_files/<project name>\_v.sdo**



The directory **primetime\_one\_slow\_corner\_files** may also have files for fast corner. These files can be ignored since they were already generated in the **primetime\_two\_corner\_files** directory.

## The Tcl Script

The Tcl script generated by the Quartus II software contains information required by the PrimeTime software to analyze the timing and set up your post-fit design. This script specifies the search path and the names of the PrimeTime database library files provided with the Quartus II software. The `search_path` and `link_path` variables are defined at the beginning of the Tcl file. The `link_path` variable is a space-delimited list that contains the names of all database files used by the PrimeTime software.

Depending on whether you selected **Verilog** or **VHDL** in the **Format for output netlist** list on the **Timing Analysis** page of the **Settings** dialog box, when the Quartus II Classic Timing Analyzer is enabled, the EDA Netlist Writer generates and saves the script as either `<revision_name>_pt.v.tcl` or `<revision_name>_pt.vhd.tcl`.

To access the **EDA Settings** dialog box, on the Assignments menu, click **EDA Tool Settings**, then expand **EDA Tool Settings** under the Category list. In the dialog box, you can specify VHDL or Verilog for the format for the output netlist.



The script also directs the PrimeTime software to use the `<device family>_all_pt.v` or `<device family>_all_pt.vhd` file, which contains the Verilog or VHDL description of library cells for the targeted device family.

**Example 10-1** shows the `search_path` and `link_path` variables defined in the Tcl script:

### Example 10-1. Sample PrimeTime Setup Script

```
set quartus_root "altera/quartus/"
set search_path [list . [format "%s%s" $quartus_root "eda/synopsys/primetime/lib"]]

set link_path [list * stratixii_lcell_comb.lib.db stratixii_lcell_ff.lib.db
stratixii_asynch_io.lib.db stratixii_io_register.lib.db stratixii_termination.lib.db
bb2.lib.db stratixii_ram_internal.lib.db stratixii_memory_register.lib.db
stratixii_memory_addr_register.lib.db stratixii_mac_out_internal.lib.db
stratixii_mac_mult_internal.lib.db stratixii_mac_register.lib.db
stratixii_lvds_receiver.lib.db stratixii_lvds_transmitter.lib.db
stratixii_asmiblock.lib.db stratixii_crcblock.lib.db stratixii_jtag.lib.db
stratixii_rublock.lib.db stratixii_pll.lib.db stratixii_dll.lib.db alt_vtl.lib]

read_vhdl -vhdl_compiler stratixii_all_pt.vhd
```

The EDA Netlist Writer converts any Quartus II Classic Timing Analyzer timing assignments to the PrimeTime software constraints and exceptions when it generates the PrimeTime files. The converted constraints are saved to the Tcl script. The Tcl script also includes a

PrimeTime software command that reads the Standard Delay Format Output (.sdo) file generated by the Quartus II software. You can place additional commands in the Tcl script to analyze or report on timing paths.

Table 10–2 shows some examples of timing assignments converted by the Quartus II software for the PrimeTime software. For example, the `set_input_delay -max` command sets the input delay on an input pin.

| <b>Table 10–2. Equivalent Quartus II and PrimeTime Software Constraints</b> |                                                                                               |
|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| <b>Quartus II Equivalent</b>                                                | <b>PrimeTime Constraint</b>                                                                   |
| Clock defined on input pin, clock of 10 ns period and 50% duty cycle        | <code>create_clock -period 10.000 -waveform {0 5.000} \ [get_ports clk] -name clk</code>      |
| Input maximum delay of 1 ns on input pin, <b>din</b>                        | <code>set_input_delay -max -add_delay 1.000 -clock \ [get_clocks clk] [get_ports din]</code>  |
| Input minimum delay of 1 ns on input pin, <b>din</b>                        | <code>set_input_delay -min -add_delay 1.000 -clock \ [get_clocks clk] [get_ports din]</code>  |
| Output maximum delay of 3 ns on output pin, <b>out</b>                      | <code>set_output_delay -max -add_delay 3.000 -clock \ [get_clocks clk] [get_ports out]</code> |

When the Quartus II TimeQuest Timing Analyzer is turned on, the EDA Netlist Writer generates and saves the script as `<revision_name>.pt.tcl`.

The EDA Netlist Writer converts all Quartus II TimeQuest Timing Analyzer SDC constraints and exceptions into compatible PrimeTime software constraints and exceptions when it generates the PrimeTime files. The constraints and exceptions are saved to the `<revision_name>.constraints.sdc` file.

### Generated File Summary

The files that are generated by the EDA Netlist Writer for the PrimeTime software depend on the Quartus II timing analysis tool you selected.

Table 10–3 shows the files that are generated for the PrimeTime software when the Quartus II Classic Timing Analyzer is selected.

**Table 10–3. Quartus II Classic Timing Analyzer-Generated PrimeTime Files**

| File                                                                                           | Description                                                                                                                                                                              |
|------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>&lt;revision_name&gt;.vho</code>   <code>&lt;revision_name&gt;.vo</code>                 | The PrimeTime software output netlist. Either a VHDL Output File or a Verilog Output file is generated, depending on the output netlist language set.                                    |
| <code>&lt;revision_name&gt;_vhd.sdo</code>  <br><code>&lt;revision_name&gt;_v.sdo</code>       | The PrimeTime software standard delay file. Either a VHDL Standard Delay Output file or a Verilog Standard Delay Output file is generated, depending on the output netlist language set. |
| <code>&lt;revision_name&gt;_pt_vhd.tcl</code>  <br><code>&lt;revision_name&gt;_pt_v.tcl</code> | PrimeTime setup and constraint script. Either a VHDL Tcl script or a Verilog Tcl script is generated, depending on the output netlist language set.                                      |

Table 10–4 shows the files that are generated for the PrimeTime software when the Quartus II TimeQuest Timing Analyzer is selected. The EDA Netlist Writer supports the output netlist format only when the TimeQuest Timing Analyzer is enabled.

**Table 10–4. Quartus II TimeQuest Timing Analyzer-Generated PrimeTime Files**

| File                                                                                        | Description                                                                                                                                  |
|---------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| <code>&lt;revision_name&gt;.vo</code>                                                       | The PrimeTime software output netlist. When the Quartus II TimeQuest Timing Analyzer is enabled, only PrimeTime (Verilog) is supported.      |
| <code>&lt;revision_name&gt;_v.sdo</code>  <br><code>&lt;revision_name&gt;_v_fast.sdo</code> | The PrimeTime software standard delay file. When the Quartus II TimeQuest Timing Analyzer is enabled, only PrimeTime (Verilog) is supported. |
| <code>&lt;revision_name&gt;.pt.tcl</code>                                                   | PrimeTime setup and constraint script. When the Quartus II TimeQuest Timing Analyzer is enabled, only PrimeTime (Verilog) is supported.      |
| <code>&lt;revision_name&gt;.collections.sdc</code>                                          | Contains the mapping from the Quartus II TimeQuest Timing Analyzer netlist to the PrimeTime netlist.                                         |
| <code>&lt;revision_name&gt;.constraints.sdc</code>                                          | Contains the converted Quartus II TimeQuest Timing Analyzer constraints for the PrimeTime software.                                          |

## Running the PrimeTime Software

The PrimeTime software runs only on UNIX operating systems. If the Quartus II output files for the PrimeTime software were generated by running the Quartus II software on a PC/Windows-based system, follow these steps to run the PrimeTime software using Quartus II output files:

1. Install the PrimeTime libraries on a UNIX system by installing Quartus II software on UNIX.

The PrimeTime libraries are located in the *<Quartus II installation directory>/eda/synopsys/primetime/lib* directory.

2. Copy the Quartus II output files to the appropriate UNIX directory. You may need to run a PC to UNIX program, such as dos2unix, to remove any control characters.
3. Modify the Quartus II path in Tcl scripts to point to the PrimeTime libraries, as described in Step 1. In [Example 10-1](#), the first line is:

```
set quartus_root "altera/quartus/" set search_path [list . [format "%s%s" $quartus_root "eda/synopsys/primetime/lib"] ]
```

This is the Tcl script that should be modified.

## Analyzing Quartus II Projects

The PrimeTime software is controlled with Tcl scripts and can be run through `pt_shell`. You can run the *<revision\_name>\_pt\_v.tcl* script file. For example, type the following at a UNIX system command prompt:

```
pt_shell -f <revision_name>_pt_v.tcl ↵
```

When the Quartus II TimeQuest Timing Analyzer is selected, type the following at a UNIX system command prompt:

```
pt_shell -f <revision_name>.pt.tcl ↵
```

After all Tcl commands in the script are interpreted, the PrimeTime software returns control to the `pt_shell` prompt, which allows you to use other commands.

## Other pt\_shell Commands

You can run additional pt\_shell commands at the pt\_shell prompt, including the `man` program. For example, to read documentation about the `report_timing` command, type the following at the pt\_shell prompt:

```
man report_timing ↵
```

You can list all commands available in pt\_shell by typing the following at the pt\_shell prompt:

```
help ↵
```

Type `quit ↵` at the pt\_shell prompt to close pt\_shell.



You can also run pt\_shell without a script file by typing `pt_shell ↵` at the UNIX command line prompt.

## PrimeTime Timing Reports

### Sample of the PrimeTime Software Timing Report

After running the script, the PrimeTime software generates a timing report. If the timing constraints are not met, **Violated** is displayed at the end of the timing report. The timing report also gives the negative slack.

The PrimeTime software report is similar to the sample shown in [Example 10-2](#). The starting point in this report is a register clocked by clock signal, *clock*, the endpoint is another register, *inst3~I.lereg*.

---

#### **Example 10-2. Hold Path Report in PrimeTime**

```
Startpoint: inst2~I.lereg
  (rising edge-triggered flip-flop clocked by clock)
Endpoint: inst3~I.lereg
  (rising edge-triggered flip-flop clocked by clock)
Path Group: clock
Path Type: min
Point  IncrPath
-----
clock clock (rise edge)0.0000.000
clock network delay (propagated)3.1663.166
inst2~I.lereg.clk (stratix_lcell_register)0.000 3.166r
inst2~I.lereg.regout (stratix_lcell_register)  <-0.176*3.342r
inst2~I.regout (stratix_lcell)0.000*3.342r
inst3~I.datac (stratix_lcell)0.000*3.342r
inst3~I.lereg.datac (stratix_lcell_register)3.413*6.755r
data arrival time6.755
clock clock (rise edge)0.0000.000
clock network delay (propagated)3.0023.002
inst3~I.lereg.clk (stratix_lcell_register)3.002r
library hold time0.100*3.102
data required time 3.102
-----
data required time3.102
data arrival time-6.755
-----
slack (MET)3.653
```

---

## Comparing Timing Reports from the Quartus II Classic Timing Analyzer and the PrimeTime Software

Both the Quartus II Classic Timing Analyzer and the Quartus II TimeQuest Timing Analyzer generate a static timing analysis report for every successful design compilation. The timing report lists all of the analyzed timing paths in your design that were analyzed, and indicates whether these paths have met or violated their timing requirements. Violations are reported only if timing constraints were specified.

The Quartus II TimeQuest Timing Analyzer uses an equivalent set of equations as PrimeTime when reporting the static timing analysis result for a design. However, the Quartus II Classic Timing Analyzer uses slightly different reporting equations when reporting the static timing analysis results for a design. This section describes these differences between the Quartus II Classic Timing Analyzer and the PrimeTime software.

The timing report generated by the Quartus II Classic Timing Analyzer differs from the report generated by the PrimeTime software. Both tools provide the same data but present in different formats. The following sections show how the PrimeTime software reports the following slack values differently from the Quartus II Classic Timing Analyzer report:

- “Clock Setup Relationship and Slack” on page 10–13
- “Clock Hold Relationship and Slack” on page 10–17
- “Input Delay and Output Delay Relationships and Slack” on page 10–21

### *Clock Setup Relationship and Slack*

The Quartus II Classic Timing Analyzer performs a setup check that ensures that the data launched by source registers is latched correctly at the destination registers. The Quartus II Classic Timing Analyzer does this by determining the data arrival time and clock arrival time at the destination registers, and compares this data with the setup time delay of the destination register. [Equation 1](#) expresses the inequality that is used for a setup check. The data arrival time includes the longest path from the clock to the source register, the clock-to-out micro delay of the source register, and the longest path from the source register to the destination register. The clock arrival time is the shortest delay from the clock to the destination register.

$$(1) \quad \text{Clock Arrival} - \text{Data Arrival} \geq t_{su}$$

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 was not met.

The Quartus II Classic Timing Analyzer determines the clock setup slack, with [Equation 2](#):

$$(2) \quad \text{Clock Setup Slack} = \text{Largest Register-to-Register Requirement} - \text{Longest Register-to-Register Delay}$$

 The longest register-to-register delay in the previous equation is equal to the register-to-register data delay.

$$(3) \quad \begin{aligned} \text{Largest Register-to-Register Requirement} &= \\ \text{Setup Relationship between Source and Destination} &+ \text{Largest Clock Skew} - \\ \text{Micro } t_{co} \text{ of Destination Register} &- \text{Micro } t_{su} \text{ of Destination Register} \end{aligned}$$

Setup Relationship between Source and Destination = Latch Edge – Launch Edge

Clock Skew = Shortest Clock Path to Destination – Longest Clock Path to Source

For a simple three-register design, refer to [Figure 10–3](#).

**Figure 10–3. Simple Three-Register Design**



The Quartus II Classic Timing Analyzer generates a report for the design, as shown in Figure 10-4.

Figure 10-4. Timing Analyzer Report from Figure 10-3



Equation 1, 2, and 3 are similar to those found in other static timing analysis tools, such as the PrimeTime software. Equation 4, 5, 6, and 7, used by the PrimeTime software, are essentially the same as those used by the Quartus II Classic Timing Analyzer, but they are rearranged.

- (4)  $\text{Slack} = \text{Data Required} - \text{Data Arrival}$
- (5)  $\text{Clock Arrival} = \text{Latch Edge} + \text{Shortest Clock Path to Destination}$
- (6)  $\text{Data Required} = \text{Clock Arrival} - \text{Micro } t_{su}$
- (7)  $\text{Data Arrival} = \text{Launch Edge} + \text{Longest Clock Path to Source} + \text{Micro } t_{co} + \text{Longest Data Delay}$



The longest data delay in the previous equation is equal to register-to-register data delay.

Figure 10–5 shows a clock setup check in the Quartus II software.

**Figure 10–5. Clock Setup Check Reporting with the Quartus II Classic Timing Analyzer**



The following results are obtained by extracting the numbers from the Quartus II Classic Timing Analyzer report and applying them to the clock setup slack equations from the Quartus II Classic Timing Analyzer:

$$(8) \quad \text{Setup Relationship between Source and Destination} = \text{Latch Edge} - \text{Launch Edge} - \text{Clock Setup Uncertainty}$$

$$8.0 - 0.0 - 0.0 = 8.0\text{ns}$$

$$\text{Clock Skew} = \text{Shortest Clock Path to Destination} - \text{Longest Clock Path to Source}$$

$$3.002 - 3.166 = -0.164\text{ns}$$

$$\begin{aligned} \text{Largest Register-to-Register Requirement} &= \\ \text{Setup Relationship between Source \& Destination} &+ \text{Largest Clock Skew} \\ -\text{Micro } t_{co} \text{ of Source Register} &- \text{Micro } t_{su} \text{ of Destination Register} \end{aligned}$$

$$8 + (-0.164) - 0.176 - 0.010 = 7.650\text{ns}$$

$$\text{Clock Setup Slack} = \text{Largest Register-to-Register Requirement} - \text{Longest Register-to-Register Delay}$$

$$7.650 - 3.413 = 4.237\text{ns}$$

For the same register-to-register path, the PrimeTime software generates a clock setup report as shown in [Example 10-3](#):

---

**Example 10-3. Setup Path Report in PrimeTime**

```

Startpoint: inst2~I.lereg
  (rising edge-triggered flip-flop clocked by clock)
Endpoint: inst3~I.lereg
  (rising edge-triggered flip-flop clocked by clock)
Path Group: clock
Path Type: max  PointIncrPath
-----
clock clock (rise edge) 0.0000.000
clock network delay (propagated) 3.1663.166
inst2~I.lereg.clk (stratix_lcell_register) 0.0003.166r
inst2~I.lereg.regout (stratix_lcell_register) <- 0.176*3.342r
inst2~I.regout (stratix_lcell) <- 0.000*3.342r
inst3~I.dataac (stratix_lcell) <- 0.000*3.342r
inst3~I.lereg.dataac (stratix_lcell_register) 3.413*6.755r
data arrival time 6.755
clock clock (rise edge) 8.0008.000
clock network delay (propagated) 3.00211.002
inst3~I.lereg.clk (stratix_lcell_register) 11.002r
library setup time -0.010*10.992
data required time 10.992
-----
data required time 10.992
data arrival time -6.755
-----
slack (MET) 4.237

```

---

*Clock Hold Relationship and Slack*

The Quartus II Classic Timing Analyzer performs a hold time check along every register-to-register path in the design to ensure that no hold time violations have occurred. The hold time check verifies that data from the source register does not reach the destination until after the hold time of the destination register. The condition used for a hold check is shown in [Equation 9](#):

$$(9) \quad \text{Data Arrival} - \text{Clock Arrival} \geq t_H$$

The Quartus II Classic Timing Analyzer determines the clock hold slack with [Equation 10, 11, 12, and 13](#):

$$(10) \quad \text{Clock Hold Slack} = \text{Shortest Register-to-Register Delay} - \text{Smallest Register-to-Register Requirement}$$

- (11) Smallest Register-to-Register Requirement = Hold Relationship between Source & Destination + Smallest Clock Skew – Micro  $t_{SU}$  of Source + Micro  $t_H$  of Destination
- (12) Hold Relationship between Source & Destination = Latch Edge – Launch Edge
- (13) Smallest Clock Skew = Longest Clock Path from Clock to Destination Register – Shortest Clock Path from Clock to Source Register

Figure 10–6 shows a simple three-register design.

**Figure 10–6. A Simple Three-Register Design**



The Quartus II Classic Timing Analyzer generates a report as shown in Figure 10–7.

**Figure 10–7. Timing Analyzer Report Generated from the Three Register Design**



The previous equations are similar to those found in the Quartus II software. The following equations are the same equations that are used by the PrimeTime software, but they are rearranged.

- (14)  $\text{Slack} = \text{Data Required} - \text{Data Arrival}$
- (15)  $\text{Clock Arrival} = \text{Latch Edge} + \text{Longest Clock Path to Destination}$
- (16)  $\text{Data Required} = \text{Clock Arrival} - \text{Micro } t_H$
- (17)  $\text{Data Arrival} = \text{Launch Edge} + \text{Longest Clock Path to Source} + \text{Micro } t_{co} + \text{Shortest Data Delay}$



The shortest register-to-register delay in the previous equation is equal to register-to-register data delay.

Figure 10–8 shows a clock setup check with the Quartus II Classic Timing Analyzer.

---

#### Figure 10–8. Clock Hold Check Reporting with the Quartus II Classic Timing Analyzer

```

□ ⓘ Info: Minimum slack time is 3.653 ns for clock "clock" between source register "inst2" and destination register "inst3"
    + ⓘ Info: + Shortest register to register delay is 3.413 ns
    ⓘ Info: - Smallest register to register requirement is -0.240 ns
        ⓘ Info: + Hold relationship between source and destination is 0.000 ns
            + ⓘ Info: + Latch edge is 0.000 ns
            ⓘ Info: - Launch edge is 0.000 ns
            ⓘ Info: - Clock hold uncertainty between source and destination is 0.000 ns
        ⓘ Info: + Smallest clock skew is -0.164 ns
            + ⓘ Info: + Longest clock path from clock "clock" to destination register is 3.002 ns
            ⓘ Info: - Shortest clock path from clock "clock" to source register is 3.166 ns
            ⓘ Info: - Micro clock to output delay of source is 0.176 ns
            ⓘ Info: + Micro hold delay of destination is 0.100 ns

```

---

The following results are obtained by extracting the numbers from the Timing Analysis report and applying the clock setup slack equations from the Quartus II Classic Timing Analyzer.

$$(18) \text{Clock Hold Slack} = \text{Shortest Register-to-Register Delay} - \text{Smallest Register-to-Register Requirement}$$

$$3.413 - (-0.240) = 3.653\text{ns}$$

$$\text{Smallest Register-to-Register Requirement} = \text{Hold Relationship between Source \& Destination} +$$

$$\text{Smallest Clock Skew} - \text{Micro } t_{co} \text{ of Source} + \text{Micro } t_H \text{ of Destination}$$

$$0 + (-0.164) - 0.176 + 0.100 = -0.240\text{ns}$$

Hold Relationship between Source & Destination = Latch – Launch

0.0 – 0.0ns

Smallest Clock Skew = Longest Clock Path from Clock to Destination Register – Shortest Clock Path from Clock to Source Register

3.002 – 3.166 = -0.164ns

For the same register-to-register path, the PrimeTime software generates the report shown in [Example 10-4](#):

---

**Example 10-4. Hold Path Report in PrimeTime**

```
Startpoint: inst2~I.lereg
  (rising edge-triggered flip-flop clocked by clock)
Endpoint: inst3~I.lereg
  (rising edge-triggered flip-flop clocked by clock)
Path Group: clock
Path Type: min
Point  IncrPath
-----
clock clock (rise edge)0.0000.000
clock network delay (propagated)3.1663.166
inst2~I.lereg.clk (stratix_lcell_register)0.0003.166r
inst2~I.lereg.regout (stratix_lcell_register)<-0.176*3.342r
inst2~I.regout (stratix_lcell)0.000*3.342r
inst3~I.datac (stratix_lcell)0.000*3.342r
inst3~I.lereg.datac (stratix_lcell_register)3.413*6.755r
data arrival time6.755

clock clock (rise edge)0.0000.000
clock network delay (propagated)3.0023.002
inst3~I.lereg.clk (stratix_lcell_register)3.002r
library hold time0.100*3.102
data required time                                3.102
-----
data required time3.102
data arrival time-6.755
-----
slack (MET)3.653
```

---

Both sets of hold slack equations can be used to determine the hold slack value of any path.

### *Input Delay and Output Delay Relationships and Slack*

Input delay and output delay reports generated by the Quartus II Classic Timing Analyzer are similar to the clock setup and clock hold relationship reports. [Figure 10–9](#) shows the input delay and output delay report for the design shown in [Figure 10–6](#) on page 10–18.

**Figure 10–9. Input and Output Delay Reporting with the Quartus II Classic Timing Analyzer**



[Figure 10–10](#) shows the fully expanded view for the output delay path.

**Figure 10–10. Output Delay Path Reporting with the Quartus II Classic Timing Analyzer**



For the same output delay path, the PrimeTime software generates a report similar to [Example 10-5](#):

**Example 10-5. Setup Path Report in PrimeTime**

```

Startpoint: inst3~I.lereg
  (rising edge-triggered flip-flop clocked by clock)
Endpoint: data_out
  (output port clocked by clock)
Path Group: clock
Path Type: max PointIncrPath
-----
clock clock (rise edge) 0.0000.000
clock network delay (propagated) 3.0023.002
inst3~I.lereg.clk (stratix_lcell_register) 0.0003.002r
inst3~I.lereg.regout (stratix_lcell_register) <- 0.176*3.178r
inst3~I.regout (stratix_lcell) <- 0.0003.178r
data_out~I.datain (stratix_io) <- 0.000 3.178r
data_out~I.out_mux3.A (mux21) <- 0.0003.178r
data_out~I.out_mux3.M0 (mux21) <- 0.000 3.178r
data_out~I.and2_22.IN1 (AND2) <- 0.0003.178r
data_out~I.and2_22.Y (AND2) <- 0.0003.178r
data_out~I.out_mux1.A (mux21) <- 0.0003.178r
data_out~I.out_mux1.M0 (mux21) <- 0.0003.178r
data_out~I.inst1.datain (stratix_asynch_io) <- 0.902*4.080r
data_out~I.inst1.padio (stratix_asynch_io) <- 2.495*6.575r
data_out~I.padio (stratix_io) <- 0.000 6.575r
data_out (out) 0.0006.575r
data arrival time 6.575
clock clock (rise edge) 8.0008.000
clock network delay (propagated) 0.0008.000
output external delay 1.2506.750
data required time 6.750
-----
data required time 6.750
data arrival time 6.575
-----
slack (MET) 0.175

```

To generate a list of the 100 worst paths and place this data into a file called **file.timing**, type the following command at the **pt\_shell** prompt:

```
report_timing -nworst 100 > file.timing ←
```

Timing paths in the PrimeTime software are listed in the order of most-negative-slack to most-positive-slack. The PrimeTime software does not categorize failing paths by default. Timing setup ( $t_{SU}$ ) and timing hold ( $t_H$ ) times are not listed separately. In the PrimeTime software, each path is shown with a start and end point; for example, if it is a

register-to-register or input-to-register type of path. If you only use the `report_timing` part of the command without adding a `-delay` option, only the `setup-time-related` timing paths are reported.

The following command is used to create a minimum timing report or a list of hold-time-related violations:

```
report_timing -delay_type min ↔
```

Ensure that the correct SDO file, either minimum or maximum delays, is loaded before running this command.

## Static Timing Analyzer Differences

Under certain design conditions, several static timing analysis differences can exist between the Classic Timing Analyzer and the TimeQuest Timing Analyzer, and the PrimeTime software. The following sections explain the differences between the two static timing analysis engines and the PrimeTime software.

### The Quartus II Classic Timing Analyzer and the PrimeTime Software

The following section describes the differences between the Quartus II Classic Timing Analyzer and the PrimeTime software.

#### *Rise/Fall Support*

The Quartus II Classic Timing Analyzer does not support rise/fall analysis. However, rise/fall support is available in PrimeTime.

#### *Minimum and Maximum Delays*

TimeQuest calculates minimum and maximum delays for all device components with the exception of clock routing. PrimeTime does not model these delays. This can result in different slacks for a given path on average by 2 - 3%.

#### *Recovery/Removal Analysis*

TimeQuest performs a more pessimistic recovery/removal analysis for asynchronous path than PrimeTime. This can result in different delays reported between the two tools.

### Encrypted Intellectual Property Blocks

The Quartus II software has the capability to decrypt all intellectual property (IP) blocks designed for Altera® devices that have been encrypted by their vendors. The decryption process allows the Quartus II software to perform a full compilation of the design that contains an encrypted IP block. This also allows the Quartus II Classic Timing Analyzer to perform a complete static timing analysis on the design. However, when the PrimeTime software is designated as the static timing analysis tool, the Quartus II EDA Netlist Writer does not generate either a VHDL Output File (.vho) or Verilog Output File (.vo) netlist file for designs that contain encrypted IP blocks for which the license does not permit generation of output netlists for third-party tools.

### Registered Clock Signals

Registered clock signals are clock signals that pass through a register before reaching the clock port of a sequential element. [Figure 10–11](#) shows an example of a registered clock signal.

**Figure 10–11. Registered Clock Signal**



If no clock setting is applied to the register on the clock path (shown as register `reg_1` in [Figure 10–11](#)), the Quartus II Classic Timing Analyzer treats the register in the clock path as a buffer. The delay of the buffer is equal to the CELL delay of the register plus the  $t_{CO}$  of the register. The PrimeTime software does not treat the register as a buffer.



For more information about creating clock settings, refer to the *Quartus II Classic Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

### Multiple Source and Destination Register Pairs

In any design, multiple paths may exist from a source register to a destination register. Each path from the source register to the destination register may have a different delay value due to the different routes taken. For example, Figure 10–12 shows a sample design that contains multiple path pairs between the source register and destination register.

**Figure 10–12. Multiple Source and Destination Pairs**



The Quartus II Classic Timing Analyzer analyzes all source and destination pairs, but reports only the source and destination register pair with the worst slack. For example, if the Path 2 pair delay is greater than the Path 1 pair delay in Figure 10–12, the Quartus II Classic Timing Analyzer reports the slack value of the Path 2 pair and not the Path 1 pair. The PrimeTime software reports all possible source and destination register pairs.

### Latches

By default, the Quartus II software implements all latches as combinational loops. The Quartus II Classic Timing Analyzer can analyze such latches by treating them as registers with inverted clocks or analyze latches as a combinational loop modeled as a combinational delay.



For more information about latch analysis, refer to the *Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

The PrimeTime software always analyzes these latches as combinational loops, as defined in the netlist file.

### LVDS I/O

When it analyzes the dedicated LVDS transceivers in your design, the Quartus II Classic Timing Analyzer generates the Receiver Skew Margin (RSKM) report and a Channel-to-Channel Skew (TCCS) report. The PrimeTime software does not generate these reports.

### *Clock Latency*

When a single clock signal feeds both the source and destination registers of a register-to-register path, and either an Early Clock Latency or a Late Clock Latency assignment has been applied to the clock signal, the Quartus II Classic Timing Analyzer does not factor in the clock latency values when it calculates the clock skew between the two registers. The Quartus II Classic Timing Analyzer factors in the clock latency values when the clock signal to the source and destination registers of a register-to-register path are different. The PrimeTime software applies the clock latency values when a single clock signal or different clock signals feeds the source and destination registers of a register-to-register path.

### *Input and Output Delay Assignments*

When a purely combinational (non-registered) path exists between an input pin and output pin of the Altera FPGA and both pins have been constrained with an input delay and an output delay assignment applied, respectively, the Quartus II Classic Timing Analyzer does not perform a clock setup or clock hold analysis. The PrimeTime software analyzes these paths.

### *Generated Clocks Derived from Generated Clocks*

The Quartus II Classic Timing Analyzer does not support a generated clock derived from a generated clock. This situation might occur if a generated clock feeds the input clock pin of a PLL. The output clock of the PLL is a generated clock.

## **The Quartus II TimeQuest Timing Analyzer and the PrimeTime Software**

The following sections describe the static timing analysis differences between the Quartus II TimeQuest Timing Analyzer and the PrimeTime software.

### *Encrypted Intellectual Property Blocks*

The Quartus II software has the capability to decrypt all IP blocks, designed for Altera devices that have been encrypted by their vendors. The decryption process allows the Quartus II software to perform a full compilation on the design containing an encrypted IP block. This also allows the Quartus II TimeQuest Timing Analyzer to perform a complete static timing analysis on the design. However, when the PrimeTime software is designated as the static timing analysis tool, the Quartus II

EDA Netlist Writer does not generate **.vho** or **.vo** netlist files for designs that contain encrypted IP blocks whose license does not permit generation of output netlists for other tools.

### *Latches*

By default, the Quartus II software implements all latches as combinational loops. The Quartus II TimeQuest Timing Analyzer can analyze such latches by treating them as registers with inverted clocks. The Quartus II TimeQuest Timing Analyzer analyzes latches as a combinational loop modeled as a combinational delay.



For more information about latch analysis, refer to the *Quartus II Classic Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

The PrimeTime software always analyzes these latches as combinational loops, as defined in the netlist file.

### *LVDS I/O*

When it analyzes the dedicated LVDS transceivers in your design, the Quartus II TimeQuest Timing Analyzer generates a Receiver Skew Margin (RSKM) report and a Channel-to-Channel Skew (TCCS) report. The PrimeTime software does not generate these reports.

### *The Quartus II TimeQuest Timing Analyzer SDC File and PrimeTime Compatibility*

Because of differences between node naming conventions with the netlist generated by the EDA Netlist Writer and the internal netlist used by the Quartus II software, SDC files generated for the Quartus II software or the Quartus II TimeQuest Timing Analyzer are not compatible with the PrimeTime software.

Run the EDA Netlist Writer to generate a compatible SDC file from the TimeQuest SDC file for the PrimeTime software. After the files have been generated, `<revision_name>.collections.sdc` and `<revision_name>.constraints.sdc`, both files can be read in by the PrimeTime software for compatibility of constraints between the Quartus II TimeQuest Timing Analyzer and the PrimeTime software.

### *Clock and Data Paths*

If a timing path acts both as a clock path (a path that connects to a clock pin with a clock associated to it), and a data path (a path that feeds into the data in port of a register), the Quartus II TimeQuest Timing Analyzer will report the data paths, whereas PrimeTime will not.

### *Inverting and Non-Inverting Propagation*

TimeQuest always propagates non-inverting sense for clocks through non-unate paths in the clock network.

PrimeTime's default behavior is to propagate both inverting and non-inverting senses through a non-unate path in the clock network.

### *Multiple Rise/Fall Numbers For a Timing Arc*

For a given timing path with a corresponding set of pins/ports that make up the path (including source and destination pair), if the individual components of that path have different rise/fall delays, there can potentially be many timing paths with different delays using the same set of pins. If this occurs, TimeQuest reports only one timing path for the set of pins that make up the path.

### *Virtual Generated Clocks*

PrimeTime does not support generated clocks that are virtual. To maintain compatibility between TimeQuest and PrimeTime, all generated clocks should have an explicit target specified.

### *Generated Clocks Derived from Generated Clocks*

The Quartus II Classic Timing Analyzer does not support the creation of a generated clock derived from a generated clock. This situation might occur if a generated clock feeds the input clock pin of another generated clock. The output clock of the PLL is a generated clock.

## **Conclusion**

The Quartus II software can export a netlist, constraints, and timing information for use with the PrimeTime software. The PrimeTime software can use data from either best-case or worst-case Quartus II timing models to measure timing. The PrimeTime software is controlled using a Tcl script generated by the Quartus II software that you can customize to direct the PrimeTime software to produce violation and slack reports.

## Referenced Documents

This chapter references the following documents:

- *Quartus II Handbook*
- *Quartus II Classic Timing Analyzer chapter* in volume 3 of the *Quartus II Handbook*
- *Quartus II TimeQuest Timing Analyzer* in volume 3 of the *Quartus II Handbook*
- *Switching to the Quartus II TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*

## Document Revision History

Table 10–5 shows the revision history for this chapter.

| <b>Table 10–5. Document Revision History</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                  |
|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|
| <b>Date and Version</b>                      | <b>Changes Made</b>                                                                                                                                                                                                                                                                                                                                                                                                                         | <b>Summary of Changes</b>                                                        |
| May 2008<br>v. 8.0.0                         | <ul style="list-style-type: none"> <li>Updated to Quartus II software version 8.0 and date.</li> <li>Added hyperlinks to referenced Altera documentation throughout the chapter.</li> </ul>                                                                                                                                                                                                                                                 | —                                                                                |
| October 2007<br>v7.2.0                       | Reorganized “Referenced Documents” on page 9–29.                                                                                                                                                                                                                                                                                                                                                                                            | —                                                                                |
| May 2007<br>v7.1.0                           | <ul style="list-style-type: none"> <li>Added Generating Multiple Operating Conditions with TimeQuest</li> <li>Added Rise/Fall Support</li> <li>Added Minimum and Maximum Delays</li> <li>Added Recovery/Removal Analysis</li> <li>Added Generated Clocks Derived from Generated Clocks</li> <li>Added Multiple Rise/Fall Numbers for a Timing Analyzer SDC</li> <li>Virtual Generated Clocks</li> <li>Added Referenced Documents</li> </ul> | Updates added to the Static Timing Analyzer Differences section of this chapter. |
| March 2007<br>v7.0.0                         | Updated Quartus II software 7.0 revision and date only.<br>No other changes made to chapter.                                                                                                                                                                                                                                                                                                                                                | —                                                                                |
| November 2006<br>v6.1.0                      | <ul style="list-style-type: none"> <li>Noted the differences between the different timing analyzers</li> <li>Explained how to select between the timing analyzers</li> <li>Introduced the TimeQuest flow with PrimeTime</li> </ul>                                                                                                                                                                                                          | Introduction of the TimeQuest Timing Analyzer updated in this chapter.           |
| May 2006<br>v6.0.0                           | Chapter title changed to <i>Synopsys PrimeTime Support</i> .<br>Minor updates for the Quartus II software version 6.0.0.                                                                                                                                                                                                                                                                                                                    | —                                                                                |
| October 2005<br>v5.1.0                       | Updated for the Quartus II software version 5.1.                                                                                                                                                                                                                                                                                                                                                                                            | —                                                                                |
| August 2005<br>v5.0.1                        | Minor text updates.                                                                                                                                                                                                                                                                                                                                                                                                                         | —                                                                                |
| May 2005<br>v5.0.0                           | New functionality for Quartus II software 5.0.0                                                                                                                                                                                                                                                                                                                                                                                             | —                                                                                |
| December 2004<br>v2.0                        | <ul style="list-style-type: none"> <li>Chapter 6 Synopsys PrimeTime moved to section III Volume 1.</li> <li>New functionality for Quartus II software 4.2.</li> </ul>                                                                                                                                                                                                                                                                       | —                                                                                |

As FPGA designs grow larger and processes continue to shrink, power becomes an ever-increasing concern. When designing a printed circuit board, the power consumed by a device needs to be accurately estimated to develop an appropriate power budget, and to design the power supplies, voltage regulators, heat sink, and cooling system.

The Quartus® II software allows you to estimate the power consumed by your current design during timing simulation. The power consumption of your design can be calculated using the Microsoft Excel-based power calculator, or the Simulation-Based Power Estimation features in the Quartus II software. This section explains how to use both.

This section includes the following chapter:

- [Chapter 11, PowerPlay Power Analysis](#)



For information about the revision history for chapters in this section, refer to each individual chapter for that chapter's revision history.



## Introduction

As designs grow larger and process technology continues to shrink, power becomes an increasingly important design consideration. When designing a printed circuit board (PCB), the power consumed by a device needs to be accurately estimated to develop an appropriate power budget and to design the power supplies, voltage regulators, heat sink, and cooling system. The PowerPlay Power Analysis tools, made available by Altera<sup>®</sup>, provide improved power consumption accuracy and the ability to estimate power consumption from early design concept through design implementation, as shown in [Figure 11-1](#).

**Figure 11-1. PowerPlay Power Analysis**



Depending where you are in your design cycle and the accuracy of the estimation required, you can either use the PowerPlay Early Power Estimator spreadsheet or the PowerPlay Power Analyzer Tool in the Quartus<sup>®</sup> II software. You can use the PowerPlay Early Power Estimator spreadsheet during the board design and layout phase to obtain a power estimate and then design for proper power management. The PowerPlay Power Analyzer Tool is used to obtain an accurate estimation of power after the design is complete, ensuring that thermal and supply budgets are not violated.

You can estimate power consumption for Arria™ GX, Stratix® series devices, Cyclone® series devices, HardCopy® II, and MAX® II devices with the Microsoft Excel-based PowerPlay Early Power Estimator spreadsheet or the PowerPlay Power Analyzer Tool.



For more information about acquiring the PowerPlay Power Estimator spreadsheet for Arria GX, Stratix series devices, Cyclone series, HardCopy II, and MAX II devices and its use, refer to *PowerPlay Early Power Estimators (EPE) and Power Analyzer* on the Altera website.

This chapter discusses the following topics:

- “Quartus II Early Power Estimator File”
- “Types of Power Analyses” on page 11–6
- “Factors Affecting Power Consumption” on page 11–7
- “Using the PowerPlay Power Analyzer” on page 11–22

## Quartus II Early Power Estimator File

When entering data into the Early Power Estimator spreadsheet, you must enter the device resources, operating frequency, toggle rates, and other parameters. This requires familiarity with the design. If you do not have an existing design, you must estimate the number of device resources used in your design and enter it manually.

If you already have an existing design or a partially completed design, the power estimator file that is generated by the Quartus II software can aid in completing the PowerPlay Early Power Estimator spreadsheet.

To generate the power estimation file, you must first compile your design in the Quartus II software. After compilation is complete, on the Project menu, click **Generate PowerPlay Early Power Estimator File** (Figure 11–2). This command instructs the Quartus II software to write out a power estimator Comma-Separated Value (.csv) file (or a text [.txt] file for older device families).

---

**Figure 11–2. Generate PowerPlay Early Power Estimator File Option**



---

After the Quartus II software successfully generates the power estimator file, a message appears (Figure 11–3).

---

**Figure 11–3. Generate PowerPlay Early Power Estimator File Message**



---

The power estimator file is named `<name of Quartus II project>_early_pwr.csv`. Figure 11–4 is an example of the contents of a power estimation file generated by the latest version of Quartus II software using a Stratix II device.

Figure 11–4. Example of Power Estimation File

| A                                           | B                                                                                       | C | D | E | F | G | H | I | J |
|---------------------------------------------|-----------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|
| 1 EARLY_POWER_ESTIMATOR_FILE_FORMAT_VERSION | 6                                                                                       |   |   |   |   |   |   |   |   |
| 2 QUARTUS_II_VERSION                        | 8.0 Internal Build 170 02/28/2008 SJ Full Version                                       |   |   |   |   |   |   |   |   |
| 3 PROJECT                                   | Multaccum                                                                               |   |   |   |   |   |   |   |   |
| 4 REVISION                                  | Multaccum                                                                               |   |   |   |   |   |   |   |   |
| 5 PROJECT_FILE                              | C:/Pipeline/Multiplier_Accum/Multaccum.qpf                                              |   |   |   |   |   |   |   |   |
| 6 TIME                                      | Mon Jul 09 14:28:12 2007                                                                |   |   |   |   |   |   |   |   |
| 7 TIME_SECONDS                              | 1184016492                                                                              |   |   |   |   |   |   |   |   |
| 8 FAMILY                                    | Stratix II                                                                              |   |   |   |   |   |   |   |   |
| 9 DEVICE                                    | EP2S30                                                                                  |   |   |   |   |   |   |   |   |
| 10 PACKAGE                                  | FBGA                                                                                    |   |   |   |   |   |   |   |   |
| 11 PART                                     | EP2S30F672C3                                                                            |   |   |   |   |   |   |   |   |
| 12 POWER_USE_DEVICE_CHARACTERISTICS         | TYPICAL                                                                                 |   |   |   |   |   |   |   |   |
| 13 POWER_AUTO_COMPUTE_TJ                    | ON                                                                                      |   |   |   |   |   |   |   |   |
| 14 POWER_TJ_VALUE                           | 25                                                                                      |   |   |   |   |   |   |   |   |
| 15 POWER_USE_CUSTOM_COOLING_SOLUTION        | OFF                                                                                     |   |   |   |   |   |   |   |   |
| 16 POWER_PRESET_COOLING_SOLUTION            | 23 mm heat sink with 200 LFpM airflow                                                   |   |   |   |   |   |   |   |   |
| 17 POWER_BOARD_THERMAL_MODEL                | None (Conservative)                                                                     |   |   |   |   |   |   |   |   |
| 18 POWER_USE_TA_VALUE                       | 25                                                                                      |   |   |   |   |   |   |   |   |
| 19 POWER_BOARD_TEMPERATURE                  | -1                                                                                      |   |   |   |   |   |   |   |   |
| 20 POWER_OJC_VALUE                          | 0.21                                                                                    |   |   |   |   |   |   |   |   |
| 21 POWER_OCS_VALUE                          | 0.1                                                                                     |   |   |   |   |   |   |   |   |
| 22 POWER_OSA_VALUE                          | 2.8                                                                                     |   |   |   |   |   |   |   |   |
| 23 POWER_OUB_VALUE                          | -1                                                                                      |   |   |   |   |   |   |   |   |
| 24 VCCIO                                    | 1 3.3 2 3.3 3 3.3 4 3.3                                                                 |   |   |   |   |   |   |   |   |
| 25 RAIL_VOLTAGES                            | VCCINT 1.2 VCCPD 3.3                                                                    |   |   |   |   |   |   |   |   |
| 26                                          |                                                                                         |   |   |   |   |   |   |   |   |
| 27                                          |                                                                                         |   |   |   |   |   |   |   |   |
| 28                                          |                                                                                         |   |   |   |   |   |   |   |   |
| 29 BLOCK                                    | I/O count 34 avg_toggle 21588235 avg_toggle 0.423299 avg_fanout                         |   |   |   |   |   |   |   |   |
| 30 BLOCK                                    | I/O count 5 avg_toggle 99600000 avg_toggle 1.952941 avg_fanout                          |   |   |   |   |   |   |   |   |
| 31 BLOCK                                    | I/O count 1 avg_toggle 21000000 avg_toggle 0.411765 avg_fanout                          |   |   |   |   |   |   |   |   |
| 32 BLOCK                                    | I/O count 51 avg_toggle 23117647 avg_toggle 0.453287 avg_fanout                         |   |   |   |   |   |   |   |   |
| 33 BLOCK                                    | I/O count 21 avg_toggle 98000000 avg_toggle 1.921569 avg_fanout                         |   |   |   |   |   |   |   |   |
| 34 BLOCK                                    | DSP block output count 16 avg_toggle 23893557 avg_toggle 0.468601 avg_fanout            |   |   |   |   |   |   |   |   |
| 35 BLOCK                                    | Combinational cell count 6892 avg_toggle 66444042 avg_toggle 1.302824 avg_fanout 1.0293 |   |   |   |   |   |   |   |   |
| 36 BLOCK                                    | Register cell count 2018 avg_toggle 24156448 avg_toggle 0.473666 avg_fanout 6.6204      |   |   |   |   |   |   |   |   |
| 37 BLOCK                                    | Clock control block count 1 avg_toggle 1.02E+08 avg_toggle 2 avg_fanout 20              |   |   |   |   |   |   |   |   |
| 28                                          |                                                                                         |   |   |   |   |   |   |   |   |



The power estimator file is named *<name of Quartus II project>\_early\_pwr.txt* for older device families.

The PowerPlay Early Power Estimator spreadsheet includes the Import Data macro that parses the information in the power estimation file and transfers it into the spreadsheet. If you do not want to use the macro, you can transfer the data into the Early Power Estimator spreadsheet manually.

If the existing Quartus II project represents only a portion of your full design, you should enter the additional resources used in the final design manually. Therefore, you can edit the spreadsheet and add additional device resources after importing the power estimation file information.

## PowerPlay Early Power Estimator File Generator Compilation Report

After successfully generating the power estimation file, a PowerPlay Early Power Estimator File Generator report is created under the **Compilation Report** section. This report is divided into the different sections, such as Summary, Settings, Generated Files, Confidence Metric Details, and Signal Activities.

For more information about the PowerPlay Early Power Estimator File Generator report, refer to “[PowerPlay Power Analyzer Compilation Report](#)” on page 11-39.

**Table 11-1** lists the main differences between the PowerPlay Early Power Estimator and the PowerPlay Power Analyzer.

| <b>Table 11-1. Comparison of PowerPlay Early Power Estimator and PowerPlay Power Analyzer</b> |                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Characteristic</b>                                                                         | <b>PowerPlay Early Power Estimator</b>                                                                                                                                                                                                       | <b>PowerPlay Power Analyzer</b>                                                                                                                                                                                                                                                                                                                                                                                      |
| Phase in the design cycle                                                                     | Any time                                                                                                                                                                                                                                     | After fitting                                                                                                                                                                                                                                                                                                                                                                                                        |
| Tool requirements                                                                             | Spreadsheet program/Quartus II software                                                                                                                                                                                                      | Quartus II software                                                                                                                                                                                                                                                                                                                                                                                                  |
| Accuracy                                                                                      | Medium                                                                                                                                                                                                                                       | Medium to very high                                                                                                                                                                                                                                                                                                                                                                                                  |
| Data inputs                                                                                   | <ul style="list-style-type: none"> <li>● Resource usage estimates</li> <li>● Clock requirements</li> <li>● Environmental conditions</li> <li>● Toggle Rate</li> </ul>                                                                        | <ul style="list-style-type: none"> <li>● Design after fitting</li> <li>● Clock requirements</li> <li>● Register transfer level (RTL) simulation results (optional)</li> <li>● Post-fitting simulation results (optional)</li> <li>● Signal activities per node or entity (optional)</li> <li>● Signal activity defaults</li> <li>● Environmental conditions</li> </ul>                                               |
| Data outputs <sup>(1)</sup>                                                                   | <ul style="list-style-type: none"> <li>● Total thermal power dissipation</li> <li>● Thermal static power</li> <li>● Thermal dynamic power</li> <li>● Off-chip power dissipation</li> <li>● Voltage supply currents <sup>(2)</sup></li> </ul> | <ul style="list-style-type: none"> <li>● Total thermal power</li> <li>● Thermal static power</li> <li>● Thermal dynamic power</li> <li>● Thermal I/O power</li> <li>● Thermal power by design hierarchy</li> <li>● Thermal power by block type</li> <li>● Thermal power dissipation by clock domain</li> <li>● Off-chip (non-thermal) power dissipation</li> <li>● Voltage supply currents <sup>(2)</sup></li> </ul> |

**Notes to Table 11-1:**

- (1) Early Power Estimator output varies by device family as some features may not be available.
- (2) Available only for Arria GX, Stratix IV, Stratix III, Stratix II, Stratix II GX, Cyclone III, Cyclone II, HardCopy II, and MAX II device families.

The results of the Power Analyzer are only an estimation of power, not a specification. The purpose of the estimation is to help establish a guide for the design's power budget. Altera recommends measuring the actual power on the board. You must measure the device's total dynamic current during device operation because the estimate is design dependent and depends on many variable factors, including input vector quantity, quality, and exact loading conditions of a PCB design. Static power consumption must not be based on empirical observation; the values reported by the Power Analyzer or datasheet must be used because the devices tested may not exhibit worst-case behavior.

## Types of Power Analyses

Understanding the uses of power analysis and the factors affecting power consumption help you use the Power Analyzer effectively. Power analysis meets two significant planning requirements:

- **Thermal planning:** The designer must ensure that the cooling solution is sufficient to dissipate the heat generated by the device. In particular, the computed junction temperature must fall within normal device specifications.
- **Power supply planning:** Power supplies must provide adequate current to support device operation.

The two types of analyses are closely related because much of the power supplied to the device is dissipated as heat from the device. However, in some situations, the two types of analyses are not identical. For example, when you use terminated I/O standards, some of the power drawn from the FPGA device power supply is dissipated in termination resistors, rather than in the FPGA.

Power analysis also addresses the activity of the design over time as a factor that impacts the power consumption of the device. Static power is defined as the power consumed regardless of design activity. Dynamic power is the additional power consumed due to signal activity or toggling.



For power supply planning, you can use the PowerPlay Early Power Estimator at the early stages of your design cycle, or use the Quartus II Power Analyzer reports when the design is completed to get an estimate of your design power requirement.

# Factors Affecting Power Consumption

This section describes the factors affecting power consumption. Understanding these factors lets you use the Power Analyzer and interpret its results effectively.

## Device Selection

Different device families have different power characteristics. Many parameters affect the device family power consumption, including choice of process technology, supply voltage, electrical design, and device architecture. For example, the Cyclone II device family architecture was designed to consume less static power than the high-performance, full-featured, Stratix II device family.

Power consumption also varies within a single device family. A larger device typically consumes more static power than a smaller device in the same family, due to its larger transistor count. Dynamic power can also increase with device size in devices that employ global routing architectures, such as the MAX device family. Stratix, Cyclone, and MAX II devices do not exhibit significantly increased dynamic power as device size increases.

The choice of device package also affects the device's ability to dissipate heat. This can impact your cooling solution choice required to meet junction temperature constraints.

Finally, process variation can affect power consumption. Process variation primarily impacts static power, since sub-threshold leakage current varies exponentially with changes in transistor threshold voltage. As a result, it is critical to consult device specifications for static power and not rely on empirical observation. Process variation has a weak effect on dynamic power.

## Environmental Conditions

Operating temperature primarily affects device static power consumption. Higher junction temperatures result in higher static power consumption. The device thermal power and cooling solution that you use must result in the device junction temperature remaining within the maximum operating range for that device.

The main environmental parameters affecting junction temperature are the cooling solution and ambient temperature.

### *Air Flow*

Air flow is a measure of how quickly heated air is removed from the vicinity of the device and replaced by air at ambient temperature. This can either be specified as “still air” when no fan is used, or as the linear feet per minute rating of the fan used in the system. Higher air flow decreases thermal resistance.

### *Heat Sink and Thermal Compound*

A heat sink allows more efficient heat transfer from the device to the surrounding area because of its large surface area exposed to the air. The thermal compound that interfaces the heat sink to the device also influences the rate of heat dissipation. The case-to-ambient thermal resistance ( $\theta_{CA}$ ) parameter describes the cooling capacity of the heat sink and thermal compound employed at a given airflow. Larger heat sinks and more effective thermal compounds reduce  $\theta_{CA}$ .

### *Ambient Temperature*

The junction temperature of a device is equal to:

$$T_{Junction} = T_{Ambient} + P_{Thermal} \cdot \theta_{JA}$$

where  $\theta_{JA}$  is the total thermal resistance from the device transistors to the environment, having units of degrees Celsius per Watt. The value  $\theta_{JA}$  is equal to the sum of the junction-to-case (package) thermal resistance ( $\theta_{JC}$ ) and the case-to-ambient thermal resistance ( $\theta_{CA}$ ) of your cooling solution.

### *Board Thermal Model*

The thermal resistance of the path through the board is referred to as the junction-to-board thermal resistance ( $\theta_{JB}$ ) (the units are in degrees Celsius per Watt). This is used in conjunction with the board temperature, as well as the top-of-chip  $\theta_{JA}$  and ambient temperatures, to compute junction temperature.

## **Design Resources**

The design resource used greatly affects power consumption.

### *Number, Type, and Loading of I/O Pins*

Output pins drive off-chip components, resulting in high-load capacitance that leads to a high-dynamic power per transition. Terminated I/O standards require external resistors that generally draw constant (static) power from the output pin.

### *Number and Type of Logic Elements, Multiplier Elements, and RAM Blocks*

A design with more logic elements (LEs), multiplier elements, and memory blocks tends to consume more power than a design with fewer such circuit elements. Also, the operating mode of each circuit element affects its power consumption. For example, a digital signal processing (DSP) block performing  $18 \times 18$  multiplications and a DSP block performing multiply-accumulate operations consume different amounts of dynamic power due to different amounts of internal capacitance being charged on each transition. Static power is also affected, to a small degree, by the operating mode of a circuit element.

### *Number and Type of Global Signals*

Global signal networks span large portions of the device and have high capacitance, resulting in significant dynamic power consumption. The type of global signal is important as well. For example, Stratix II devices support several kinds of global clock networks that span either the entire device or a specific portion of the device (a regional clock network covers a quarter of the device). Clock networks that span smaller regions have lower capacitance and therefore, tend to consume less power. In addition, the location of the logic array blocks (LABs) that are driven by the clock network can have an impact, because the Quartus II software automatically disables unused branches of a clock.

## **Signal Activities**

The final important factor in estimating power consumption is the behavior of each signal in the design. The two vital statistics are the toggle rate and the static probability.

The toggle rate of a signal is the average number of times that the signal changes value per unit of time. The units for toggle rate are transitions per second, and a transition is a change from 1 to 0, or 0 to 1.

The static probability of a signal is the fraction of time that the signal is logic 1 during the period of device operation that is being analyzed. Static probability ranges from 0 (always at ground) to 1 (always at logic high).

Dynamic power increases linearly with the toggle rate as the capacitive load is charged more frequently for logic and routing. The Quartus II models assume full rail-to-rail switching. For high toggle rates, especially on circuit output I/O pins, the circuit can transition before fully charging the downstream capacitance. The result is a slightly conservative prediction of power by the Quartus II PowerPlay Power Analyzer.

The static power consumed by both routing and logic can sometimes be affected by the static probabilities of their input signals. This effect is due to state-dependent leakage, and has a larger affect on smaller process geometries. The Quartus II software models this effect on devices at 90 nm (or smaller) if it is deemed important to the power estimate. The static power also varies with the static probability of a logic 1 or 0 on the I/O pin when output I/O standards drive termination resistors.



To get accurate results from the power analysis, the signal activities that are used for analysis must be representative of the actual operating behavior of the design. Inaccurate signal toggle rate data is the largest source of power estimation error.

## PowerPlay Power Analyzer Flow

The PowerPlay Power Analyzer supports accurate and representative power estimation by allowing you to specify all the important design factors affecting power consumption. [Figure 11-5](#) shows the high-level Power Analyzer flow.

**Figure 11-5. PowerPlay Power Analyzer High-Level Flow**



**Note to Figure 11-5:**

- (1) Operating condition specifications are available only for the Arria GX devices, Stratix IV, Stratix III, Stratix II, Stratix II GX, Cyclone III, Cyclone II, HardCopy II, and MAX II device families.

The PowerPlay Power Analyzer requires that your design is synthesized and fit to the target device. Therefore, the Power Analyzer knows the target device, and how the design is placed and routed on the device. The electrical standard used by each I/O cell and the capacitive load on each I/O standard must be specified in the design to obtain accurate I/O power estimates.

## Operating Conditions

For the Arria GX, Stratix IV, Stratix III, Stratix II, Stratix II GX, Cyclone III, Cyclone II, HardCopy II, and MAX II device families, you can specify the operating conditions for power analysis in the Quartus II software.

The following settings are available in the **Settings** dialog box:

- **Device power characteristics**—Should the Power Analyzer assume typical silicon or maximum power silicon? The typical setting is useful for comparing to empirical data measured on an average unit. Worst-case data provides a boundary to the worst-case device that you could receive.
- **Selectable Core Voltage**—You can select a suitable core supply voltage for your design based on performance and power requirements using the **Core Supply Voltage** option, available for the Stratix III devices with variable voltage support. The power consumption of a device is heavily dependent on the voltage, so it is very important to choose the right core supply voltage for your design. The core supply voltage provides power to device logic resources such as logic array blocks (LABs), Memory LABs (MLABs), DSP functions, memory, and interconnects.
- **Environmental conditions and junction temperature**—By default, the Power Analyzer automatically computes the junction temperature based on the specified ambient temperature and the cooling solution that you selected. For a more accurate analysis, enter the thermal resistance of your cooling solution. For some cooling solutions, such as a heat sink with no forced airflow, the thermal resistance varies with the amount of thermal power that is dissipated. Air convection increases as the difference between the device temperature and the ambient temperature increases, reducing thermal resistance. When entering a thermal resistance in such cases, it is important to use the thermal resistance that occurs when the heat flow ( $Q$ ) is equal to the thermal power generated by the device. You can also specify a junction temperature in the PowerPlay Power Analyzer. However, Altera does not recommend this because the PowerPlay Power Analyzer provides more accurate results by computing the junction temperature.

- **Board Thermal Modeling**—If you want the Power Analyzer thermal model to take the  $\theta_{JB}$  into consideration, set the board thermal model to either **Typical** or **Custom**. This feature produces more accurate thermal power estimation.

A **Typical** board thermal model automatically sets  $\theta_{JB}$  to a value based on the package and device selected. You only need to specify a board temperature. If you choose a **Custom** board thermal model, you must specify a value for  $\theta_{JB}$  and a board temperature. If you do not want the PowerPlay Power Analyzer thermal model to take the  $\theta_{JB}$  resistance into consideration, set the **Board thermal model** option to **None** (conservative). In this case, the path through the board and power dissipation is not considered, and a more conservative thermal power estimate is obtained.

The **Board thermal model** option is only available if you select the **Auto compute junction temperature** option with the pre-set cooling solution set to a heat sink solution option or custom solution. This option is disabled when a cooling solution with no heat sink is selected, as thermal conduction through the board is included in the  $\theta_{JA}$  value used to compute a junction temperature in that case.

## Signal Activities Data Sources

The Power Analyzer provides a flexible framework for specifying signal activities. This reflects the importance of using representative signal activity data during power analysis. You can use the following sources to provide information about signal activity:

- Simulation results
- User-entered node, entity, and clock assignments
- User-entered default toggle rate assignment
- Vectorless estimation

The PowerPlay Power Analyzer lets you mix and match the signal activity data sources on a signal-by-signal basis. [Figure 11–6](#) shows the priority scheme. The data sources are described in the following sections.

**Figure 11–6. Signal Activity Data Source Priority Scheme****Note to Figure 11–6:**

- (1) Vectorless estimation is available only for the Arria GX, Stratix IV, Stratix III, Stratix II, Stratix II GX, Cyclone II, HardCopy II, and MAX II device families.

*Simulation Results*

The Power Analyzer directly reads the waveforms generated by a design simulation. The static probability and toggle rate for each signal is calculated from the simulation waveform. Power analysis is most accurate when simulations are generated using representative input stimuli.

The Power Analyzer reads the results generated by the following simulators:

- Quartus II Simulator
- ModelSim® VHDL, Active HDL, ModelSim Verilog HDL, ModelSim-Altera VHDL, ModelSim-Altera Verilog
- NC-Verilog, NC-VHDL
- VCS

Signal activity and static probability information are stored in a Signal Activity File (.saf) or may be derived from a Value Change Dump File (.vcd), described in “[Signal Activities](#)” on page 11–9. The Quartus II simulator generates an .saf file or a .vcd file, which is then read by the Power Analyzer.

For third-party simulators, use the **Quartus II EDA Tool Settings for Simulation** to specify a **Generate Value Change Dump** file script. These scripts instruct the third-party simulators to generate a **.vcd** file that encodes the simulated waveforms. The Quartus II Power Analyzer reads this file directly to derive the toggle rate and static probability data for each signal.

Third-party EDA simulators, other than those listed above, can generate a **.vcd** file that can then be used with the Power Analyzer. For those simulators, it is necessary to manually create a simulation script to generate the appropriate **.vcd** file.



You can use a **.saf** or **.vcd** file created for power analysis to optimize the design for power during fitting by utilizing the appropriate settings in the **PowerPlay power optimization** list, available in **Fitter Settings** page of the **Settings** dialog box.



For more information about power optimization, refer to the *Power Optimization* chapter in volume 2 of the *Quartus II Handbook*.

## Using Simulation Files in Modular Design Flows

A common design practice is to create modular or hierarchical designs in which you develop each design entity separately and then instantiate it in a higher-level entity, forming a complete design. Simulation is performed on a complete design or on each modular design for verification. The Quartus II PowerPlay Power Analyzer Tool supports modular design flows when reading the signal activities generated from these simulation files, as shown in [Figure 11-7](#).

**Figure 11-7. Modular Simulation Flow**



When specifying a simulation file, an associated design entity name may be given, such that the signal activities derived from the simulation file (**.vcd** or **.saf** file) can be imported into the Power Analyzer for that

particular design entity. The PowerPlay Power Analyzer Tool also supports the specification of multiple **.saf** files for power analysis with each having an associated design entity name to allow the integration of partial design simulations into a complete design power analysis. When specifying multiple **.saf** files for your design, it is possible that more than one simulation file will contain signal activity information for the same signal. In the case where multiple **.saf** files are applied to the same design entity, the signal activity used in the power analysis is the equal-weight arithmetic average of each **.saf** file. Also in the case where multiple simulation files are applied to design entities at different levels in the design hierarchy, the signal activity used in the power analysis is derived from the simulation file that is applied to the most specific design entity.

**Figure 11–8** shows an example of a hierarchical design. The design **Top** consists of three 8b/10b Decoders, followed by a multiplexer whose output is then encoded again before being output from the design. There is also an error-handling module that handles any 8b/10b decoding errors. The top-level module, called **Top**, automatically contains the design's top-level entity and any logic not defined as part of another module. The design file for the top-level module may be just a wrapper for the hierarchical entities below it, or it may contain its own logic. The following usage scenarios show common ways that you may simulate your design and import **.saf** files into the PowerPlay Power Analyzer Tool.

**Figure 11–8. Example Hierarchical Design**



## Complete Design Simulation

You can simulate the entire design **Top**, generating a **.vcd** file if you use a third-party simulator, or generating a **.saf** or **.vcd** file if you use the Quartus II Simulator. The **.vcd** or **.saf** file can then be imported (specifying Entity **Top**) into the Power Analyzer. The resulting power

analysis uses all the signal activities information from the generated .vcd or .saf file, including those that apply to submodules, such as decode[1-3], err1, mux1, and encode1.

## Modular Design Simulation

You can simulate submodules of the design Top independently, and then import all of the resulting .saf files into the Power Analyzer. For example, you may simulate the 8b10b\_dec independent of the entire design, as well as multiplexer, 8b10b\_rxerr, and 8b10b\_enc. You can then import the .vcd or .saf file generated from each simulation by specifying the appropriate instance name. For example, if the files produced by the simulations are 8b10b\_dec.vcd, 8b10b\_enc.vcd, 8b10b\_rxerr.vcd, and mux.saf, the import specifications in [Table 11-2](#) are used.

**Table 11-2. Import Specifications**

| File Name              | Entity                    |
|------------------------|---------------------------|
| <b>8b10b_dec.vcd</b>   | Top   8b10b_dec : decode1 |
| <b>8b10b_dec.vcd</b>   | Top   8b10b_dec : decode2 |
| <b>8b10b_dec.vcd</b>   | Top   8b10b_dec : decode3 |
| <b>8b10b_rxerr.vcd</b> | Top   8b10b_rxerr : err1  |
| <b>8b10b_enc.vcd</b>   | Top   8b10b_enc : encode1 |
| <b>mux.saf</b>         | Top   mux : mux1          |

The resulting power analysis applies the simulation vectors found in each file to the assigned entity. Simulation provides signal activities for the pins and for the outputs of functional blocks. If the inputs to an entity instance are input pins for the entire design, the simulation file associated with that instance does not provide signal activities for the inputs of that instance. For example, an input to an entity such as mux1 has its signal activity specified at the output of one of the decode entities.

## Multiple Simulations on the Same Entity

You can perform multiple simulations of an entire design or specific modules of a design. For example, in the process of verifying the “Top” design, you may have three different simulation testbenches: one for

normal operation, and two for corner cases. Each of these simulations produces a separate .vcd or .saf file. In this case, apply the different .vcd or .saf file names to the same top-level entity, shown in [Table 11–3](#).

**Table 11–3. Multiple Simulation File Names and Entities**

| File Name          | Entity |
|--------------------|--------|
| <b>normal.saf</b>  | Top    |
| <b>corner1.vcd</b> | Top    |
| <b>corner2.vcd</b> | Top    |

The resulting power analysis uses an arithmetic average of the signal activities calculated from each simulation file to obtain the final signal activities used. Thus, if a signal `err_out` has a toggle rate of 0 toggles per second in **normal.saf**, 50 toggles per second in **corner1.vcd**, and 70 toggles per second in **corner2.vcd**, the final toggle rate that is used in the power analysis is 40 toggles per second.

## Overlapping Simulations

You can perform a simulation on the entire design Top and more exhaustive simulations on a sub-module, such as `8b10b_rxerr`. [Table 11–4](#) shows the import specification for overlapping simulations.

**Table 11–4. Overlapping Simulation Import Specifications**

| File Name              | Entity                 |
|------------------------|------------------------|
| <b>full_design.vcd</b> | Top                    |
| <b>error_cases.vcd</b> | Top   8b10b_rxerr:err1 |

In this case, signal activities from **error\_cases.vcd** are used for all of the nodes in the generated .saf file, and signal activities from **full\_design.vcd** are used for only those nodes that do not overlap with nodes in **error\_cases.vcd**. In general, the more specific hierarchy (the most bottom-level module) is used to derive signal activities for overlapping nodes.

## Partial Simulations

You can perform a simulation where the entire simulation time is not applicable to signal activity calculation. For example, if you run a simulation for 10,000 clock cycles and reset the chip for the first 2,000 clock cycles. If the signal activity calculation is performed over all 10,000

cycles, the toggle rates are typically only 80% of their steady state value (since the chip is in reset for the first 20% of the simulation). In this case, you should specify the useful parts of the **.vcd** file for power analysis. The **Limit VCD Period** option enables you to specify a start and end time to be used when performing signal activity calculations.

## Node Name Matching Considerations

Node name mismatches happen when you have **.saf** or **.vcd** files applied to entities other than the top-level entity. In a modular design flow, the gate-level simulation files created in different Quartus II software projects may not match their node names with the current Quartus II project.

For example, if you have a file named **8b10b\_enc.vcd**, which was generated in a separate project called **8b10b\_enc** and is simulating the **8b10b** encoder, and you import that **.vcd** file into another project called **Top**, you may encounter name mismatches when applying the **.vcd** file to the **8b10b\_enc** module in the **Top** project. This is because all of the combinational nodes in the **8b10b\_enc.vcd** file may be named differently in the **Top** project.

You can avoid name mismatching by using only register transfer level (RTL) simulation data, where register names usually do not change, or by using an incremental compile flow that preserves node names in conjunction with a gate-level simulation.

 To ensure the best accuracy, Altera recommends using an incremental compile flow to preserve your design's node names.

 For more information about the incremental compile flow, refer to the *Quartus II Incremental Compilation for Hierarchical and Team-Based Design* chapter in volume 1 of the *Quartus II Handbook*.

## Glitch Filtering

The Power Analyzer defines a glitch as two signal transitions that are so closely spaced in time that the pulse, or glitch, occurs faster than the logic and routing circuitry can respond. The output of a transport delay model simulator (the default mode of the Quartus II simulator) generally contains glitches for some signals. The device's logic and routing structures form a low-pass filter that filters out glitches that are tens to hundreds of picoseconds long, depending on the device family.

Some third-party simulators use different models than the transport delay model as default. Different models cause differences in signal activity and power estimation. The inertial delay model, which is the ModelSim default model, filters out many more glitches than the transport delay model; therefore, it usually yields a lower power estimate.



Altera recommends using the transport simulation model when using the Quartus II glitch filtering support with third-party simulators. If the inertial simulation model is used, simulation glitch filtering has little effect.



For more information about how to set the simulation model type for your specific simulator, refer to the Quartus II Help.

Glitch filtering in a simulator can also filter a glitch on one LE (or other circuit element) output from propagating to downstream circuit elements so that the glitch will not affect simulated results. This prevents a glitch on one signal from producing non-physical glitches on all downstream logic, which would result in a signal toggle rate that is too high and a power estimate that is too high. Circuit elements in which every input transition produces an output transition, including multipliers and logic cells configured to implement XOR functions, are especially prone to glitches. Therefore, circuits with many such functions can have power estimates that are too high when glitch filtering is not used.

Altera recommends that the glitch filtering feature be used to obtain the most accurate power estimates. For **.vcd** files, the Power Analyzer flows support two types of glitch filtering, both of which are recommended for power estimation. In the first, glitches are filtered during simulation. To enable this level of glitch filtering in the Quartus II software for supported third-party simulators, perform the following steps:

1. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
2. In the **Category** list, select **Simulation**. The **Simulation** page appears.
3. Select the **Tool Name** to use for the simulation.
4. Turn on the **Enable glitch filtering** option.

To enable this level of glitch filtering in the Quartus II software using the Quartus II Simulator, refer to “[Generating a SAF or VCD File Using the Quartus II Simulator](#)” on page 11–23.

The second level of glitch filtering occurs while the Power Analyzer is reading the **.vcd** file generated by the third-party simulator or Quartus II Simulator. Enable this level of glitch filtering by performing the following steps:

1. On the Assignments menu, click **Settings**. The **Settings** dialog box appears.
2. In the **Category** list, select **PowerPlay Power Analyzer Settings**. The **PowerPlay Power Analyzer Settings** page appears.
3. Under **Input File(s)**, turn on the **Perform glitch filtering on VCD files** option.

Altera recommends that you use both forms of glitch filtering.

The **.vcd** file reader performs complementary filtering to the filtering performed during simulation and is often not as effective. While the **.vcd** file reader can remove glitches on logic blocks, it has no way of determining how downstream logic and routing are affected by a given glitch, and may not eliminate the impact of the glitch completely. Filtering the glitches during simulation avoids switching downstream routing and logic automatically.



When running simulation for design verification (rather than to produce input to the Quartus PowerPlay Power Analyzer), Altera recommends leaving glitch filtering turned off. This produces the most rigorous and conservative simulation from a functionality viewpoint. When performing simulation to produce input for the Quartus II PowerPlay Power Analyzer, Altera recommends turning on glitch filtering to produce the most accurate power estimates.

## Node and Entity Assignments

You can assign specific toggle rates and static probabilities to individual nodes and entities in the design. These assignments have the highest priority, overriding data from all other signal activity sources.

Use the Assignment Editor or tool command language (Tcl) commands to make the **Power Toggle Rate** and **Power Static Probability** assignments. You can specify the power toggle rate as an absolute toggle rate in transitions using the **Power Toggle Rate** assignment or you can use the **Power Toggle Rate Percentage** assignment to specify a toggle rate relative to the clock domain of the assigned node for more specific assignment made in terms of hierarchy level.



If the **Power Toggle Rate Percentage** assignment is used, and the given node does not have a clock domain, a warning is issued and the assignment is ignored.



For more information about how to use the Assignment Editor in the Quartus II software, refer to the *Assignment Editor* chapter in volume 2 of the *Quartus II Handbook*.

This method is appropriate for special-case signals where you have specific knowledge of the signal or entity being analyzed. For example, if you know that a 100-MHz data bus or memory output produces data that is essentially random (uncorrelated in time), you can directly enter a 0.5 static probability and a toggle rate of 50 million transitions per second.

Bidirectional I/O pins are treated specially. The combinational input port and the output pad for a given pin share the same name. However, those ports might not share the same signal activities. For the purpose of reading signal activity assignments, the Power Analyzer creates a distinct name `<node_name~output>` when the bidirectional signal is configured as an output and `<node_name~result>` when the signal is configured as an input. For example, if a design has a bidirectional pin named MYPIN, assignments for the combinational input use the name MYPIN~result, and the assignments for the output pad use the name MYPIN~output.



When making the logic assignment in the Assignment Editor, you will not find the MYPIN~result and MYPIN~output node names in the Node Finder. Therefore, to make the logic assignment, you must manually enter the two differentiating node names to make the specific assignment for the input and output port of the bidirectional pin.

### *Timing Assignments to Clock Nodes*

For clock nodes, the Power Analyzer uses the timing requirements to derive the toggle rate when neither simulation data nor user entered signal activity data is available.



$f_{MAX}$  requirements specify full cycles per second, but each cycle represents a rising transition and a falling transition. For example, a clock  $f_{MAX}$  requirement of 100 MHz corresponds to 200 million transitions per second.

## Default Toggle Rate Assignment

You can specify a default toggle rate for primary inputs and all other nodes in the design. The default toggle rate is used when no other method has specified the signal activity data.

The toggle rate can be specified in absolute terms (transitions per second) or as a fraction of the clock rate in effect for each particular node. The toggle rate for a given clock is derived from the timing settings for the clock. For example, if a clock is specified with an  $f_{MAX}$  constraint of 100 MHz and a default relative toggle rate of 20%, nodes in this clock domain transition in 20% of the clock periods, or 20 million transitions occur per second. In some cases, the Power Analyzer cannot determine the clock domain for a given node because there is either no clock domain for the node or it is ambiguous. In these cases, the Power Analyzer substitutes and reports a toggle rate of zero.

## Vectorless Estimation

For some device families, the Power Analyzer automatically derives estimates for signal activity on nodes with no simulation or user-entered signal-activity data. Vectorless estimation is available and enabled by default for Arria GX, Stratix IV, Stratix III, Stratix II, Stratix II GX, Cyclone III, Cyclone II, HardCopy II, and MAX II device families.

Vectorless estimation statistically estimates the signal activity of a node based on the signal activities of all nodes feeding that node, and on the actual logic function implemented by the node. The PowerPlay Power Analyzer **Settings** dialog box lets you disable vectorless estimation.

When enabled, vectorless estimation takes priority over default toggle rates. Vectorless estimation does not override clock assignments.



Vectorless estimation cannot derive signal activities for primary inputs. Vectorless estimation is generally accurate for combinational nodes, but not for registered nodes. Therefore, simulation data for at least the registered nodes and I/O nodes is needed for accuracy.

## Using the PowerPlay Power Analyzer

For all flows that use the PowerPlay Power Analyzer, synthesize your design first and then fit it to the target device. You must either provide timing assignments for all clocks in the design or use a simulation-based flow to generate activity data. The I/O standard used on each device input or output and the capacitive load on each output must be specified in the design.

## Common Analysis Flows

You can use the analysis flows in this section with the PowerPlay Power Analyzer. However, vectorless activity estimation is only available for some device families.

### *Signal Activities from Full Post-Fit Netlist (Timing) Simulation*

This flow provides the highest accuracy because all node activities reflect actual design behavior, provided that supplied input vectors are representative of typical design operation. Results are better if the simulation filters glitches. The disadvantage with this method is that simulation times can be long.

### *Signal Activities from RTL (Functional) Simulation, Supplemented by Vectorless Estimation*

In this flow, simulation provides toggle rates and static probabilities for all pins and registers in the design. Vectorless estimation fills in the values for all the combinational nodes between pins and registers. This method yields good results, since vectorless estimation is accurate, given that the proper pin and register data is provided. This flow usually provides a compilation time benefit to the user in the third-party RTL simulator.



RTL simulation may not provide signal activities for all registers in the post-fitting netlist because some register names may be lost during synthesis. For example, synthesis may automatically transform state machines and counters, thus changing the names of registers in those structures.

### *Signal Activities from Vectorless Estimation, User-Supplied Input Pin Activities*

This option provides a low level of accuracy, because vectorless estimation for registers is not entirely accurate.

### *Signal Activities from User Defaults Only*

This option provides the lowest degree of accuracy.

## **Generating a SAF or VCD File Using the Quartus II Simulator**

While performing a timing or functional simulation using the Quartus II Simulator, you can generate a **.saf** or **.vcd** file. These files store the toggle rate and static probability for each connected output signal based on the

simulation vectors that are entered in the Vector Waveform File (.vWF) or the Vector File (.vec). You can use the .saf file(s) or .vcd file(s) as input to the PowerPlay Power Analyzer to estimate power for your design.



For more accurate results, Altera recommends that you use the .saf file created from the Quartus II simulator as the input to the PowerPlay Power Analyzer.

To create a .saf or .vcd file for your design, perform the following steps:

1. On the Assignments menu, click **Settings**. The **Settings** dialog box appears.
2. In the **Category** list, select **Simulator Settings**. The **Simulator Settings** page appears (Figure 11–9).

**Figure 11–9. Simulator Settings Page**



3. In the **Simulation mode** list, select either **Timing** or **Functional**. Refer to “[Common Analysis Flows](#)” on page 11–23 for a description of the difference in accuracy between the two types of simulation modes.
4. (Optional) Click **More Settings**. The **More Simulator Settings** dialog box appears.
5. (Optional) Turn on glitch filtering. To turn on glitch filtering, in the **Glitch filtering options** list, select **Always**.
6. In the **Category** list, click the  icon to expand **Simulator Settings** and select **Simulation Output Files** ([Figure 11–10](#)).

**Figure 11–10. Simulator Output Files Page of the Settings Dialog Box**



7. Turn on **Generate Signal Activity File** and enter the file name for the **.saf** file.



For more information about the Quartus II Simulator and how to create a **.saf** file, refer to the *Quartus II Simulator* chapter in volume 3 of the *Quartus II Handbook*.



When generating a **.vcd** file from the Quartus Simulator, you must make sure that you add **all nodes** to the input vector wave file. Only the nodes that have been added to your vector file are output to the Quartus-generated **.vcd** file. This is not the case when generating a **.saf** file. The Quartus II Simulator creates a **.saf** file, including all the internal nodes of your design, even if the stimuli file contains only the input vectors for your simulation.

8. (Optional) Click **Signal Activity File Options**. The **Signal Activity File Options** dialog box appears (Figure 11–11).

**Figure 11–11. Signal Activity File Options Dialog Box**



9. (Optional) Turn on the **Limit signal activity period** option to specify the simulation period to use when calculating the signal activities.

Power estimation can be performed for the entire simulation time or for a portion of the simulation time. This allows you to look at the power consumption at different points in your overall simulation without having to rework your testbenches. This feature is also useful when multiple clock cycles are necessary to initialize the state of the design, but you want to measure the signal activity only during the normal operation of the design, not during its initialization phase. You can specify the start time and end time in the **Signal Activity File Options** dialog box by turning on the **Limit signal activity period** option. Simulation information is used during

this time interval only to calculate toggle rates and static probabilities. If no time interval is specified, the whole simulation is used to compute signal activity data.

10. After the simulation is complete, a **.saf** file is generated with the specified filename and stored in the main project directory.



For more information about how to perform simulations in the Quartus II software, see the Quartus II Help.

## Generating a VCD File Using a Third-Party Simulator

You can use other EDA simulation tools, such as the Model Technology<sup>TM</sup> ModelSim<sup>®</sup> software, to perform a simulation and create a **.vcd** file. You can use this file as input to the PowerPlay Power Analyzer to estimate power for your design. To do this, you must tell the Quartus II software to generate a script file that is used as input to the third-party simulator. This script tells the third-party simulator to generate a **.vcd** file that contains all the output signals. For more information about the supported third-party simulators, refer to ["Simulation Results" on page 11-13](#).

To create a **.vcd** file for your design, perform the following steps:

1. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
2. In the **Category** list, select **Simulation**. The **Simulation** page appears, as shown in [Figure 11-12](#).

Figure 11–12. Simulation Page of the Settings Dialog Box



3. In the **Tool name** list, select the appropriate EDA simulation tool.

4. In the **Format for output netlist** list, select **VHDL** or **Verilog**.

5. Turn on **Generate Value Change Dump (VCD) file script**.



This turns on the **Map illegal HDL character** and **Enable glitch filtering** options.

6. (Optional) **Map illegal HDL characters** ensures that all signals have legal names and that signal toggle rates are available later in the PowerPlay Power Analyzer.

7. (Optional) By turning on **Enable glitch filtering**, glitch filtering logic is the output when you generate an EDA netlist for simulation. This option is always available, regardless of whether or not you want to generate the **.vcd** file scripts. For more information about glitch filtering, refer to “[Glitch Filtering](#)” on page 11–18.



When performing simulation using ModelSim, the `+nospecify` option given to the `vsim` command disables **specify** path delays and timing checks in ModelSim. By enabling glitch filtering on the **Simulation** page, the simulation models include **specify** path delays. Thus, ModelSim can fail to simulate a design if glitch filtering is enabled, and the `+nospecify` option is specified. Altera recommends the removal of the `+nospecify` option from the ModelSim `vsim` command to ensure accurate simulation for power estimation.

8. Click **Script Settings**. The **Script Settings** dialog box appears, shown in [Figure 11–13](#).

**Figure 11–13. Script Settings Dialog Box**



Select which signals should be output to the `.vcd` file. With **All signals** selected, the generated script instructs the third-party simulator to write all connected output signals to the `.vcd` file. With **All signals except combinational lcell outputs** selected, the generated script tells the third-party simulator to write all connected output signals to the `.vcd` file, except logic cell combinational outputs.



You may not want to write all output signals to the file because the file can become extremely large (since its size depends on the number of output signals being monitored and the number of transitions that occur).

9. Click **OK**.
10. Type a name for your testbench in the **Design instance name** box.
11. Compile your design with the Quartus II software and generate the necessary EDA netlist and script that tells the third-party simulator to generate a `.vcd` file.



For more information about NativeLink use, refer to *Section I. Simulation* in volume 3 of the *Quartus II Handbook*.

12. Perform a simulation with the third-party EDA simulation tool. Call the generated script in the simulation tool before running the simulation. The simulation tool generates the **.vcd** file and places it in the project directory.

### *Generating a VCD File from ModelSim Software*

The following example provides step-by-step instructions to successfully produce a **.vcd** file with the ModelSim software:

1. In the Quartus II software, on the Assignments menu, click **Settings**.
2. In the **Settings** dialog box, on the **Simulator Settings** page, choose the appropriate ModelSim selection in the **Tool Name** list, and turn on the **Generate Value Change Dump File Script** option.
3. To generate the **.vcd** file, perform a full compilation.
4. In the ModelSim software, compile the files necessary for simulation.
5. Load your design by clicking **Start Simulation** on the Tools menu, or use the **vsim** command.
6. Source the Quartus II **.vcd** script created in step 3 using the following command:  
`source <design>_dump_all_vcd_nodes.tcl`
7. Run the simulation (for example, **run 2000ns** or **run -all**).
8. Quit the simulation using the **quit -sim** command, if needed.
9. Exit the ModelSim software. If you do not exit the software, the ModelSim software may end the writing process of the **.vcd** files improperly, resulting in a corrupted **.vcd** file.



For more information about how to create a **.vcd** file in other third-party EDA simulation tools, refer to *Section I. Simulation*, in volume 3 of the *Quartus II Handbook*.

## **Running the PowerPlay Power Analyzer Using the Quartus II GUI**

To run the PowerPlay Power Analyzer using the Quartus II GUI, perform the following steps:

1. On the Assignments menu, click **Settings**. The **Settings** dialog box appears.
2. In the **Category** list, select **PowerPlay Power Analyzer Settings**, shown in [Figure 11-14](#).

**Figure 11-14. PowerPlay Power Analyzer Settings**



3. (Optional) If you want to use either .saf file(s) or .vcd file(s) or both as an input to the PowerPlay Power Analyzer, turn on **Use input file(s) to initialize toggle rates and static probabilities during power analysis**.  
(Optional) The **Edit** button allows you to change the settings for a selected file from the list. The **Remove** button allows you to remove a selected file from the list.
4. Click **Add**. The **Add Power Input File** dialog box appears, as shown in [Figure 11-15](#).

---

**Figure 11–15. Add Power Input File Dialog Box**



- 
5. Add your **.saf** file(s) or **.vcd** file(s) by clicking the browse button for the **File name** field.
  6. The **Entity** field enables you to specify the design entity (hierarchy) to which the entered power input file applies. To enter the entity, you can type in the box or browse through the list of your design entities. To browse your design entities, click the browse button. The **Select Hierarchy** dialog box appears, shown in [Figure 11–16](#). You can specify multiple entities in the entity text box by using comma delimiters.

---

Figure 11–16. Select Hierarchy Dialog Box



- 
7. You can specify whether the input file is a **.vcd** or **.saf** file under **Input File Type**.
  8. (Optional) **Limit VCD period** is enabled only when the **VCD file** is selected. This enables you to specify the simulation period to use when calculating the signal activities. For more information, refer to step 9 of “[Generating a SAF or VCD File Using the Quartus II Simulator](#)” on page 11–23.
  9. Click **OK**.
  10. Click **OK** in the **Add Power Input File** dialog box.
  11. (Optional) Turn on **Perform glitch filtering on VCD files**. This option is recommended. For more information, refer to “[Glitch Filtering](#)” on page 11–18.
  12. (Optional) Turn on **Write out signal activities used during power analysis**. In the **Output file name** list, select the output file name. This file contains all the signal activities information used during the power estimation of your design. This is recommended if you

used a **.vcd** file as input into the PowerPlay Power Analyzer, because it reduces the run time of any subsequent power estimation. You can use the generated **.saf** file as input instead of the original **.vcd** file.

13. (Optional) Turn on **Write signal activities to report file**.
14. (Optional) Turn on **Write power dissipation by block to report file** to enable the output of detailed thermal power dissipation by block to be included in the PowerPlay Power Analyzer report.
15. (Optional) You can also use the Assignment Editor to enter the Power Toggle Rate or Power Toggle Rate Percentage, and the Power Static Probability for a node or entity in your design, shown in [Figure 11-17](#).

**Figure 11-17. Assignment Editor Notes (1), (2)**



**Notes to Figure 11-17:**

- (1) The assignments made with the Assignment Editor override the values already existing in the **.saf** file or **.vcd** file.
- (2) You can also use Tcl script commands to make these assignments.



For more information about how to use the Assignment Editor in the Quartus II software, see the [Assignment Editor](#) chapter in volume 2 of the *Quartus II Handbook*. For information about scripting, see the [Tcl Scripting](#) chapter in volume 2 of the *Quartus II Handbook*.

16. Specify the toggle rate in the **Default toggle rate used for input I/O signals** field. This toggle rate is used for all unspecified input I/O signal toggle rates regardless of whether or not the device family supports vectorless estimation. By default, its value is set to 12.5%. The default static probability for unspecified input I/O signals is 0.5 and cannot be changed.
17. Select either **Use default value** or **Use vectorless estimation** for Arria GX, Stratix IV, Stratix III, Stratix II, Stratix II GX, Cyclone III, Cyclone II, HardCopy II, or MAX II device families. For all other device families, only **Use default value** is available. This setting controls how the remainder of the unspecified signal activities are calculated. For more information, refer to “[Vectorless Estimation](#)” on page 11–22 and “[Default Toggle Rate Assignment](#)” on page 11–22.
18. In the **Category** list, select **Operating Settings and Conditions**. This option is available only for the Arria GX, Stratix IV, Stratix III, Stratix II, Stratix II GX, Cyclone III, Cyclone II, HardCopy II, and MAX II device families ([Figure 11–18](#)).

**Figure 11–18. Operating Conditions**



19. In the **Device power characteristics** list, select **Typical** or **Maximum**. The default is **Typical**.
20. In the **Category** list, click the  icon to expand **Operating Settings and Conditions** and click **Voltage**. The **Voltage** page appears.
21. For the devices with selectable core voltage support, in the **Core supply voltage** list, select the core supply voltage for your device. This option is available for the latest devices with variable voltage selection.
22. In the **Category** list, under **Operating Settings and Conditions**, select **Temperature**. The **Temperature** page appears (Figure 11-19).

**Figure 11-19. Temperature Settings Page**



23. Under **Junction temperature range**, specify a junction temperature in degrees Celsius and specify the junction temperature range. Select the **Low temperature** and **High temperature** range for your selected device.
24. Specify the junction temperature and cooling solution settings. You can select **Specify junction temperature** or **Auto compute junction temperature using cooling solution**.
25. (Optional) Under **Board thermal modeling**, select the **Board thermal model** and type the **Board temperature**. This feature can only be turned on when you have selected **Auto compute junction temperature using cooling solution**.

For more information about how to use the operating condition settings, refer to “[Operating Conditions](#)” on page 11-11.

26. Click **OK** to close the **Settings** dialog box.
27. On the Processing menu, click **PowerPlay Power Analyzer Tool**. The **PowerPlay Power Analyzer Tool** dialog box appears (Figure 11-20).

**Figure 11-20. PowerPlay Power Analyzer Tool Dialog Box**



- Click **Start** to run the PowerPlay Power Analyzer. Be sure that all the settings are correct.



You can also make changes to some of your settings in this dialog box. For example, you can click the **Add Power Input File(s)** button to make changes to your input file(s).

- After the PowerPlay Power Analyzer runs successfully, a message appears (Figure 11–21).

**Figure 11–21. PowerPlay Power Analyzer Message**



- Click **OK**.
- In the **PowerPlay Power Analyzer Tool** dialog box, click **Report** to open the PowerPlay Power Analyzer Summary window. You can also view the summary in the **PowerPlay Power Analyzer Summary** page of the **Compilation Report** (Figure 11–22).

**Figure 11–22. PowerPlay Power Analyzer Summary**



## PowerPlay Power Analyzer Compilation Report

The PowerPlay Power Analyzer section of the Compilation Report is divided into the following sections.

### *Summary*

This section of the report shows your design's estimated total thermal power consumption. This includes dynamic, static, and I/O thermal power consumption. The I/O thermal power consumption is the total I/O power contributed by both the  $V_{CCIO}$  power supplies and some portion of the  $V_{CCINT}$ . The report also includes a confidence metric that reflects the overall quality of the data sources for the signal activities. For example, a **Low** power estimation confidence value reflects that the user has provided insufficient toggle rate data, or most of the signal activity information used for power estimation is from default or vectorless estimation settings (see the PowerPlay Power Analyzer Confidence Metric report for details of the input data).

### *Settings*

This section of the report shows your design's PowerPlay Power Analyzer settings information. This includes default input toggle rates, operating conditions, and other relevant setting information.

### *Simulation Files Read*

This section of the report lists simulation output files (.vcd or .saf file) used for power estimation.

### *Operating Conditions Used*

This section of the report shows device characteristics, voltages, temperature, and cooling solution, if any, that were used during the power estimation. It also shows the entered junction temperature or auto-computed junction temperature that was used during the power analysis. This page is created only for Arria GX, Stratix IV, Stratix III, Stratix II, Stratix II GX, Cyclone III, Cyclone II, HardCopy II, and MAX II device families.

### *Thermal Power Dissipated by Block*

This section of the report shows estimated thermal dynamic power and thermal static power consumption categorized by atoms. This information provides designers with an estimated power consumption for each atom in their design.

### *Thermal Power Dissipation by Block Type (Device Resource Type)*

This section of the report shows the estimated thermal dynamic power and thermal static power consumption categorized by block types. This information is further categorized by estimated dynamic and static power that was used, as well as providing an average toggle rate by block type. Thermal power is the power dissipated as heat from the FPGA device.

### *Thermal Power Dissipation by Hierarchy*

This section of the report shows an estimated thermal dynamic power and thermal static power consumption categorized by design hierarchy. This is further categorized by the dynamic and static power that was used by the blocks and routing within that hierarchy. This information is very useful in locating problem modules in your design.

### *Core Dynamic Thermal Power Dissipation by Clock Domain*

This section of the report shows the estimated total core dynamic power dissipation by each clock domain. This provides designs with estimated power consumption for each clock domain in their design. If the clock frequency for a domain is unspecified by a constraint, the clock frequency is listed as "unspecified." For all the combinational logic, the clock domain is listed as no clock with 0 MHz.

### *Current Drawn from Voltage Supplies*

This section of the report lists the current that was drawn from each voltage supply. The V<sub>CCIO</sub> voltage supply is further categorized by I/O bank and by voltage. The minimum safe power supply size (current supply ability) is also listed for each supply voltage. This page is created only for Arria GX, Stratix IV, Stratix III, Stratix II, Stratix II GX, Cyclone III, Cyclone II, HardCopy II, and MAX II device families.

The I/O thermal power dissipation which is listed on the summary page does not correlate directly to the power drawn from the V<sub>CCIO</sub> voltage supply listed in this report. This is because the I/O thermal power dissipation value also includes portions of the V<sub>CCINT</sub> power, such as the IOE registers which are modeled as I/O power, but do not draw from the V<sub>CCIO</sub> supply.

### *Confidence Metric Details*

The confidence metric indicates the quality of the signal toggle rate data used to compute a power estimate. The confidence metric is low if the signal toggle rate data comes from sources that are considered poor

predictors of real signal toggle rates in the device during an operation. Toggle rate data that comes from simulation, user-entered assignments on specific signals, or entities are considered reliable. Toggle rate data from default toggle rates (for example, 12.5% of the clock period) or vectorless estimation are considered relatively inaccurate. This section gives an overall confidence rating in the toggle rate data, from low to high. It also summarizes how many pins, registers, and combinational nodes obtained their toggle rates from each of simulation, user entry, vectorless estimation, or default toggle rate estimations. This detailed information can help you understand how to increase the confidence metric, letting you decide on your own confidence in the toggle rate data.

### *Signal Activities*

This section lists toggle rate and static probabilities assumed by power analysis for all signals with fan-out and pins. The signal type is provided (Pin, Registered, or Combinational), as well as the data source for the toggle rate and static probability. By default, all signal activities are reported. This may be turned off on the **PowerPlay Power Analyzer Settings** page by turning off the **Write signal activities to report file** option.



Turning this option off may be advisable for a large design because of the large number of signals present. You can use the Assignment Editor to specify that activities for individual nodes or entities are reported by assigning an on value to those nodes for the Power Report Signal Activities assignment.

### *Messages*

This section lists any messages generated by the Quartus II software during the analysis.

### *Specific Rules for Reporting*

In a Stratix GX device, the XGM II State Machine block is always used together with GXB transceivers, so its power is lumped into the power for the transceivers. Therefore, the power for the XGM II State Machine block is reported as 0 Watts.

## Scripting Support

You can run procedures and make settings described in this chapter in a Tcl script. You can also run some procedures at a command prompt. For detailed information about scripting command options, refer to the Quartus II Command-Line and Tcl API Help browser. To run the Help browser, type the following command at the command prompt:

```
quartus_sh --qhelp
```

The *Scripting Reference Manual* includes the same information in PDF format.



For more information about Tcl scripting, refer to the *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*. Refer to the *Quartus II Settings File Reference Manual* for information about all settings and constraints in the Quartus II software. For more information about command-line scripting, refer to the *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*.

### Running the PowerPlay Power Analyzer from the Command Line

The separate executable that can be used to run the PowerPlay Power Analyzer is `quartus_pow`. For a complete listing of all command line options supported by `quartus_pow`, type the following at a system command prompt:

```
quartus_pow --help or quartus_sh --qhelp ↵
```

The following is an example of using the `quartus_pow` executable with project `sample.qpf`:

- To instruct the PowerPlay Power Analyzer to generate a PowerPlay Early Power Estimator file, type the following at a system command prompt:

```
quartus_pow sample --output_epe=sample.csv ↵
```

- To instruct the PowerPlay Power Analyzer to generate a PowerPlay Early Power Estimator file without doing the power estimate, type the following command at a system command prompt:

```
quartus_pow sample --output_epe=sample.csv --estimate_power=off ↵
```

- To instruct the PowerPlay Power Analyzer to use a `.saf` file as input (`sample.saf`), type the following at a system command prompt:

```
quartus_pow sample --input_saf=sample.saf ↵
```

- To instruct the PowerPlay Power Analyzer to use two .vcd files as input (**sample1.vcd** and **sample2.vcd**), perform glitch filtering on the .vcd file, and use a default input I/O toggle rate of 10,000 transitions/second, type the following at a system command prompt:

```
quartus_pow sample --input_vcd=sample1.vcd \
--input_vcd=sample2.vcd --vcd_filter_glitches=on \
--default_input_io_toggle_rate=10000transitions/s ↵
```

- To instruct the PowerPlay Power Analyzer to not use any input file, a default input I/O toggle rate of 60%, no vectorless estimation, and a default toggle rate of 20% on all remaining signals, type the following at a system command prompt:

```
quartus_pow sample --no_input_file --default_input_io_toggle_rate=60% \
--use_vectorless_estimation=off --default_toggle_rate=20% ↵
```



There are no command line options to specify the information found on the **PowerPlay Power Analyzer Settings Operating Conditions** page. The easiest way to specify these options is to use the Quartus II GUI.

A report file, *<revision name>.pow.rpt*, is created by the quartus\_pow executable and saved in the main project directory. The report file contains the same information as described in the “[PowerPlay Power Analyzer Compilation Report](#)” on page 11-39.

## Conclusion

PowerPlay power analysis tools are designed for accurate estimation of power consumption from early design concept through design implementation. Designers can use the PowerPlay Early Power Estimator to estimate power consumption during the design concept stage. Power estimations can be refined during design implementation using the Quartus II PowerPlay Power Analyzer feature. The Quartus II PowerPlay Power Analyzer produces detailed reports that you can use to optimize designs for lower power consumption and verify that the design is within your power budget.

## Referenced Documents

This chapter references the following documents:

- *Assignment Editor* chapter in volume 2 of the *Quartus II Handbook*
- *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*
- *PowerPlay Early Power Estimators (EPE) and Power Analyzer*
- *Power Optimization* chapter in volume 2 of the *Quartus II Handbook*
- *Quartus II Incremental Compilation for Hierarchical and Team-Based Design* chapter in volume 1 of the *Quartus II Handbook*
- *Quartus II Settings File Reference Manual*
- *Quartus II Simulator* chapter in volume 3 of the *Quartus II Handbook*
- *Section I. Simulation* in volume 3 of the *Quartus II Handbook*
- *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*

# Document Revision History

Table 11–5 shows the revision history for this chapter.

| <b>Table 11–5. Document Revision History</b> |                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                  |
|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| <b>Date and Version</b>                      | <b>Changes Made</b>                                                                                                                                                                                                                                                                                                                                           | <b>Summary of Changes</b>                                                                                        |
| May 2008<br>v8.0.0                           | <ul style="list-style-type: none"> <li>Updated Figure 11–5.</li> <li>Updated “Types of Power Analyses” on page 11–6.</li> <li>Updated “Operating Conditions” on page 11–11.</li> <li>Updated “PowerPlay Power Analyzer Compilation Report” on page 11–39.</li> <li>Updated “Current Drawn from Voltage Supplies” on page 11–40.</li> </ul>                    | Updated for the Quartus II software version 8.0.                                                                 |
| October 2007<br>v7.2.0                       | <ul style="list-style-type: none"> <li>Updated Figures 10–4, 10–9, 10–10, 10–11, and 10–22.</li> <li>Updated “Generating a SAF or VCD File Using the Quartus II Simulator” on page 10–24.</li> <li>Updated “Generating a VCD File Using a Third-Party Simulator” on page 10–28.</li> </ul>                                                                    | Updated for the Quartus II software version 7.2.                                                                 |
| May 2007<br>v7.1.0                           | <ul style="list-style-type: none"> <li>Updated procedures for “Generating a SAF or VCD File Using the Quartus II Simulator” on page 10–24.</li> <li>Updated figures.</li> <li>Added “Document Revision History” on page 10–45.</li> </ul>                                                                                                                     | Added support for Arria GX devices.                                                                              |
| March 2007<br>v7.0.0                         | Added Cyclone III to list of devices supported (page 10–2)                                                                                                                                                                                                                                                                                                    | —                                                                                                                |
| November 2006<br>v6.1.0                      | <ul style="list-style-type: none"> <li>Updated “Generating a SAF or VCD File Using the Quartus II Simulator” by changing steps in certain processes to accommodate new functionality.</li> <li>Updated “Operating Conditions” by adding Selectable Core Voltage option.</li> <li>Updated Figure 10–2, 10–9, 10–10, 10–12, 10–14, 10–18, and 10–19.</li> </ul> | Figure changes were made to accommodate the changes to the GUI. Also, added information for Stratix III devices. |
| May 2006<br>v6.0.0                           | <p>Chapter title changed to <i>PowerPlay Power Analysis</i>.<br/>           Updated for the Quartus II software version 6.0.0:</p> <ul style="list-style-type: none"> <li>Added information about the EPE tools.</li> <li>Added information about the power analyzer.</li> </ul>                                                                              | —                                                                                                                |
| October 2005<br>v5.1.0                       | Updated for the Quartus II software version 5.1.                                                                                                                                                                                                                                                                                                              | —                                                                                                                |
| May 2005<br>v5.0.0                           | <ul style="list-style-type: none"> <li>Updated information.</li> <li>Updated figures.</li> <li>New functionality for Quartus II software 5.0.</li> </ul>                                                                                                                                                                                                      | —                                                                                                                |
| December 2004<br>v1.0                        | Initial release.                                                                                                                                                                                                                                                                                                                                              | —                                                                                                                |



As FPGA usage expands into more high-speed applications, signal integrity becomes an increasingly important factor to consider for an FPGA design.

Signal integrity issues must be taken into account as part of FPGA I/O planning and assignments, as well as in the design and layout of the printed circuit board (PCB) that must support the FPGA. Early design simulation is essential for preventing issues that may require a board redesign. The Quartus II software provides a number of features that will help you make smart board design decisions to ensure good signal integrity on all your high-speed interfaces.

This section includes the following chapter:

- [Chapter 12, Signal Integrity Analysis with Third-Party Tools](#)

 For information about the revision history for chapters in this section, refer to each individual chapter for that chapter's revision history.



### Introduction

With the introduction of high-speed interfaces to traditional FPGA design, it timing and signal integrity margins between the FPGA and other devices on the board must be within specification and tolerance before a single PCB is built. If the board trace is designed poorly or the route is too heavily loaded, noise in the signal can cause data corruption, while overshoot and undershoot can potentially damage input buffers over time.

As FPGA devices are used in high-speed applications, signal integrity and timing margin between the FPGA and other devices on the printed circuit board (PCB) are important aspects to consider to ensure proper system operation. To avoid time-consuming redesigns and expensive board respins, the topology and routing of critical signals must be simulated. The high-speed interfaces available on current FPGA devices must be modeled accurately and integrated into timing models and board-level signal integrity simulations. The tools used in the design of an FPGA and its integration into a PCB must be “board-aware”—able to take into account properties of the board routing and the connected devices on the board.

This chapter contains the following topics:

- “I/O Model Selection: IBIS or HSPICE” on page 12–4
- “FPGA to Board Signal Integrity Analysis Flow” on page 12–5
- “Simulation with IBIS Models” on page 12–9
- “Simulation with HSPICE Models” on page 12–22

The Quartus® II software provides methodologies, resources, and tools to ensure good signal integrity and timing margin between Altera® FPGA devices and other components on the board. Three types of analysis are possible with the Quartus II software:

- I/O timing with a default or user-specified capacitive load and no signal integrity analysis (default)
- The Quartus II Advanced I/O Timing option utilizing a user-defined board trace model to produce enhanced timing reports from accurate “board-aware” simulation models
- Full board routing simulation in third-party tools using Altera-provided or generated Input/Output Buffer Information Specification (IBIS) or HSPICE I/O models

I/O timing using a specified capacitive test load requires no special configuration other than setting the size of the load. I/O timing reports from Quartus II TimeQuest or the Quartus II Classic Timing Analyzer are generated based only on point-to-point delays within the I/O buffer and assume the presence of the capacitive test load with no other details about the board specified. The default size of the load is based on the I/O standard selected for the pin. Timing is measured to the FPGA pin with no signal integrity analysis details.

The Advanced I/O Timing option expands the details in I/O timing reports by taking board topology and termination components into account. A complete point-to-point board trace model is defined and accounted for in the timing analysis. This ability to define a board trace model is an example of how the Quartus II software is “board-aware.”

In this case, timing and signal integrity metrics between the I/O buffer and the defined far end load are analyzed and reported in enhanced reports generated by the Quartus II TimeQuest Timing Analyzer.



For more information about defining capacitive test loads or how to use the Advanced I/O Timing option to configure a board trace model, refer to the *I/O Management* chapter in volume 2 of the *Quartus II Handbook*.

This chapter focuses on the third type of analysis. The Quartus II software can export accurate HSPICE models with the built-in HSPICE Writer. You can run signal integrity simulations with these complete HSPICE models in Synopsys HSPICE. IBIS models of the FPGA I/O buffers are also created easily with the Quartus II IBIS Writer. You can integrate IBIS models into any third-party simulation tool that supports them, such as the Mentor Graphics® Hyperlynx software. With the ability to create industry-standard model definition files quickly, you can build accurate simulations that can provide data to help improve board-level signal integrity.

The I/O’s IBIS and HSPICE model creation available in the Quartus II software can help prevent problems before a costly board respin is needed. In general, creating and running accurate simulations is difficult and time consuming. The tools in the Quartus II software automate the I/O model setup and creation process by configuring the models specifically for your design. With these tools, you can set up and run accurate simulations quickly and acquire data that helps guide your FPGA and board design.

The information about signal integrity in this chapter refers to board-level signal integrity based on I/O buffer configuration and board parameters, not simultaneous switching noise (SSN), also known as ground bounce or  $V_{CC}$  sag. SSN is a product of multiple output drivers switching at the

same time, causing an overall drop in the voltage of the chip's power supply. This can cause temporary glitches in the specified level of ground or  $V_{CC}$  for the device.



For a more information about SSN and ways to prevent it, refer to application note [AN 315: Guidelines for Designing High-Speed FPGA PCBs](#).

This chapter is intended for FPGA and board designers and includes details about the concepts and steps involved in getting designs simulated and how to adjust designs to improve board-level timing and signal integrity. Also included is information about how to create accurate models from the Quartus II software and how to use those models in simulation software.

The information in this chapter is meant for those who are familiar with the Quartus II software and basic concepts of signal integrity and the design techniques and components in good PCB design. Finally, you should know how to set up simulations and use your selected third-party simulation tool.



For information about basic signal integrity concepts and signal integrity details pertaining to Altera FPGA devices, refer to the [Altera Signal Integrity Center](#).

## I/O Model Selection: IBIS or HSPICE

The Quartus II software can export two different types of I/O models that are useful for different simulation situations. IBIS models define the behavior of input or output buffers through the use of voltage-current (V-I) and voltage-time (V-t) data tables. HSPICE models, often referred to as HSPICE decks, include complete physical descriptions of the transistors and parasitic capacitances that make up an I/O buffer along with all the parameter settings needed to run a simulation. The HSPICE decks generated by the Quartus II software are preconfigured with the I/O standard, voltage, and pin loading settings for each pin in your design.

The choice of I/O model type is based on many factors. Table 12-1 shows a detailed comparison of the two I/O model types and information and examples of situations in which they might be used.

**Table 12-1. IBIS and HSPICE Model Comparison**

| Feature                        | IBIS Model                                                                                                                                        | HSPICE Model                                                                                                                                                                                                         |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I/O Buffer Description         | <b>Behavioral</b> —I/O buffers are described by voltage-current and voltage-time tables in typical, minimum, and maximum supply voltage cases.    | <b>Physical</b> —I/O buffers and all components in a circuit are described by their physical properties, such as transistor characteristics and parasitic capacitances, as well as their connections to one another. |
| Model Customization            | <b>Simple and limited</b> —The model completely describes the I/O buffer and does not usually need to be customized.                              | <b>Fully customizable</b> —Unless connected to an arbitrary board description, the description of the board trace model must be customized in the model file. All parameters of the simulation are also adjustable.  |
| Simulation Set Up and Run Time | <b>Fast</b> —Simulations run quickly once set up correctly.                                                                                       | <b>Slow</b> —Simulations take time to set up and take longer to run and complete.                                                                                                                                    |
| Simulation Accuracy            | <b>Good</b> —For most simulations, accuracy is sufficient to make useful adjustments to the FPGA and/or board design to improve signal integrity. | <b>Excellent</b> —Simulations are highly accurate, making HSPICE simulation almost a requirement for any high-speed design where signal integrity and timing margins are tight.                                      |
| Third-Party Tool Support       | <b>Excellent</b> —Almost all third-party board simulation tools support IBIS.                                                                     | <b>Good</b> —Most third-party tools that support SPICE support HSPICE. However, Synopsys HSPICE is required for simulations of Altera's encrypted HSPICE models.                                                     |



For more information about IBIS files created by the Quartus II IBIS Writer and IBIS files in general, as well as links to websites with detailed information, refer to [AN 283: Simulating Altera Devices with IBIS Models](#).

## FPGA to Board Signal Integrity Analysis Flow

Board signal integrity analysis can take place at any point in the FPGA design process and is often performed both before and after board layout. If it is performed early in the process as part of a pre-PCB layout analysis, the models used for simulations can be more generic and can be changed as much as needed to see how adjustments improve timing or signal integrity and help with the design and routing of the PCB. Simulations and the resulting changes made at this stage allow you to analyze “what if” scenarios to plan and implement your design better. To assist with early board signal integrity analysis, you can download generic IBIS model files for each device family and obtain HSPICE buffer simulation kits from the Altera website at: [www.altera.com](http://www.altera.com).

Typically, if board signal integrity analysis is performed late in the design, it is used for a post-layout verification. The inputs and outputs of the FPGA are defined, and required board routing topologies and constraints are known. Simulations can help you find problems that may still exist in the FPGA or board design before fabrication and assembly. In either case, a simple process flow illustrates how to create accurate IBIS and HSPICE models from a design in the Quartus II software and transfer them to third-party simulation tools. [Figure 12-1](#) shows this flow.



This chapter is organized around the type of model, IBIS or HSPICE, that you use for your simulations. Once you understand the steps in the analysis flow, refer to the section of this chapter that corresponds to the model type you are using.

**Figure 12–1. Third-Party Board Signal Integrity Analysis Flow**

## Create I/O and Board Trace Model Assignments

If your design uses a Stratix® II, Stratix III, or Cyclone® III device, you can configure a board trace model for output signals or for bidirectional signals in output mode and automatically transfer its description to HSPICE decks generated by the HSPICE Writer. This helps improve simulation accuracy.

To configure a board trace model, in the **Settings** dialog box, in the **TimeQuest Timing Analyzer** page, turn on the **Enable Advanced I/O Timing** option and configure the board trace model assignment settings for each I/O standard used in your design. You can add series or parallel termination, specify the transmission line length, and set the value of the far-end capacitive load. You can configure these parameters either in the Board Trace Model view of the Pin Planner, or click **Device and Pin Options** in the **Device** page of the **Settings** dialog box,



For information about how to use Advanced I/O Timing and configure board trace models for the I/O standards used in your design, refer to the *I/O Management* chapter in volume 2 of the *Quartus II Handbook*.

The Quartus II software can generate IBIS models and HSPICE decks without needing to configure a board trace model with the Advanced I/O Timing option. In fact, IBIS models ignore any board trace model settings other than the far-end capacitive load. If any load value is set other than the default, the delay given by IBIS models generated by the IBIS Writer cannot be used to account correctly for the double counting problem. The load value mismatch between the IBIS delay and the  $t_{CO}$  measurement of the Quartus II software prevents the delays from being safely added together. Warning messages displayed when the EDA Netlist Writer runs indicate when this mismatch occurs.

## Output File Generation

IBIS and HSPICE model files are not generated by the Quartus II software by default. To generate or update the files automatically during each project compilation, select the type of file to generate and a location where to save the file in the project settings. These settings can also be specified with commands in a Tcl script.

The IBIS and HSPICE Writers in the Quartus II software are run as part of the EDA Netlist Writer during normal project compilation. If either writer is turned on in the project settings, IBIS or HSPICE files are created and stored in the specified location. For IBIS, a single file is generated containing information about all assigned pins. HSPICE file generation creates separate files for each assigned pin. You can run the EDA Netlist Writer separately from a full compilation in the Quartus II software or at

the command line. However, you must fully compile the project or perform I/O Assignment Analysis at least once for the IBIS and HSPICE Writers to have information about the I/O assignments and settings in the design.

## Customize the Output Files

The files generated by either the IBIS or HSPICE Writer are text files that you can edit and customize easily for design or experimentation purposes. IBIS files downloaded from the Altera website must be customized with the correct RLC values for the specific device package you have selected for your design. IBIS files generated by the IBIS Writer do not require this customization because they are configured automatically with the RLC values for your selected device. HSPICE decks require modification to include a detailed description of your board. With **Enable Advanced I/O Timing** turned on and a board trace model defined in the Quartus II software, generated HSPICE decks automatically include that model's parameters. However, Altera recommends that you replace that model with a more detailed model that describes your board design more accurately. A default simulation included in the generated HSPICE decks measures delay between the FPGA and the far-end device. You can make additions or adjustments to the default simulation in the generated files to change the parameters of the default simulation or to perform additional measurements.

## Set Up and Run Simulations in Third-Party Tools

Once you have generated the files, you can use them to perform simulations in your selected simulation tool. With IBIS models, you can apply them to input, output, or bidirectional buffer entities and quickly set up and run simulations. For HSPICE decks, the simulation parameters are included in the files. Open the files in Synopsys HSPICE and run simulations for each pin as needed.

With HSPICE decks generated from the HSPICE Writer, the double counting problem is accounted for, which ensures that your simulations are accurate. Simulations that involve IBIS models created with anything other than the default loading settings in the Quartus II software must take the change in the size of the load between the IBIS delay and the Quartus II  $t_{CO}$  measurement into account. Warning messages during compilation alert you to this change.

## Interpret Simulation Results

If you encounter timing or signal integrity issues with your high-speed signals after running simulations, you can make adjustments to I/O assignment settings in the Quartus II software. These could include such things as drive strength or I/O standard, or making changes to your board routing or topology. After regenerating models in the Quartus II software based on the changes you have made, rerun the simulations to check whether your changes corrected the problem.

## Simulation with IBIS Models

IBIS models provide a way to run accurate signal integrity simulations quickly. IBIS models describe the behavior of I/O buffers with voltage-current and voltage-time data curves. Because of their behavioral nature, IBIS models do not have to include any information about the internal circuit design of the I/O buffer. Most component manufacturers, including Altera, provide IBIS models for free download and use in signal integrity analysis simulation tools. You can download generic device family IBIS models from the Altera website for early design simulation or use the IBIS Writer to create custom IBIS models for your existing design.

### Elements of an IBIS Model

An IBIS model file (.ibs) is a text file that describes the behavior of an I/O buffer across minimum, typical, and maximum temperature and voltage ranges with a specified test load. The tables and values specified in the IBIS file describe five basic elements of the I/O buffer. [Figure 12–2](#) highlights each of these elements in the I/O buffer model.

**Figure 12–2. Five Basic Elements in IBIS Models**



The following elements correspond to each numbered block in [Figure 12-2](#).

1. **Pulldown**—A voltage-current table describes the current when the buffer is driven low based on a pull-down voltage range of  $-V_{CC}$  to  $2V_{CC}$ .
2. **Pullup**—A voltage-current table describes the current when the buffer is driven high based on a pull-up voltage range of  $-V_{CC}$  to  $V_{CC}$ .
3. **Ground and Power Clamps**—Voltage-current tables describe the current when clamping diodes for electrostatic discharge (ESD) are present. The ground clamp voltage range is  $-V_{CC}$  to  $V_{CC}$ , and the power clamp voltage range is  $-V_{CC}$  to ground.
4. **Ramp and Rising/Falling Waveform**—A voltage-time (dv/dt) ratio describes the rise and fall time of the buffer during a logic transition. Optional rising and falling waveform tables can be added to more accurately describe the characteristics of the rising and falling transitions.
5. **Total Output Capacitance and Package RLC**—The total output capacitance includes the parasitic capacitances of the output pad, clamp diodes (if present), and input transistors. The package RLC is device package-specific and defines the resistance, inductance, and capacitance of the bond wire and pin of the I/O.



For more information about IBIS models and Altera-specific features, including links to the official IBIS specification, refer to [AN 283: Simulating Altera Devices with IBIS Models](#).

## Creating Accurate IBIS Models

There are two methods to obtain Altera device IBIS files for your board-level signal integrity simulations. You can download generic IBIS models from the Altera website or you can use the IBIS writer in the Quartus II software to create design-specific models.

### Download IBIS Models

Altera provides IBIS models for almost all FPGA and FPGA configuration devices. Check the Download Center at [www.altera.com](http://www.altera.com) for information about whether models for your selected device are available. You can use the IBIS models from the website to perform early simulations of the I/O buffers you expect to use in your design as part of a pre-layout analysis.

Downloaded IBIS models have the RLC package values set to one particular device in each device family. To simulate your design with the model accurately, you must adjust the RLC values in the IBIS model file to match the values for your particular device package by performing the following steps:

1. Download and expand the ZIP file (.zip) of the IBIS model for the device family you are using for your design. The .zip file contains the IBIS model file along with an IBIS model user guide and a model data correlation report.
2. Download the Package RLC Values spreadsheet for the same device family.
3. Open the spreadsheet and locate the row that describes the device package used in your design.
4. From the package's I/O row, copy the minimum, maximum, and typical values of resistance, inductance, and capacitance for your device package.
5. Open the IBIS model file in a text editor and locate the [Package] section of the file.
6. Overwrite the listed values copied with the values from the spreadsheet and save the file.

The IBIS model file is now customized for your device package and can be used for any simulation. IBIS models downloaded and used for simulations in this manner are generic. They describe only a certain set of models listed for each device on the IBIS model Download Center page on the Altera website ([www.altera.com](http://www.altera.com)). To create customized models for your design, use the IBIS Writer as described in the next section.

#### *Generate Custom IBIS Models with the IBIS Writer*

If you have started your FPGA design and have created custom I/O assignments, such as drive strength settings or the enabling of clamping diodes for ESD protection, you can use the Quartus II IBIS Writer to create custom IBIS models to accurately reflect your assignments. IBIS models created with the IBIS Writer take I/O assignment settings into account.

If the **Enable Advanced I/O Timing** option is turned off, the generated IBIS model files are based on the load value setting for each I/O standard on the **Capacitive Loading** tab of the **Device and Pin Options** dialog box in the **Device** page of the **Settings** dialog box. With the **Enable Advanced**

**I/O Timing** option turned on, IBIS models use an effective capacitive load based on settings found in the board trace model on the **Board Trace Model** tab in the **Device and Pin Options** dialog box or the **Board Trace Model** view in the Pin Planner. The effective capacitive load is based on the sum of the **Near capacitance**, **Transmission line distributed capacitance**, and the **Far capacitance** settings in the board trace model. Resistances and transmission line inductance values are ignored.



If you made any changes from the default load settings, the delay in the generated IBIS model cannot safely be added to the Quartus II  $t_{CO}$  measurement to account for the double counting problem. This is because the load values between the two delay measurements do not match. When this happens, the Quartus II software displays warning messages when the EDA Netlist Writer runs to remind you about the load value mismatch.

When the IBIS Writer is enabled, it generates a custom IBIS model file whenever the EDA Netlist Writer is run in the Quartus II software. To turn on the IBIS Writer and create custom IBIS model files, perform the following steps:

1. On the Assignments menu, click **Settings**.
2. In the **Category** list, click the icon to expand **EDA Tool Settings** and select **Board-Level**.
3. Under **Board-Level Signal Integrity Analysis Format**, in the **Format** list, select **IBIS** (Figure 12-3).

Figure 12–3. Enabling IBIS Model Generation in the Settings Dialog Box



4. IBIS models are stored in the `<project directory>/board/ibis` directory by default. To change the directory, click the browse button next to the **Output directory** box, and browse to the desired location.
5. Click **OK** to close the **Settings** dialog box.
6. If the project has not been compiled, run a full compilation to create a netlist and establish I/O assignments. On the Processing menu, click **Start Compilation**. The IBIS model file, named `<project name>.ibs`, is saved in the specified location.
7. If the project has been compiled before, you only need to run the EDA Netlist Writer to create or update the IBIS model file. On the Processing menu, point to Start and click **Start EDA Netlist Writer**. The IBIS model file is created or updated in the specified location.



You can save compilation time when creating the IBIS model file the first time for early design simulation by performing only required steps of the compilation process instead of a full compilation of your project. Run Analysis and Synthesis and I/O Assignment Analysis before creating the IBIS model file with the EDA Netlist Writer.



For more information about IBIS model generation, refer to the [AN 283: Simulating Altera Devices with IBIS Models](#) or to the Quartus II Help.

## Design Simulation Using the Mentor Graphics HyperLynx Software

You must integrate IBIS models downloaded from the Altera website ([www.altera.com](http://www.altera.com)) or created with the Quartus II IBIS Writer into board design simulations to accurately model timing and signal integrity. The HyperLynx software from Mentor Graphics is one of the most popular tools for design simulation. The HyperLynx software makes it easy to integrate IBIS models into simulations.

The HyperLynx software is a PCB analysis and simulation tool for high-speed designs, consisting of two products, LineSim and BoardSim. LineSim is an early simulation tool. Before any board routing takes place, LineSim is used to simulate “what if” scenarios to assist in creating routing rules and defining board parameters. BoardSim is a post-layout tool used to analyze existing board routing. Specific nets are selected from a board layout file and simulated in a manner similar to LineSim. With board and routing parameters, and surrounding signal routing known, highly accurate simulations of the final fabricated PCB are possible. This section focuses on LineSim. Because the process of creating and running simulations is very similar for both LineSim and BoardSim, the details of IBIS model use in LineSim applies to simulations in BoardSim.

Simulations in LineSim are configured using a schematic GUI to create connections and topologies between I/O buffers, route trace segments, and termination components. LineSim provides two methods for creating routing schematics: cell-based and free-form. Cell-based schematics are based on fixed cells consisting of typical placements of buffers, trace impedances, and components. Parts of the grid-based cells are filled with the desired objects to create the topology. A topology in a cell-based schematic is limited by the available connections within and between the cells.

A more robust and expandable way to create a circuit schematic for simulation is to use the free-form schematic format in LineSim as shown in [Figure 12-4](#). The free-form schematic format makes it easy to place

parts into any configuration and edit them as needed. This section describes the use of IBIS models with free-form schematics, but the process is nearly identical for cell-based schematics.

**Figure 12–4. HyperLynx LineSim Free-Form Schematic Editor**



When you use HyperLynx software to perform simulations, you typically perform the following steps:

1. Create a new LineSim free-form schematic document and set up the board stackup for your PCB using the Stackup Editor. In this editor, specify board layer properties including layer thickness, dielectric constant, and trace width.
2. Create a circuit schematic for the net you want to simulate. The schematic represents all the parts of the routed net including source and destination I/O buffers, termination components, transmission line segments, and representations of impedance discontinuities such as vias or connectors.

3. Assign IBIS models to the source and destination I/O buffers to represent their behavior during operation.
4. Attach probes from the digital oscilloscope that is built in to LineSim to points in the circuit that you want to monitor during simulation. Typically, at least one probe is attached to the pin of a destination I/O buffer. For differential signals, you can attach a differential probe to both the positive and negative pins at the destination.
5. Configure and run the simulation. You can simulate a rising or falling edge and test the circuit under different drive strength conditions.
6. Interpret the results and make adjustments. Based on the waveforms captured in the digital oscilloscope, you can adjust anything in the circuit schematic to correct any signal integrity issues, such as overshoot or ringing. If necessary, you can make I/O assignment changes in the Quartus II software, regenerate the IBIS file with the IBIS Writer, and apply the updated IBIS model to the buffers in your HyperLynx software schematic.
7. Repeat the simulations and circuit adjustments until you are satisfied with the results. Once the operation of the net meets your design requirements, implement changes to your I/O assignments in the Quartus II software and/or adjust your board routing constraints, component values, and placement to match the simulation.



For more information about HyperLynx software, including schematic creation, simulation setup, model usage, product support, licensing, and training, refer to HyperLynx Help or the Mentor Graphics website at [www.mentor.com](http://www.mentor.com).

## Configuring LineSim to Use Altera IBIS Models

You must configure LineSim to find and use the downloaded or generated IBIS models for your design. To do this, add the location of your IBIS model file or files to the LineSim Model Library search path. Then you apply a selected model to a buffer in your schematic.

To add the Quartus II software's default IBIS model location, `<project directory>/board/ibis`, to the HyperLynx LineSim model library search path, perform the following steps in LineSim:

1. From the Options menu, click **Directories**. The **Set Directories** dialog box appears (Figure 12–5). The **Model-library file path(s)** list displays the order in which LineSim searches file directories for model files.

**Figure 12–5. LineSim Set Directories Dialog Box**



2. Click **Edit**. A dialog box appears where you can add directories and adjust the order in which LineSim searches them (Figure 12–6).

**Figure 12–6. LineSim Select Directories Dialog Box**

3. Click **Add**
4. Browse to the default IBIS model location, *<project directory>/board/ibis*. Click **OK**.
5. Click **Up** to move the IBIS model directory to the top of the list. Click **Generate Model Index** to update LineSim's model database with the models found in the added directory.
6. Click **OK**. The IBIS model directory for your project is added to the top of the Model-library file path(s) list.
7. To close the Set Directories dialog box, Click **OK**.

### Integrating Altera IBIS Models into LineSim Simulations

When the location for IBIS files has been set, you can assign the downloaded or generated IBIS models to the buffers in your schematic. To do this, perform the following steps:

1. Double-click a buffer symbol in your schematic to open the **Assign Models** dialog box (Figure 12–7). You can also click **Assign Models** from the buffer symbol's right-click menu.

Figure 12-7. LineSim Assign Model Dialog Box



2. The pin of the buffer symbol you selected should be highlighted in the **Pins** list. If you want to assign a model to a different symbol or pin, select it from the list.
3. Click **Select**. The **Select IC Model** dialog box appears (Figure 12-8).

Figure 12–8. LineSim Select IC Model Dialog Box



4. To filter the list of available libraries to display only IBIS models, select **.IBS**. Scroll through the **Libraries** list, and click the name of the library for your design. By default, this is *<project name>.ibr*.
5. The device for your design should be selected as the only item in the **Devices** list. If not, select your device from the list.
6. From the **Signal** list, select the name of the signal you want to simulate. You can also choose to select by device pin number.
7. Click **OK**. The **Assign Models** dialog box displays the selected IBIS model file and signal.
8. If applicable to the signal you chose, adjust the buffer settings as needed for the simulation.
9. Select and configure other buffer pins from the **Pins** list in the same manner.
10. Click **OK** when all I/O models are assigned.

## Running and Interpreting LineSim Simulations

Now you can now run any desired simulations and make adjustments to the I/O assignments or simulation parameters as needed. For example, if you see too much overshoot in the simulated signal at the destination buffer after running a simulation (as shown in [Figure 12–9](#)), you could adjust the drive strength I/O assignment setting to a lower value. Regenerate the IBIS model file, and run the simulation again to verify whether the change fixed the problem.

*Figure 12–9. Example of Overshoot in HyperLynx with IBIS Models*



If you see a discontinuity or other anomalies at the destination, such as slow rise and fall times (as shown in [Figure 12–10](#)), adjust the termination scheme or termination component values. After making these changes, rerun the simulation to check whether your adjustments solved the problem. In this case, it is not necessary to regenerate the IBIS model file.

**Figure 12–10. Example of Signal Integrity Anomaly in HyperLynx with IBIS Models**



For more information about board-level signal integrity and to learn about ways to improve it with simple changes to your design, visit the Altera Signal Integrity Center at [www.altera.com](http://www.altera.com).

## Simulation with HSPICE Models

HSPICE decks are used to perform highly accurate simulations by describing the physical properties of all aspects of a circuit precisely. HSPICE decks describe I/O buffers, board components, and all of the connections between them, as well as defining the parameters of the simulation to be run. By their nature, to be effective, HSPICE decks are highly customizable and require a detailed description of the circuit under simulation. For devices that support Advanced I/O timing, when **Enable Advanced I/O Timing** is turned on, the HSPICE decks generated by the Quartus II HSPICE Writer automatically include board components and topology defined in the Board Trace Model. Configure the board components and topology in the Pin Planner or in the **Board Trace Model** tab of the **Device and Pin Options** dialog box. All HSPICE decks generated by the Quartus II software include compensation for the double count problem. For more information about the double count problem, refer to **“The Double Counting Problem in HSPICE Simulations”** on page 12–24. You can simulate with the default simulation parameters built in to the generated HSPICE decks or make adjustments to customize your simulation.

## Supported Devices and Signaling

Beginning with Quartus II software version 6.1 and later, the HSPICE Writer supports the devices and signaling defined in [Table 12-2](#). Only Stratix II and Cyclone III devices support the creation of a board trace model in the Quartus II software for automatic inclusion in an HSPICE deck. Other devices require the board description to be manually added to the HSPICE file.

**Table 12-2. HSPICE Writer Device and Signaling Support**

| Device                           | Input | Output | Single-Ended | Differential | Automatic Board Trace Model Description |
|----------------------------------|-------|--------|--------------|--------------|-----------------------------------------|
| Stratix II                       | ✓     | ✓      | ✓            | ✓            | ✓                                       |
| Stratix II GX (non-HSSI signals) | ✓     | ✓      | ✓            | ✓            | —                                       |
| HardCopy® II                     | ✓     | ✓      | ✓            | ✓            | —                                       |
| Cyclone III                      | —     | ✓      | ✓            | ✓            | ✓                                       |

If you are using a Stratix II or Cyclone III device for your design, you can turn on **Enable Advanced I/O Timing** and configure the board trace model for each I/O standard used in your design. The HSPICE files include the board trace description you create in the Board Trace Model view in the Pin Planner or the **Board Trace Model** tab in **Device and Pin Options** dialog box.



For more information about Advanced I/O Timing and configuring board trace models for the I/O standards in your design, refer to the *I/O Management* chapter in volume 2 of the *Quartus II Handbook*.

## Accessing HSPICE Simulation Kits

You can access the available HSPICE models at the [SPICE Models for Altera Devices](#) web page and also with the Quartus II software's HSPICE Writer tool. The Quartus II software HSPICE Writer tool removes many common sources of user error from the I/O simulation process. The HSPICE Writer tool automatically creates preconfigured I/O simulation spice decks that only require the addition of a user board model. All the difficult tasks required to configure the I/O modes and interpret the timing results are handled automatically by the HSPICE Writer tool.

## The Double Counting Problem in HSPICE Simulations

Simulating I/Os using accurate models is extremely helpful for finding and fixing FPGA I/O timing and board signal integrity issues before any boards are built. However, the usefulness of such simulations is directly related to the accuracy of the models used and whether the simulations are set up and performed correctly. To ensure accuracy in models and simulations created for FPGA output signals, the timing hand-off between  $t_{CO}$  timing in the Quartus II software and simulation-based board delay must be taken into account. If this hand-off is not handled correctly, the calculated delay could either count some of the delay twice or even miss counting some of the delay entirely.

### Defining the Double Counting Problem

The double counting problem is inherent to the method output timing is analyzed versus the method used for HSPICE models. The timing analyzer tools in the Quartus II software measure delay timing for an output signal from the core logic of the FPGA design through the output buffer ending at the FPGA pin with a default capacitive load or a specified value for the selected I/O standard. This measurement is the  $t_{CO}$  timing variable as shown in Figure 12-11.

**Figure 12-11. Double Counting Problem**



HSPICE models for board simulation measure  $t_{PD}$  (propagation delay) from an arbitrary reference point in the output buffer, through the device pin, out along the board routing, and ending at the signal destination.

It is apparent immediately that if these two delays were simply added together, the delay between the output buffer and the device pin would be counted twice in the calculation. A model or simulation that does not account for this double count would create overly pessimistic simulation results, because the double-counted delay can limit I/O performance artificially. To fix the problem, it may seem like simply subtracting the overlap between  $t_{CO}$  and  $t_{PD}$  would account for the double count. However, this adjustment would not be accurate because each measurement is based on a different load.



Input signals do not exhibit this problem because the HSPICE models for inputs stop at the FPGA pin instead of at the input buffer. In this case, simply adding the delays together produces an accurate measurement of delay timing.

### *The Solution to Double Counting*

To adjust the measurements to account for the double-counting, the delay between the arbitrary point in the output buffer selected by the HSPICE model and the FPGA pin must be subtracted from either  $t_{CO}$  or  $t_{PD}$  before adding the results together. The subtracted delay must also be based on a common load between the two measurements. This is done by repeating the HSPICE model measurement, but with the same load used by the Quartus II software for the  $t_{CO}$  measurement. This second measurement, called  $t_{TESTLOAD}$ , is illustrated with the top circuit in Figure 12-12.

Figure 12–12. Common Test Loads Used for Output Timing



With  $t_{TESTLOAD}$  known, the total delay for the output signal from the FPGA logic to the signal destination on the board, accounting for the double count, is calculated as shown in [Equation 1](#).

$$(1) \quad t_{delay} = t_{CO} + (t_{PD} - t_{TESTLOAD})$$

The preconfigured simulation files generated by the HSPICE Writer in the Quartus II software are designed to account for the double-counting problem based on this calculation automatically. Performing accurate timing simulations is easy without the need to make adjustments for double counting manually.

## HSPICE Writer Tool Flow

This section includes information to help you get started using the Quartus II software HSPICE Writer tool. The information in this section assumes you have a basic knowledge of the standard Quartus II software design flow, such as project and assignment creation, compilation, and timing analysis.



For additional information about standard design flows, refer to the appropriate sections of the *Quartus II Handbook*.

### *Applying I/O Assignments*

The first step in the HSPICE Writer tool flow is to configure the I/O standards and modes for each of the pins in your design properly. In the Quartus II software, these settings are represented by assignments that map I/O settings, such as pin selection, and I/O standard and drive strength, to corresponding signals in your design.

The Quartus II software provides multiple methods for creating these assignments:

- Using the Pin Planner
- Using the assignment editor
- Manually editing the QSF file
- By making assignments in a scripted Quartus II flow using TCL

### *Enabling HSPICE Writer*

You must enable the HSPICE Writer prior to the Quartus II software (Figure 12-13), as the Quartus II software does not generate HSPICE simulation files by default.

Enable the HSPICE Writer as follows:

1. On the Assignment menu, click **EDA Tool Settings**. The **EDA Tool Settings** dialog box appears.
2. In the category list, click the “+” icon next to **EDA Tool Settings** to expand the folder.
3. On the expanded **EDA Tool Settings** list, click **Board-Level**.

4. On the right-side of the dialog box, under **Board-Level Signal Integrity Analysis**, from the format drop down list, select **HSPICE**.

Optionally, select the directory in which to place the Quartus II software HSPICE files (default is **board/hspice**).

5. To close the dialog box, click **OK**.

**Figure 12–13. EDA Tool Settings: Board Level Options Dialog Box**



### Enabling HSPICE Writer Using Assignments

You can also use HSPICE Writer in conjunction with a scripted TCL flow. To enable HSPICE Writer during a full compile, include the lines shown in [Example 12-1](#) in your `.tcl` script.

---

#### Example 12-1.

```
set_global_assignment -name EDA_BOARD_DESIGN_SIGNAL_INTEGRITY_TOOL "HSPICE
(Signal Integrity)"

set_global_assignment -name EDA_OUTPUT_DATA_FORMAT HSPICE -section_id
eda_board_design_signal_integrity

set_global_assignment -name EDA_NETLIST_WRITER_OUTPUT_DIR
<output_directory> -section_id eda_board_design_signal_integrity
```

---

As with command-line invocation, specifying the output directory is optional. If not specified, the output directory defaults to **board/hspice**.

### Naming Conventions for HSPICE Files

HSPICE Writer automatically generates simulation files and names them using the following naming convention:

`<pin #>_<pin_name>_<in/out>.sp`

For bidirectional pins, two spice decks are produced; one with the I/O buffer configured as an input, and the other with the I/O buffer configured as an output.

The Quartus II software supports alphanumeric pin names that contain the underscore (   ) and dash ( - ) characters. Any illegal characters used in file names are converted automatically to underscores.

The contents of the HSPICE files are described in detail in [“Sample Output for I/O HSPICE Simulation Deck” on page 12-44](#), and [“Sample Input for I/O HSPICE Simulation Deck” on page 12-37](#).

### Invoking HSPICE Writer

After enabled, the HSPICE simulation files are generated automatically each time the project is completely compiled. The Quartus II software also provides the option to generate a new set of simulation files without the need to recompile the entire project. Use the following steps to invoke the HSPICE Writer without invoking Analysis & Synthesis and Fitting.



You must perform both Analysis & Synthesis and Fitting on a design before invoking the HSPICE Writer tool using the following method:

1. On the Processing Menu, click **Start**.
2. Click **Start EDA Netlist Writer**.

The actual process of generating the HSPICE files happens either automatically as part of the complete compilation flow, or manually by selecting **Start EDA Netlist Writer**, in the Processing menu.

#### *Invoking HSPICE Writer from the Command Line*

If you use a script-based flow to compile your project, you can create HSPICE model files by including the commands shown in [Example 12-2](#) in your Tcl script (.tcl file).

---

#### **Example 12-2.**

```
set_global_assignment -name EDA_BOARD_DESIGN_SIGNAL_INTEGRITY_TOOL \
"SPICE (Signal Integrity)"\n\nset_global_assignment -name EDA_OUTPUT_DATA_FORMAT SPICE \
- section_ideda_board_design_signal_integrity\n\nset_global_assignment -name EDA_NETLIST_WRITER_OUTPUT_DIR <output_directory> \
- section_id eda_board_design_signal_integrity
```

---

The *<output directory>* option specifies the location where HSPICE model files are saved. By default, the following directory is used:  
*<project directory>/board/hspice*

To invoke the HSPICE Writer tool through the command line, enter the syntax shown in [Example 12-3](#).

---

#### **Example 12-3.**

```
quartus_edu.exe <project_name> --board_signal_integrity=on --format=SPICE \
--output_directory=<output_directory>
```

---

*<output\_directory>* specifies the location where the generated spice decks will be written (relative to the design directory). This is an optional parameter and defaults to **board/hspice**.

### *Customizing Automatically Generated HSPICE Decks*

HSPICE models generated by the HSPICE Writer can be used for simulation as generated. A default board description is included, and a default simulation is set up to measure rise and fall delays for both input and output simulations, which compensates for the double counting problem. However, Altera recommends that you customize the board description to more accurately represent your routing and termination scheme. To do this, open the generated HSPICE model files for all pins you want to simulate, and locate the following commented section.

The sample board trace loading must be replaced by your actual trace model before you can run a correct simulation. The section of the file that must be modified is indicated in the comment block shown in [Example 12-4](#).

---

#### ***Example 12-4.***

- \* I/O Board Trace and Termination Description
  - \* - Replace this with your board trace and termination description
- 

You must replace the example load with a load that matches the design of your PCB board. This includes a trace model, termination resistors, and, for output simulations, a receiver model. The spice circuit node that represents the pin of the FPGA package is called **pin**. The node that represents the far pin of the external device is called **load-in** (for output SPICE decks) and **source-in** (for input SPICE decks).

For an input simulation, you must also modify the stimulus portion of the spice file. The section of the file that must be modified is indicated in the comment block shown in [Example 12-5](#).

---

#### ***Example 12-5.***

- \* Sample source stimulus placeholder
  - \* - Replace this with your I/O driver model
- 

Replace the sample stimulus model with a model for the device that will drive the FPGA.

## Running an HSPICE Simulation

Because simulation parameters are configured directly in the HSPICE model files, running a simulation requires only that you open an HSPICE file in the HSPICE user interface and start the simulation. The HSPICE user interface window is shown in Figure 12-14.

Figure 12-14. HSPICE User Interface Window



Click **Open** and browse to the location of the HSPICE model files generated by the Quartus II HSPICE Writer. The default location for HSPICE model files is *<project directory>/board/hspice*. Select the **.sp** file generated by the HSPICE Writer for the signal you want to simulate. Click **OK**.

To run the simulation, click **Simulate**. The status of the simulation is displayed in the window and saved in an **.lis** file with the same name as the **.sp** file when the simulation is complete. Check the **.lis** file if an error occurs during the simulation requiring a change in the **.sp** file to fix.

## Interpreting the Results of an Output Simulation

By default, the automatically generated output simulation spice decks are set up to measure three delays for both rising and falling transitions. Two of the measurements, **tpd\_rise** and **tpd\_fall**, measure the double-counting corrected delay from the FPGA pin to the load pin. To determine the complete clock-edge to load-pin delay, add these numbers to the Quartus II software reported default loading  $T_{co}$  delay.

The remaining four measurements, `tpd_uncomp_rise`, `tpd_uncomp_fall`, `t_dblcnt_rise`, and `t_dblcnt_fall`, are required for the double-counting compensation process and are not needed for further timing usage. Refer to “[Simulation Analysis](#)” on page [12-43](#) for a description of these measurements.

## Interpreting the Results of an Input Simulation

By default, the automatically generated input simulation SPICE decks are set up to measure delays from the source’s driver pin to the FPGA’s input pin for both rising and falling transitions. The propagation delay is reported by HSPICE measure statements as `tpd_rise` and `tpd_fall`. To determine the complete source driver pin-to-FPGA register delay, add these numbers to the Quartus II software reported  $T_h$  and  $T_{su}$  input timing numbers.

## Viewing and Interpreting Tabular Simulation Results

The `.lis` file stores the collected simulation data in tabular form. The default simulation configured by the HSPICE Writer produces delay measurements for rising and falling transitions on both input and output simulations. These measurements are found in the `.lis` file and named `tpd_rise` and `tpd_fall`. For output simulations, these values are already adjusted for the double count. To determine the complete delay from the FPGA logic to the load pin, add either of these measurements to the Quartus II  $t_{CO}$  delay. For input simulations, add either of these measurements to the Quartus II  $t_{SU}$  and  $t_H$  delay values to calculate the complete delay from the far end stimulus to the FPGA logic. Other values found in the `.lis` file, such as `tpd_uncomp_rise`, `tpd_uncomp_fall`, `t_dblcnt_rise`, and `t_dblcnt_fall`, are parts of the double count compensation calculation. These values are not necessary for further analysis.

## Viewing Graphical Simulation Results

You can view the results of the simulation quickly as a graphical waveform display using the AvanWaves viewer included with HSPICE. With the default simulation configured by the HSPICE Writer, you can view the simulated waveforms at both the source and destination in input and output simulations.

To see the waveforms for the simulation, in the HSPICE user interface window, click **AvanWaves**. The AvanWaves viewer opens and displays the **Results Browser** as shown in [Figure 12-15](#).

Figure 12–15. HSPICE AvanWaves Results Browser



The **Results Browser** lets you select which waveform to view quickly in the main viewing window. If multiple simulations are run on the same signal, the list at the top of the **Results Browser** displays the results of each simulation. Click the simulation description to select which simulation to view. By default, the descriptions are derived from the first line of the HSPICE file, so the description may appear as a line of asterisks.

Select the type of waveform to view.

1. To see the source and destination waveforms with the default simulation, from the **Types** list, select **Voltages**.
2. On the **Curves** list, double-click the waveform you want to view. The waveform appears in the main viewing window.

You can zoom in and out and adjust the view as desired (Figure 12–16).

**Figure 12–16. AvanWaves Waveform Viewer**



## Making Design Adjustments Based on HSPICE Simulations

Based on the results of your simulations, you can make adjustments to the I/O assignments or simulation parameters if required. For example, after you run a simulation and see overshoot or ringing in the simulated signal at the destination buffer as shown in the example in Figure 12–17, you can adjust the drive strength I/O assignment setting to a lower value. Regenerate the HSPICE deck, and run the simulation again to verify that the change fixed the problem.

**Figure 12–17. Example of Overshoot in the AvanWaves Waveform Viewer**

If there is a discontinuity or any other anomalies at the destination as shown in the example in [Figure 12–18](#), adjust the board description in the Quartus II Board Trace Model (for Stratix II or Cyclone III devices) or in the generated HSPICE model files to change the termination scheme or adjust termination component values. After making these changes, regenerate the HSPICE files if necessary, and rerun the simulation to verify whether your adjustments solved the problem.

**Figure 12–18. Example of Signal Integrity Anomaly in the AvanWaves Waveform Viewer**



For more information about board-level signal integrity and to learn about ways to improve it with simple changes to your FPGA design, refer to the [Altera Signal Integrity Center](#).

### Sample Input for I/O HSPICE Simulation Deck

The following sections examine a typical HSPICE simulation spice deck for an I/O of type input. Each section presents the simulation file one block at a time.

#### *Header Comment*

The first block of an input simulation spice deck is the header comment. The purpose of this block is to provide an easily readable summary of how the simulation file has been automatically configured by the Quartus II software.

This block has two main components: The first component summarizes the I/O configuration relevant information such as device, speed grade, and so on. The second component specifies the exact test condition that the Quartus II software assumes for the given I/O standard.

**Example 12-6** shows a header comment block.

---

**Example 12-6.**

```
* Quartus II HSPICE Writer I/O Simulation Deck*
* This spice simulation deck was automatically generated by
* Quartus for the following IO settings:
*
* Device: EP2S60F1020C3
* Speed Grade: C3
* Pin: AA4 (out96)
* Bank: IO Bank 6 (Row I/O)
* I/O Standard: LVTTI, 12mA
* OCT: Off
*
* Quartus II's default I/O timing delays assume the following slow
* corner simulation conditions.
*
* Specified Test Conditions For Quartus II Tco
* Temperature: 85C (Slowest Temperature Corner)
* Transistor Model: TT (Typical Transistor Corner)
* Vccn: 3.135V (Vccn_min = Nominal - 5%)
* Vccpd: 2.97V (Vccpd_min = Nominal - 10%)
* Load: No Load
* Vtt: 1.5675V (Voltage reference is Vccn/2)
*
* Note: The I/O transistors are specified to operate at least as
* fast as the TT transistor corner, actual production
* devices can be as fast as the FF corner. Any simulations
* for hold times should be conducted using the fast process
* corner with the following simulation conditions.
* Temperature: 0C (Fastest Commercial Temperature Corner **)
* Transistor Model: FF (Fastest Transistor Corner)
* Vccn: 1.98V (Vccn_hold = Nominal + 10%)
* Vccpd: 3.63V (Vccpd_hold = Nominal + 10%)
* Vtt: 0.95V (Vtt_hold = Vccn/2 - 40mV)
* Vcc: 1.25V (Vcc_hold = Maximum Recommended)
* Package Model: Short-circuit from pad to pin (no parasitics)
*
* Warnings:
```

---

### Simulation Conditions

The simulation conditions block loads the appropriate process corner models for the transistors. This condition is automatically set up for the slow timing corner and is modified only if other simulation corners are desired. [Example 12-7](#) shows a simulation conditions block.

---

#### **Example 12-7.**

\* Process Settings

```
.options brief
.inc 'sii_tt.inc' * TT process corner
```

---

### Simulation Options

The simulation options block configures the simulation temperature and configures HSPICE with typical simulation options. [Example 12-8](#) shows a simulation options block.



For a detailed description of these options consult your *HSPICE* manual.

---

#### **Example 12-8.**

\* Simulation Options

```
.options brief=0
.options badchr co=132 scale=1e-6 acct ingold=2 nomod dv=1.0
+           dcstep=1 absv=1e-3 absi=1e-8 probe csdf=2 accurate=1
+           converge=1
.temp 85
```

---

### Constant Definition

The constant definition block of the simulation file instantiates the voltage sources that controls the configuration modes of the I/O buffer. [Example 12-9](#) shows a constant definition block.

---

#### **Example 12-9.**

\* Constant Definition

```
voeb      oeb      0      vc  * Set to 0 to enable buffer output
vopdrain  opdrain  0      0   * Set to vc to enable open drain
vrambh    rambh    0      0   * Set to vc to enable bus hold
vrpullup  rpullup  0      0   * Set to vc to enable weak pullup
vpcdp5    rpcdp5   0      rp5 * Set the IO standard
vpcdp4    rpcdp4   0      rp4
vpcdp3    rpcdp3   0      rp3
vpcdp2    rpcdp2   0      rp2
vpcdp1    rpcdp1   0      rp1
vpcdp0    rpcdp0   0      rp0
vpcdn4    rpcdn4   0      rn4
vpcdn3    rpcdn3   0      rn3
vpcdn2    rpcdn2   0      rn2
vpcdn1    rpcdn1   0      rn1
vpcdn0    rpcdn0   0      rn0
vdin     din      0      0
```

Where:

- Voltage source **voeb** controls the output enable of the buffer and is set to *disabled* for inputs.
  - **vopdrain** controls the open drain mode for the I/O.
  - **vrambh** controls the bus hold circuitry in the I/O.
  - **vrpullup** controls the weak pullup.
  - The next 11 voltages sources control the I/O standard of the buffer and are configured through a later library call.
  - **vdin** is not used on input pins as it is the data pin for the output buffer.
-

*Buffer Netlist*

The buffer netlist block ([Example 12-10](#)) of the simulation SPICE deck loads all the load models required for the corresponding input pin.

---

**Example 12-10.**

```
* IO Buffer Netlist  
.include 'vio_buffer.inc'
```

---

*Drive Strength*

The drive strength block ([Example 12-11](#)) of the simulation SPICE deck loads the configuration bits necessary to configure the I/O into the proper I/O standard and drive strengths. Although these settings are not relevant to an input buffer, they are provided to allow the SPICE deck to be modifiable to support bidirectional simulations.

---

**Example 12-11.**

```
* Drive Strength Settings  
.lib 'drive_select_hio.lib' 3p3ttl_12ma
```

---

*I/O Buffer Instantiation*

The I/O buffer instantiation block of the simulation SPICE deck instantiates the necessary power supplies and I/O model components that are necessary to simulate the given I/O.

Example 12-12 shows I/O buffer instantiation.

---

**Example 12-12.**

## I/O Buffer Instantiation

```
* Supply Voltages Settings
.param vcn=3.135
.param vpd=2.97
.param vc=1.15

* Instantiate Power Supplies|
vvcc      vcc      0      vc      * FPGA core voltage
vvss      vss      0      0      * FPGA core ground
vvccn     vccn     0      vcn     * IO supply voltage
vvssn     vssn     0      0      * IO ground
vvccpd    vccpd    0      vpd     * Pre-drive supply voltage

* Instantiate I/O Buffer
xvio_buf din oeb opdrain die rambh
+ rpcdn4 rpcdn3 rpcdn2 rpcdn1 rpcdn0
+ rpcdp5 rpcdp4 rpcdp3 rpcdp2 rpcdp1 rpcdp0
+ rpullup vccn vccpd vcpad0 vio_buf

* Internal Loading on Pad
* - No loading on this pad due to differential buffer/support
*   circuitry

* I/O Buffer Package Model
* - Single-ended I/O standard on a Row I/O
.lib 'lib/package.lib' hio
xpkg die pin hio_pkg
```

---

### *Board Trace and Termination*

The board trace and termination block of the simulation SPICE deck is provided only as an example, (shown in [Example 12-13](#)). Replace this block with your own board trace and termination models.

---

#### **Example 12-13.**

- \* I/O Board Trace and Termination Description
- \* - Replace this with your board trace and termination description

```
wtline pin vssn load vssn N=1 L=1 RLGCMODEL=tlinemodel
.MODEL tlinemodel W MODELTYPE=RLGC N=1 Lo=7.13n Co=2.85p
Rterm2 load vssn 1x
```

---

### *Stimulus Model*

The stimulus model block of the simulation spice deck is provided only as a place holder example (shown in [Example 12-14](#)). Replace this block with your own stimulus model. Options for this include an IBIS or HSPICE model, among others.

---

#### **Example 12-14.**

- \* Sample source stimulus placeholder
- \* - Replace this with your I/O driver model

```
Vsource source 0 pulse(0 vcn 0s 0.4ns 0.4ns 8.5ns 17.4ns)
```

---

### *Simulation Analysis*

The simulation analysis block ([Example 12-15](#)) of the simulation file is configured to measure the propagation delay from the source to the FPGA pin. Both the source and end point of the delay are referenced against the 50%  $V_{CCN}$  crossing point of the waveform.

---

**Example 12-15.**

```
* Simulation Analysis Setup

* Print out the voltage waveform at both the source and the pin
.print tran v(source) v(pin)
.tran 0.020ns 17ns

* Measure the propagation delay from the source pin to the pin
* referenced against the 50% voltage threshold crossing point

.measure TRAN tpd_rise TRIG v(source) val='vcn*0.5' rise=1
+ TARG v(pin) val ='vcn*0.5' rise=1
.measure TRAN tpd_fall TRIG v(source) val='vcn*0.5' fall=1
+ TARG v(pin) val ='vcn*0.5' fall=1
```

---

## Sample Output for I/O HSPICE Simulation Deck

The following sections examine a typical HSPICE simulation SPICE deck for an I/O-type output. Each section presents the simulation file one block at a time.

### *Header Comment*

The first block of an output simulation SPICE deck is the header comment, as shown in [Example 12-16](#). The purpose of this block is to provide a readable summary of how the simulation file has been automatically configured by the Quartus II software.

This block has two main components: The first component summarizes the I/O configuration relevant information such as device, speed grade, and so on; the second component specifies the exact test condition that the Quartus II software assumes when generating  $t_{co}$  delay numbers. This information is used as part of the double-counting correction circuitry contained in the simulation file.

The SPICE decks are preconfigured to calculate the slow process corner delay but can also be used to simulate the fast process corner as well. The fast corner conditions are listed in the header under the notes section.

---

The final section of the header comment lists any warning messages that you must consider when you use the SPICE decks.

---

**Example 12-16.**

```

* Quartus II HSPICE Writer I/O Simulation Deck
*
* This spice simulation deck was automatically generated by
* Quartus II for the following IO settings:
*
* Device: EP2S60F1020C3
* Speed Grade: C3
* Pin: AA4 (out96)
* Bank: IO Bank 6 (Row I/O)
* I/O Standard: LVTTL, 12mA
* OCT: Off
*
* Quartus' default I/O timing delays assume the following slow
* corner simulation conditions.
* Specified Test Conditions For Quartus II Tco
* Temperature: 85C (Slowest Temperature Corner)
* Transistor Model: TT (Typical Transistor Corner)
* Vccn: 3.135V (Vccn_min = Nominal - 5%)
* Vccpd: 2.97V (Vccpd_min = Nominal - 10%)
* Load: No Load
* Vtt: 1.5675V (Voltage reference is Vccn/2)
* For C3 devices, the TT transistor corner provides an
* approximation for worst case timing. However, for functionality
* simulations, it is recommended that the SS corner be simulated
* as well.
*
* Note: The I/O transistors are specified to operate at least as
* fast as the TT transistor corner, actual production
* devices can be as fast as the FF corner. Any simulations
* for hold times should be conducted using the fast process
* corner with the following simulation conditions.
* Temperature: 0C (Fastest Commercial Temperature Corner
**)
* Transistor Model: FF (Fastest Transistor Corner)
* Vccn: 1.98V (Vccn_hold = Nominal + 10%)
* Vccpd: 3.63V (Vccpd_hold = Nominal + 10%)
* Vtt: 0.95V (Vtt_hold = Vccn/2 - 40mV)
* Vcc: 1.25V (Vcc_hold = Maximum Recommended)
* Package Model: Short-circuit from pad to pin
* Warnings:

```

---

### Simulation Conditions

The simulation conditions block ([Example 12-17](#)) loads the appropriate process corner models for the transistors. This condition is automatically set up for the slow timing corner and must be modified only if other simulation corners are desired.



When simulating other corners, make sure the simulation conditions for the double-counting correction circuitry are not accidentally changed as well.

---

#### **Example 12-17.**

\* Process Settings

```
.options brief
.inc 'sii_tt.inc' * typical-typical process corner
```

---

### Simulation Options

The simulation options block ([Example 12-18](#)) configures the simulation temperature and configures HSPICE with typical simulation options.



For a detailed description of these options, consult your *HSPICE* manual.

---

#### **Example 12-18.**

\* Simulation Options

```
.options brief=0
.options badchr co=132 scale=1e-6 acct ingold=2 nomod dv=1.0
+      dcstep=1 absv=1e-3 absi=1e-8 probe csdf=2 accurate=1
+      converge=1
.temp 85
```

---

### Constraint Definition

The constant definition block (Example 12-19) of the output simulation SPICE deck instantiates the voltage sources that controls the configuration modes of the I/O buffer.

---

#### Example 12-19.

##### \* Constant Definition

```

voeb      oeb      0      0 * Set to 0 to enable buffer output
vopdrain  opdrain  0      0 * Set to vc to enable open drain
vrambh    rambh    0      0 * Set to vc to enable bus hold
vrpullup  rpullup  0      0 * Set to vc to enable weak pullup
vpcdp4    rpcdp4   0      rp4  * These control bits set the IO standard
vpcdp3    rpcdp3   0      rp3
vpcdp2    rpcdp2   0      rp2
vpcdp1    rpcdp1   0      rp1
vpcdp0    rpcdp0   0      rp0
vpcdn4    rpcdn4   0      rn4
vpcdn3    rpcdn3   0      rn3
vpcdn2    rpcdn2   0      rn2
vpcdn1    rpcdn1   0      rn1
vpcdn0    rpcdn0   0      rn0
vdin      din      0      pulse(0 vc 0s 0.2ns 0.2ns 8.5ns 17.4ns)

```

Where:

- Voltage source **voeb** controls the output enable of the buffer.
  - **vopdrain** controls the open drain mode for the I/O.
  - **vrambh** controls the bus hold circuitry in the I/O.
  - **vrpullup** controls the weak pullup.
  - The next 10 voltage sources control the I/O standard of the buffer and are configured through a later library call.
  - **vdin** is connected to the data input of the I/O buffer.
  - The edge rate of the input stimulus is automatically set to the correct value by the Quartus II software.
-

*I/O Buffer Netlist*

The buffer netlist block (Example 12-20) loads all of the models required for the corresponding pin. These include a model for the I/O output buffer, as well as any loads that may be present on the pin.

---

**Example 12-20.**

\*IO Buffer Netlist

```
.include 'hio_buffer.inc'  
.include 'lvds_input_load.inc'  
.include 'lvds_oct_load.inc'
```

---

*Drive Strength*

The drive strength block (Example 12-21) of the simulation spice deck loads the configuration bits for configuring the I/O to the proper I/O standard and drive strength. These options are set by the HSPICE Writer tool and are not changed for expected use.

---

**Example 12-21.**

\* Drive Strength Settings

```
.lib 'drive_select_hio.lib' 3p3ttl_12ma
```

---

### I/O Buffer Instantiation

The I/O buffer instantiation block ([Example 12-22](#)) of the output simulation spice deck instantiates the necessary power supplies and I/O model components that are necessary to simulate the given I/O.

---

#### **Example 12-22.**

```

* I/O Buffer Instantiation

* Supply Voltages Settings
.param vcn=3.135
.param vpd=2.97
.param vc=1.15

* Instantiate Power Supplies
vvcc      vcc      0      vc      * FPGA core voltage
vvss      vss      0      0      * FPGA core ground
vvccn     vccn     0      vcn     * IO supply voltage
vvssn     vssn     0      0      * IO ground
vvccpd    vccpd    0      vpd     * Pre-drive supply voltage

* Instantiate I/O Buffer
xhio_buf din oeb opdrain die rambh
+ rpcdn4 rpcdn3 rpcdn2 rpcdn1 rpcdn0
+ rpcdp4 rpcdp3 rpcdp2 rpcdp1 rpcdp0
+ rpullup vccn vccpd vcpad0 hio_buf

* Internal Loading on Pad
* - This pad has an LVDS input buffer connected to it, along
*   with differential OCT circuitry. Both are disabled but
*   introduce loading on the pad that is modeled below.
xlvds_input_load die vss vccn lvds_input_load
xlvds_oct_load die vss vccpd vccn vcpad0 vccn lvds_oct_load

* I/O Buffer Package Model
* - Single-ended I/O standard on a Row I/O
.lib 'lib/package.lib' hio
xpkg die pin hio_pkg

```

---

### *Board and Trace Termination*

The board trace and termination block ([Example 12-23](#)) of the simulation SPICE deck is provided only as an example. Replace this block with your specific board loading models.

---

#### **Example 12-23.**

\* I/O Board Trace And Termination Description  
\* - Replace this with your board trace and termination description

```
wtline pin vssn load vssn N=1 L=1 RLGCMODEL=tlinemodel
.MODEL tlinemodel W MODELTYPE=RLGC N=1 Lo=7.13n Co=2.85p
Rterm2 load vssn 1x
```

---

### *Double-Counting Compensation Circuitry*

The double-counting compensation circuitry block ([Example 12-24](#)) of the simulation SPICE deck instantiates a second I/O buffer that is used to measure double-counting. The buffer is configured identically to the user I/O buffer but is connected to the Quartus II software test load. The simulated delay of this second buffer can be interpreted as the amount of double-counting between the Quartus II software and HSPICE Writer simulated results.

As the amount of double-counting is constant for a given I/O standard on a given pin, consider separating the double-counting circuitry from the simulation file. In doing so, you can perform any number of I/O simulations while referencing the delay only once. For more information about the double-counting problem, refer to ["The Double Counting Problem in HSPICE Simulations"](#) on page 12-24

---

**Example 12-24.**

```

* Double Counting Compensation Circuitry
*
* The following circuit is designed to calculate the amount of
* double counting between Quartus II and the HSPICE models. If
* you have not changed the default simulation temperature or
* transistor corner the double counting will be automatically
* compensated by this spice deck. In the event you wish to
* simulate an IO at a different temperature or transistor corner
* you will need to remove this section of code and manually
* account for double counting. A description of Altera's
* recommended procedure for this process can be found in the
* Quartus II HSPICE Writer AppNote.
*

* Supply Voltages Settings
.param vcn_t1=3.135
.param vpd_t1=2.97

* Test Load Constant Definition
vopdrain_t1    opdrain_t1    0      0
vrambh_t1      rambh_t1      0      0
vrvpullup_t1   rpullup_t1   0      0

* Instantiate Power Supplies
vvccn_t1        vccn_t1        0      vcn_t1
vvssn_t1        vssn_t1        0      0
vvccpd_t1       vccpd_t1       0      vpd_t1

* Instantiate I/O Buffer
xhio_testload din oeb opdrain_t1 die_t1 rambh_t1
+ rpcdn4 rpcdn3 rpcdn2 rpcdn1 rpcdn0
+ rpcdp4 rpcdp3 rpcdp2 rpcdp1 rpcdp0
+ rpullup_t1 vccn_t1 vccpd_t1 vcpad0_t1 hio_buf

* Internal Loading on Pad
xlvds_input_testload die_t1 vss vccn_t1 lvds_input_load
xlvds_oct_testload die_t1 vss vccpd_t1 vccn_t1 vcpad0_t1 vccn_t1
lvds_oct_load

* I/O Buffer Package Model
* - Single-ended I/O standard on a Row I/O
.lib 'lib/package.lib' hio
xpkg die pin hio_pkg

* Default Altera Test Load
* - 3.3V LVTTL default test condition is an open load

```

---

### *Simulation Analysis*

The simulation analysis block ([Example 12-25](#)) is set up to measure double-counting corrected delays. This is accomplished by measuring the uncompensated delay of the I/O buffer when connected to the user load, and when subtracting the simulated amount of double-counting from the test load I/O buffer.

---

#### **Example 12-25.**

##### \*Simulation Analysis Setup

```
* Print out the voltage waveform at both the pin and far end load
.print tran v(pin) v(load)
.tran 0.020ns 17ns

* Measure the propagation delay to the load pin. This value will
* include some double counting with Quartus II's Tco
.measure TRAN tpd_uncomp_rise TRIG v(din) val='vc*0.5' rise=1
+ TARG v(load) val='vcn*0.5' rise=1
.measure TRAN tpd_uncomp_fall TRIG v(din) val='vc*0.5' fall=1
+ TARG v(load) val='vcn*0.5' fall=1

* The test load buffer can calculate the amount of double counting
.measure TRAN t_dblcnt_rise TRIG v(din) val='vc*0.5' rise=1
+ TARG v(pin_t1) val='vcn_t1*0.5' rise=1
.measure TRAN t_dblcnt_fall TRIG v(din) val='vc*0.5' fall=1
+ TARG v(pin_t1) val='vcn_t1*0.5' fall=1

* Calculate the true propagation delay by subtraction
.measure TRAN tpd_rise PARAM='tpd_uncomp_rise-t_dblcnt_rise'
.measure TRAN tpd_fall PARAM='tpd_uncomp_fall-t_dblcnt_fall'
```

---

## **Advanced Topics**

The information in this section describes some of the more advanced topics and methods employed when setting up and running HSPICE simulation files.

### *PVT Simulations*

The automatically generated HSPICE simulation files are set up to simulate the slow process corner using low voltage, high temperature, and slow transistors. To ensure a fully robust link, Altera recommends that you run simulations over all process corners.

To perform process, voltage, and temperature (PVT) simulations, manually modify the spice decks in a two step process:

1. Remove the double-counting compensation circuitry from the simulation file. This is required as the amount of double-counting is dependant upon how the Quartus II software calculates delays and is not based on which PVT corner is being simulated. By default, the Quartus II software provides timing numbers using the slow process corner.
2. Select the proper corner for the PVT simulation by setting the correct HSPICE temperature, changing the supply voltage sources, and loading the correct transistor models.

A more detailed description of HSPICE process corners can be found in the family-specific HSPICE model documentation. This document is available online with the HSPICE models as described in [“Accessing HSPICE Simulation Kits” on page 12-23](#).

### *Hold Time Analysis*

Altera recommends performing worst-case hold time analysis using the fast corner models, which use fast transistors, high voltage, and low temperature. This involves modifying the SPICE decks to select the correct temperature option, change the supply voltage sources, and load the correct fast transistor models. The values of these parameters are located in the header comment section of the corresponding simulation deck files.

For a truly worst-case analysis, combine the HSPICE Writer hold time analysis results with the Quartus II software fast timing model. This requires that you change the double-counting compensation circuitry in the simulations files to also simulate the fast process corners, as this is what the Quartus II software uses for the fast timing model.



This method of hold time analysis is recommended only for globally synchronous buses. Do not apply this method of hold-time analysis to source synchronous buses. This is because the source synchronous clocking scheme is designed to cancel out some of the PVT timing effects. If this is not taken into account, the timing results will not be accurate. Proper source synchronous timing analysis is beyond the scope of this document.

### *I/O Voltage Variations*

Use each of the FPGA family datasheets to verify the recommended operating conditions for supply voltages. For current FPGA families, the maximum recommended voltage corresponds to the fast corner, while the minimum recommended voltage corresponds to the slow corner. These voltage recommendations are specified at the power pins of the FPGA and are not necessarily the same voltage that are seen by the I/O buffers due to package IR drops.

The automatically generated HSPICE simulation files model this IR effect pessimistically by including a 50-mV IR drop on the  $V_{CCPD}$  supply when a high drive strength standard is being used.

### *Correlation Report*

Correlation reports for the HSPICE I/O models are located in the family-specific HSPICE I/O buffer simulation kits. Refer to “[Accessing HSPICE Simulation Kits](#)” on page 12–23 for additional information.

## Conclusion

As FPGA devices are used in more high-speed applications, it becomes increasingly necessary to perform board-level signal integrity analysis simulations. You must run such simulations to ensure good signal integrity between the FPGA and any connected devices. The Quartus II software helps to simplify this process with the ability to automatically generate I/O buffer description models easily with the IBIS and HSPICE Writers. IBIS models can be integrated into a third-party signal integrity analysis workflow using a tool such as Mentor Graphics HyperLynx software, generating quick and accurate simulation results. HSPICE decks include preconfigured simulations and only require descriptions of board routing and stimulus models to create highly accurate simulation results using Synopsys HSPICE. Either type of simulation helps prevent unnecessary board spins, increasing your productivity and decreasing your costs.

## Referenced Documents

This chapter references the following documents:

- [AN 283: Simulating Altera Devices with IBIS Models](#)
- [AN 315: Guidelines for Designing High-Speed FPGA PCBs](#)
- [I/O Management chapter in volume 2 of the Quartus II Handbook](#)
- [Quartus II Handbook](#)

# Document Revision History

Table 12–3 shows the revision history for this chapter.

| <b>Table 12–3. Document Revision History</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                           |
|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| <b>Date and Document Version</b>             | <b>Changes Made</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | <b>Summary of Changes</b>                 |
| May 2008<br>v8.0.0                           | <ul style="list-style-type: none"> <li>● Updated “Introduction” on page 12–1.</li> <li>● Updated Figure 12–1.</li> <li>● Updated Figure 12–3.</li> <li>● Updated Figure 12–13.</li> <li>● Updated “Output File Generation” on page 12–7.</li> <li>● Updated “Simulation with HSPICE Models” on page 12–22.</li> <li>● Updated “Invoking HSPICE Writer from the Command Line” on page 12–30.</li> <li>● Added “Sample Input for I/O HSPICE Simulation Deck” on page 12–37.</li> <li>● Added “Sample Output for I/O HSPICE Simulation Deck” on page 12–44.</li> <li>● Updated “Correlation Report” on page 12–54.</li> <li>● Added hyperlinks to referenced documents and websites throughout the chapter.</li> <li>● Made minor editorial updates.</li> </ul> | Updated for Quartus software version 8.0. |
| October 2007<br>v7.2.0                       | Reorganized “Referenced Documents” on page 3–51.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | —                                         |
| May 2007<br>v7.1.0                           | Added Referenced Documents.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | —                                         |
| March 2007<br>v7.0.0                         | Updated Quartus II software 7.0 revision and date only. No other changes made to chapter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | —                                         |
| November 2006<br>v6.1.0                      | Initial Release                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | —                                         |



### Introduction

Debugging today's FPGA designs can be a daunting task. As your product requirements continue to increase in complexity, the time you spend on design verification continues to rise. To get your product to market as quickly as possible, you must minimize design verification time. To help alleviate the time-to-market pressure, you need a set of verification tools that are powerful, yet easy to use.

The Quartus® II software provides a portfolio of in-system design debugging tools for real-time verification of your design. Each tool in the on-chip debugging portfolio uses a combination of available memory, logic, and routing resources to assist in the debugging process. The tools provide visibility by routing (or "tapping") signals in your design to debugging logic. The debugging logic is then compiled with your design and downloaded into the FPGA or CPLD for analysis. Because different designs may have different constraints and requirements, such as the number of spare pins available or the amount of logic or memory resources remaining in the physical device, you can choose a tool from the available debugging tools that matches the specific requirements for your design.

This section provides a quick overview on the tools available in the on-chip debugging suite and discusses the criteria for selecting the best tool for your design.

# On-Chip Debugging Ecosystem

Table 13–1 summarizes the tools in the In-System verification tool suite that are covered in this section of the *Quartus II Handbook*.

**Table 13–1. Available Tools in the In-System Verification Tools Suite**

| Tool                                   | Description                                                                                                                                                                        | Typical Circumstances of Use                                                                                                                                                                                                                                     |
|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SignalTap® II Logic Analyzer</b>    | This embedded logic analyzer uses FPGA resources to sample test nodes and outputs the information to the Quartus II software for display and analysis.                             | You have spare on-chip memory and you want functional verification of your design running in hardware.                                                                                                                                                           |
| <b>SignalProbe</b>                     | This tool incrementally routes internal signals to I/O pins while preserving results from your last place-and-routed design.                                                       | You have spare I/O pins and you would like to check the operation of a small set of control pins using either an external Logic Analyzer or an Oscilloscope.                                                                                                     |
| <b>Logic Analyzer Interface (LAI)</b>  | This tool multiplexes a larger set of signals to a smaller number of spare I/O pins. LAI allows you to select which signals are switched onto the I/O pins over a JTAG connection. | You have limited on-chip memory, and have a large set of internal data buses that you would like to verify using an external Logic Analyzer. Logic Analyzer vendors, such as Tektronics and Agilent, provide integration with the tool to improve the usability. |
| <b>In-System Memory Content Editor</b> | This tool displays and allows you to edit on-chip memory.                                                                                                                          | You would like to view and edit the contents of the either the instruction cache or data cache of a Nios® II processor application.                                                                                                                              |
| <b>In-System Sources and Probes</b>    | This feature provides an easy way to drive and sample logic values to and from internal nodes using the JTAG interface.                                                            | You want to prototype a front panel with virtual buttons for your FPGA design.                                                                                                                                                                                   |
| <b>Virtual JTAG Interface</b>          | This megafunction opens up the JTAG interface so that you can develop your own custom applications.                                                                                | You want to generate a large set of test vectors and send them to your device over the JTAG port to functionally verify your design running in hardware.                                                                                                         |

With the exception of SignalProbe, each of the on-chip debugging tools uses the JTAG port to control and read back data from debugging logic and signals under test. The JTAG resource is shared among all of the on-chip debugging tools. The Quartus II software compiles logic into your design automatically to distinguish between data and control information and each of the debugging logic blocks when the JTAG resource is required. This arbitration logic, also known as the System-Level Debugging (SLD) infrastructure, is shown in the design hierarchy of your compiled project as `sld_hub:sld_hub_inst`. The SLD logic allows you to instantiate multiple debugging blocks into your design and run them simultaneously.

To maximize debugging closure, the Quartus II software allows you to use a combination of the debugging tools in tandem to fully exercise and analyze the logic under test. All of the tools described in [Table 13–1](#) have basic analysis features built in; that is, all of the tools enable you to read back information collected from the design nodes that are connected to the debugging logic. Out of the set of debugging tools, the SignalTap II Logic Analyzer, the LAI, and the SignalProbe feature are general-purpose debugging tools optimized for probing signals in your RTL netlist. In-System Sources and Probes, the Virtual JTAG Interface, and In-System Memory content editor, in addition to being able to read back data from the debugging points, allow you to input values into your design during runtime. Taken together, the set of on-chip debugging tools form a debugging ecosystem. The set of tools can generate a stimulus to and solicit a response from the logic under test, providing a complete debugging solution ([Figure 13–1](#)).

**Figure 13–1. Quartus II Debugging Ecosystem** [Note \(1\)](#)



**Note to Figure 13–1:**

- (1) The set of debugging tools offer end-to-end debugging coverage.

The tools in the toolchain offer different advantages and different trade-offs. To understand the selection criteria between the different tools, the following sections analyze the tools according to their typical applications.

The first section, “[Analysis Tools for RTL Nodes](#)”, compares the SignalTap II Logic Analyzer, SignalProbe, and the LAI. These three tools are logically grouped since they are intended for debugging nodes from your RTL netlist at system speed.

The next section, “[Stimulus-Capable Tools](#)” on page 13–ix, compares the In-System Memory Content Editor, Virtual JTAG Interface Megafunction, and In-System Sources and Probes. These tools are logically grouped since they offer the ability to both read and write transactions through the JTAG port.

## Analysis Tools for RTL Nodes

The SignalTap II Embedded Logic Analyzer, the SignalProbe feature, and the LAI are designed specifically for probing and debugging RTL signals at system speed. They are general-purpose analysis tools that enable you to tap and analyze any routable node from the FPGA or CPLD. These three tools satisfy a range of requirements. If you have spare logic and memory resources, the SignalTap II Logic Analyzer is useful for providing fast functional verification of your design running on actual hardware.

If, on the other hand, logic and memory resources are tight and you require the large sample depths associated with external logic analyzers, both the LAI and the SignalProbe feature make it easy to view internal design signals using external equipment.

The most important selection criteria for these three tools are the available resources remaining on your device after implementing your design and the number of spare pins available. It is worthwhile to evaluate your preferred debugging option early on in the design planning process to ensure that your board, your Quartus II project, and your design are all set up to support the appropriate options. Planning early can reduce time spent during debugging and eliminate the need to make changes later to accommodate your preferred debugging methodologies. The following two sections provide information to assist you in choosing the appropriate tool by comparing the tools according to their resource usage and their pin consumption.



The SignalTap II Logic Analyzer is not supported on CPLDs, because there are no memory resources available on these devices.

### *Resource Usage*

Any debugging tool that requires the use of a JTAG connection requires the SLD infrastructure logic mentioned earlier, for communication with the JTAG interface and arbitration between any instantiated debugging modules. This overhead logic uses around 200 LEs, a small fraction of the resources available in any of the supported devices. The overhead logic is shared between all available debugging modules in your design. Both the SignalTap II Logic Analyzer and the LAI use a JTAG connection.

SignalProbe requires very few on-chip resources. Because it requires no JTAG connection, SignalProbe uses no logic or memory resources—it uses only routing resources to route an internal signal to a debugging test point.

The LAI requires a small amount of logic to implement the multiplexing function between the signals under test, in addition to the SLD infrastructure logic. Because no data samples are stored on the chip, the LAI uses no memory resources.

The SignalTap II Logic Analyzer requires both logic and memory resources. The number of logic resources used depends on the number of signals tapped and the complexity of the trigger logic. However, the amount of Logic Resources that the SignalTap II Logic Analyzer uses is typically a small percentage of most designs. A baseline configuration consisting of the SLD arbitration logic and a single node with basic triggering logic contains approximately 300–400 logic elements (LEs). Each additional node you add to the baseline configuration adds about 11 LEs. Compared with logic resources, memory resources is a more important factor to consider for your design. Memory usage can be significant and depends on how you configure your SignalTap II Logic Analyzer instance to capture data and the sample depth that your design requires for debugging. For the SignalTap II Logic Analyzer, there is the added benefit of requiring no external equipment, as all of the triggering logic and storage is on the chip.

Figure 13–2 shows a conceptual graph of the resource usage of the three analysis tools relative to each other.

**Figure 13–2. Resource Usage per Debugging Tool** Note (1)**Note to Figure 13–2:**

- (1) Though resource usage is highly dependent on the design, this graph provides a rough guideline for tool selection.

The resource estimation feature for the SignalTap II Logic Analyzer and the LAI allows you to quickly judge if enough on-chip resources are available before compiling the tool with your design. Figure 13–3 shows the resource estimation feature for the SignalTap II Logic Analyzer and the Logic Analyzer Interface.

**Figure 13–3. Resource Estimator****Pin Usage**

The ratio of the number of pins used to the number of signals tapped for the SignalProbe feature is one-to-one. Because this feature can consume free pins quickly, a typical application for this feature is for routing control signals to spare debugging pins for debugging.

The ratio of the number of pins used to the number of signals tapped for the LAI is many-to-one. It can map up to 256 signals to each debugging pin, depending on available routing resources. The control of the active signals that are mapped to the the spare I/O pins is performed via the JTAG port. The LAI is ideal for routing data buses to a set of test pins for analysis.

Other than the JTAG test pins, the SignalTap II Logic Analyzer uses no additional pins. All data is buffered using on-chip memory and communicated to the SignalTap II GUI via the JTAG test port.

### *Usability Enhancements*

The SignalTap II Embedded Logic Analyzer, the SignalProbe feature, and the LAI tools can be added to your existing design with minimal effects. Using the node finder, you can find signals to route to a debugging module without making any changes to your HDL. SignalProbe inserts signals directly from your post-fit database. The SignalTap II Logic Analyzer and LAI support inserting signals from both pre-synthesis and post-fit netlists. All three tools allow you to find and configure your debugging setup quickly. In addition, the Quartus II incremental compilation feature and the Quartus II incremental routing feature allow for a fast turnaround time for your programming file, increasing productivity and enabling fast debugging closure.

Both LAI and the SignalTap II Logic Analyzer support incremental compilation. With incremental compilation, you can add a SignalTap II Logic Analyzer instance or an LAI instance incrementally into your placed-and-routed design. This has the benefit of both preserving your timing and area optimizations from your existing design, and decreasing the overall compilation time when any changes are necessary during the debugging process. With incremental compilation, you can save up to 70% compile time of a full compilation.

SignalProbe uses the incremental routing feature. The incremental routing feature runs only the Fitter stage of the compilation. This also leaves your compiled design untouched, except for the newly routed node or nodes. With SignalProbe, you can save as much as 90% compile time of a full compilation.

As another productivity enhancement, all tools in the on-chip debugging tool set support scripting via the `quartus_stp` Tcl package. For the SignalTap II Logic Analyzer and the LAI, scripting enables user-defined automation for data collection while debugging in the lab.

In addition, the JTAG server allows you to debug a design that is running on a device attached to a PC in a remote location. This allows you to set up your hardware in the lab environment, download any new `.sof` files, and perform any analysis from your desktop.

Table 13–2 compares common debugging features between these tools and provides suggestions about which is the best tool to use for a given feature.

**Table 13–2. Suggested On-Chip Debugging Tools for Common Debugging Features Note (1) (Part 1 of 2)**

| Feature                                 | SignalProbe | Logic Analyzer Interface (LAI) | SignalTap II Logic Analyzer | Description                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------------|-------------|--------------------------------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Large Sample Depth</b>               | N/A         | ✓                              | —                           | An external logic analyzer used with the LAI has a bigger buffer to store more captured data than the SignalTap II Logic Analyzer. No data is captured or stored with SignalProbe.                                                                                                                                                  |
| <b>Ease in Debugging Timing Issue</b>   | ✓           | ✓                              | —                           | External equipment, such as Oscilloscopes and Mixed Signal Oscilloscopes (MSOs), can be used with either LAI or SignalProbe used with the LAI to provide you with access to timing mode, enabling you to debug combined streams of data.                                                                                            |
| <b>Minimal Effect on Logic Design</b>   | ✓           | ✓ (2)                          | ✓ (2)                       | The LAI adds minimal logic to a design, requiring fewer device resources. The SignalTap II Logic Analyzer has little effect on the design, as it is set as a separate design partition. SignalProbe incrementally routes nodes to pins, not affecting the design at all.                                                            |
| <b>Short Compile and Recompile Time</b> | ✓           | ✓ (2)                          | ✓ (2)                       | SignalProbe attaches incrementally routed signals to previously reserved pins, requiring very little recompilation time to make changes to source signal selections. The SignalTap II Logic Analyzer and the LAI can take advantage of incremental compilation to refit their own design partitions to decrease recompilation time. |
| <b>Triggering Capability</b>            | N/A         | N/A                            | ✓                           | The SignalTap II Logic Analyzer offers triggering capabilities that are comparable to commercial logic analyzers.                                                                                                                                                                                                                   |
| <b>I/O Usage</b>                        | —           | —                              | ✓                           | No additional output pins are required with the SignalTap II Logic Analyzer. Both the LAI and SignalProbe require I/O pin assignments.                                                                                                                                                                                              |

**Table 13–2. Suggested On-Chip Debugging Tools for Common Debugging Features Note (1) (Part 2 of 2)**

| Feature                        | SignalProbe | Logic Analyzer Interface (LAI) | SignalTap II Logic Analyzer | Description                                                                                                                                                                                                                                                                                                                                                                    |
|--------------------------------|-------------|--------------------------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Acquisition Speed              | N/A         | —                              | ✓                           | The SignalTap II Logic Analyzer can acquire data at speeds of over 200 MHz. The same acquisition speeds are obtainable with an external logic analyzer used with the LAI, but signal integrity issues may limit this.                                                                                                                                                          |
| No JTAG Connection Required    | ✓           | —                              | —                           | An FPGA design with the SignalTap II Logic Analyzer or the LAI requires an active JTAG connection to a host running the Quartus II software. SignalProbe does not require a host for debugging purposes.                                                                                                                                                                       |
| No External Equipment Required | —           | —                              | ✓                           | The SignalTap II Logic Analyzer logic is completely internal to the programmed FPGA device. No extra equipment is required other than a JTAG connection from a host running the Quartus II software or the stand-alone SignalTap II software. SignalProbe and the LAI require the use of external debugging equipment, such as multimeters, oscilloscopes, or logic analyzers. |

**Notes to Table 13–2:**

- (1) ✓ indicates the recommended tools for the feature.  
 — indicates that while the tool is available for that feature, that tool may not give the best results.  
 N/A indicates that the feature is not applicable for the selected tool.
- (2) When used with incremental compilation.

## Stimulus-Capable Tools

The In-System Memory Content Editor, the In-System Sources and Probes, and the Virtual JTAG interface each enable you to use the JTAG interface as a general-purpose communication port. Though all three tools can be used to achieve the same results, there are some considerations that make one tool easier to use in certain applications than others. In-System Sources and Probes is ideal for toggling control signals. The In-System Memory Content Editor is useful for inputting large sets of test data. Finally, the Virtual JTAG megafunction is well suited for more advanced users who want to develop their own customized JTAG solution.

### *In-System Sources and Probes*

In-System Sources and Probes is an easy way to access JTAG resources to both read and write to your design. You can start by instantiating a megafunction into your HDL. The megafunction contains source ports and probe ports for driving values into and sampling values from the signals that are connected to the ports, respectively. Transaction details of the JTAG interface are abstracted away by the megafunction. During runtime, a GUI displays each source and probe port by instance and allows you to read from each probe port and drive to each source port. The GUI makes this tool ideal for toggling a set of control signals during the debugging process.

A good application of In-System Sources and Probes is to use the GUI as a replacement for the push buttons and LEDs used during the development phase of a project. Furthermore, In-System Sources and Probes supports a set of scripting commands for reading and writing using `quartus_stp`. When used with the Tk toolkit, you can build your own graphical interfaces—a feature that is ideal for building a virtual front panel during the prototyping phase of the design.

### *In-System Memory Content Editor*

The In-System Memory Content Editor allows you to quickly view and modify memory contents either through a GUI interface or through Tcl scripting commands. The In-System Memory Content Editor works by turning single-port RAM blocks into dual-port RAM blocks. One port is connected to your clock domain and data signals, and the other port is connected to the JTAG clock and data signals for editing or viewing.

Because you can modify a large set of data easily, a useful application for the In-System Memory Content Editor is to generate test vectors for your design. For example, you can instantiate a free memory block, connect the output ports to the logic under test (using the same clock as your logic under test on the system side), and create the glue logic for the address generation and control of the memory. At runtime, you can modify the contents of the memory using either a script or the In-System Memory Content Editor GUI and perform a burst transaction of the data contents in the modified RAM block synchronous to the logic being tested.

### *Virtual JTAG Interface Megafunction*

The Virtual JTAG Interface megafunction provides the finest level of granularity for manipulating the JTAG resource. This megafunction allows you to build your own JTAG scan chain by exposing all of the JTAG control signals and configuring your JTAG Instruction Registers (IRs) and JTAG Data Registers (DRs). During runtime, you control the

IR/DR chain through a Tcl API. This feature is meant for users who have a thorough understanding of the JTAG interface and want precise control over the number and type of resources used.

## Conclusion

The Quartus II on-chip debugging tool suite allows you quickly reach debugging closure by providing you both a set of powerful analysis tools and a set of tools that open up the JTAG port as a general purpose communication interface. The Quartus II software further broadens the scope of applications by giving you a comprehensive Tcl/Tk API. With the Tcl/Tk API, you can not only increase the level of automation for all of the analysis tools, but you can also build virtual front panel applications quickly early in the prototyping phase.

In addition, all of the on-chip debugging tools have a tight integration with the rest of the productivity features within the Quartus II software. The incremental compile and incremental routing features enable a fast turnaround time for programming file generation. The cross-probing feature allows you to find and identify nodes quickly. The SignalTap II Logic Analyzer, when used with the TimeQuest Timing Analyzer, a best-in-class timing verification suite, allows for fast functional and timing verification.

This section contains the detailed usage for each of the On-Chip Debugging tools. This section contains the following chapters:

- *Quick Design Debugging Using SignalProbe*
- *Design Debugging Using the SignalTap II Embedded Logic Analyzer*
- *In-System Debugging Using External Logic Analyzers*
- *In-System Updating of Memory and Constants*
- *Design Debugging Using In-System Sources and Probes*

## Document Revision History

Table 13–3 shows the revision history for this chapter.

| <b>Table 13–3. Document Revision History</b> |                                                                                                                                                                                                              |                                                               |
|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| <b>Date and Document Version</b>             | <b>Changes Made</b>                                                                                                                                                                                          | <b>Summary of Changes</b>                                     |
| May 2008<br>v8.0.0                           | <ul style="list-style-type: none"> <li>● Significant re-write; entire text was updated</li> <li>● Added Table 13–1, Table 13–2, Table 13–3</li> <li>● Added Figure 13–1, Figure 13–2, Figure 13–3</li> </ul> | Updates made for the Quartus II software version 8.0 release. |



### Introduction

Hardware verification can be a lengthy and expensive process. The SignalProbe incremental routing feature helps reduce the hardware verification process and time-to-market for system-on-a-programmable-chip (SOPC) designs.

Easy access to internal device signals is important in design or debugging. The SignalProbe feature makes design verification more efficient by quickly routing internal signals to I/O pins without affecting the design. Starting with a fully routed design, you can select and route signals for debugging to either previously reserved or currently unused I/O pins.

You can use the SignalProbe feature with Arria™ GX, the Stratix® series, Cyclone® series, MAX® II, and APEX™ series device families.

This chapter is divided into two sections. If you are using the SignalProbe feature to debug your Stratix series, Cyclone series, and MAX II device, refer to [“Debugging Using the SignalProbe Feature” on page 13–1](#). If you are using the SignalProbe feature to debug your APEX series device, refer to [“Using SignalProbe with the APEX Device Family” on page 13–17](#).



The Quartus® II software provides a portfolio of on-chip debugging solutions. For an overview and comparison of all of the tools available in the Quartus II software on-chip debugging tool suite, refer to [Section V. In-System Design Debugging](#) in the *Quartus II Handbook*.

### Debugging Using the SignalProbe Feature

The SignalProbe feature allows you to reserve available pins and route internal signals to those reserved pins, while preserving the behavior of your design. SignalProbe is an effective debugging tool providing visibility into your FPGA.



This section describes the SignalProbe process for the Stratix series, Cyclone series, and MAX II device families. Using SignalProbe with APEX devices is described in [“Using SignalProbe with the APEX Device Family” on page 13–17](#). APEX devices do not support post-fit netlist changes made as engineering change orders (ECOs).

You can reserve pins for SignalProbe and assign I/O standards before or after a full compilation. Each SignalProbe-source to SignalProbe-pin connection is implemented as an ECO change that is applied to your netlist after a full compilation.

To route the internal signals to the device's reserved pins for SignalProbe, perform the following tasks:

1. Reserve the SignalProbe Pins, described on [page 13–2](#).
2. Perform a Full Compilation, described on [page 13–4](#).
3. Assign a SignalProbe Source, described on [page 13–4](#).
4. Add Registers to the Pipeline Path to SignalProbe Pin, described on [page 13–5](#).
5. Perform a SignalProbe Compilation, described on [page 13–7](#).
6. Analyze the Results of the SignalProbe Compilation, described on [page 13–8](#).
7. Generate the Programming File, described on [page 13–9](#).

## Reserve the SignalProbe Pins

You can reserve SignalProbe pins before or after compiling your design. Reserving SignalProbe pins before a compilation is optional. You can also reserve any unused I/Os of the device for SignalProbe pins after compilation. You can assign sources easily after reserving your SignalProbe pins. The sources for SignalProbe pins are the internal nodes and registers in the post-compilation netlist that you want to probe.



Although you can reserve SignalProbe pins using many features within the Quartus II software, including the Pin Planner and the Tcl interface, you should use the **SignalProbe Pins** dialog box to create and edit your SignalProbe pins.

To reserve an available package pin as a SignalProbe pin using the **SignalProbe Pins** dialog box, perform the following steps:

1. On the Tools menu, click **SignalProbe Pins**. The **SignalProbe Pins** dialog box appears ([Figure 13–1](#)). The SignalProbe pin name and I/O standard appear as the only fields that are editable if a place-and-route, or fit, has not been performed.

Figure 13–1. Reserving a SignalProbe Pin in the SignalProbe Pins Dialog Box



2. In the **Current and potential SignalProbe pins** list, click a pin from the **Number** column and type your SignalProbe pin name into the **Pin name** box.
3. Select an I/O standard from the **I/O standard** drop-down list.
4. Click **Add** to add the new SignalProbe pin or **Change** if you are editing a previously reserved pin for SignalProbe. (Figure 13–1 shows the dialog box editing a previously reserved pin; if you were adding a new SignalProbe pin, the **Add** button appears instead of the **Change** button.)
5. Click **OK**.

## Perform a Full Compilation

You must complete a full compilation to generate an internal netlist containing a list of internal nodes to probe to a SignalProbe output.

To perform a full compilation, on the processing menu, click **Start Compilation**.

## Assign a SignalProbe Source

A SignalProbe source can be any combinational node, register, or pin in your post-compilation netlist. To find a SignalProbe source, use the SignalProbe filter in the Node Finder to filter out all sources that cannot be probed. You may not be able to find a particular internal node because the node may be optimized away during synthesis, or the node cannot be routed to the SignalProbe pin, as it is untappable. For example, internal nodes and registers within the Gigabit transceivers can not be probed because there are no physical routes to the pins available.

 To probe virtual I/O pins generated in low-level partitions in an incremental compilation flow, select the source of the logic that feeds the Virtual Pin as your SignalProbe source pin.

To assign a SignalProbe source to your SignalProbe reserved pin, perform the following steps:

1. On the Tools menu, click **SignalProbe Pins**. The **SignalProbe Pins** dialog box appears (Figure 13-1 on page 13-3).
2. If a SignalProbe reserved pin is shown, click the pin in the **Current and potential SignalProbe pins** list. Alternately, you can click an available pin number in the **Current and potential SignalProbe pins** list and type a new SignalProbe pin name into the **Pin name** box.
3. In the **Source** box, specify the source name. Click the browse button. The **Node Finder** dialog box appears.
4. When you open the **Node Finder** dialog box from the **SignalProbe Pins** dialog box, **SignalProbe** is selected by default in the **Filter** list. Click **List** to show a set of nodes that can be probed in the **Nodes Found** list.
5. Select your source node in the **Nodes Found** list and click the “>” button. The selected node appears in the **Selected Nodes** list.
6. Click **OK**.

7. After a source is selected, the **SignalProbe enable** option is turned on. Click **Change** or **Add** to accept the changes.



Because SignalProbe pins are implemented and routed as ECOs, turning the **SignalProbe enable** option on or off is the same as selecting **Apply Selected Change** or **Restore Selected Change** in the Change Manager window. (If the Change Manager window is not visible at the bottom of your screen, from the View menu, point to **Utility Windows** and click **Change Manager**.)



For more information about the Change Manager for the Chip Planner and Resource Property Editor, refer to the *Engineering Change Management with the Chip Planner* chapter in volume 2 of the *Quartus II Handbook*.

### Add Registers to the Pipeline Path to SignalProbe Pin

You can specify the number of registers placed between a SignalProbe source and a SignalProbe pin to synchronize the data with a clock and to control the latency of the SignalProbe outputs. The SignalProbe feature automatically inserts the number of registers specified into the SignalProbe path.

Figure 13–2 shows a single register between the SignalProbe source `Reg_b_1` and SignalProbe `SignalProbe_Output_2` output pin added to synchronize the data between the two SignalProbe output pins.



When you add a register to a SignalProbe pin, the SignalProbe compilation attempts to place the register to best fit timing requirements. You can place SignalProbe registers near the SignalProbe source to meet  $f_{MAX}$  requirements, or you can place the register near the I/O to meet  $t_{CO}$  requirements.

**Figure 13–2. Synchronizing SignalProbe Outputs with a SignalProbe Register**

To pipeline an existing SignalProbe, perform the following steps:

1. On the Tools menu, click **SignalProbe Pins**. The **SignalProbe Pins** dialog box appears.
2. Select a SignalProbe pin and in the **Clock** dialog box, type the clock name used to drive your registers, or click the browse button to use the Node Finder to select your clock source.
3. In the **Registers** dialog box, specify the number of registers you want to add in between the SignalProbe source and the SignalProbe output.
4. Click **Change**.
5. Click **OK**.



In addition to clock input for pipeline registers, you can also specify a reset signal pin for pipeline registers. To specify a reset pin for pipeline registers, use the Tcl command `make_sp`, as described in “[Scripting Support](#)” on page 13–15.

## Perform a SignalProbe Compilation

Perform a SignalProbe compilation to route your SignalProbe pins. On the Processing menu, point to **Start** and click **Start SignalProbe Compilation** (Figure 13–3). A SignalProbe compilation saves and checks all netlist changes without recompiling the other parts of the design and completes compilation in a fraction of the time of a full compilation. The design's current placement and routing are preserved.

**Figure 13–3. Performing the SignalProbe Compilation**



## Analyze the Results of the SignalProbe Compilation

After a SignalProbe compilation, you can view the results in the compilation report file. Each SignalProbe pin is displayed in the **SignalProbe Fitting Result** page in the **Fitter** section of the Compilation Report (Figure 13–4). To view the status of each SignalProbe pin in the **SignalProbe Pins** dialog box, click **SignalProbe Pins** on the Tools menu.

**Figure 13–4. SignalProbe Fitting Results Page in the Compilation Report Window**



You can also view the status of each SignalProbe pin in the Change Manager window (Figure 13–5). (If the Change Manager window is not visible at the bottom of your GUI, from the View menu, point to **Utility Windows** and click **Change Manager**.)

**Figure 13–5. Change Manager Window with SignalProbe Pins**





For more information about how to use the Change Manager, refer to the *Engineering Change Management with the Chip Planner* chapter in volume 2 of the *Quartus II Handbook*.

To view the timing results of each successfully routed SignalProbe pin, on the Processing menu, point to **Start** and click **Start Timing Analysis**.

## Generate the Programming File

After a SignalProbe compilation, generate the new programming file containing your successfully routed SignalProbe pins. To generate a programming file, on the Processing menu, point to **Start** and click **Start Assembler**.

## SignalProbe ECO flows

Beginning with Quartus II software version 6.0, SignalProbe pins are implemented using the same flow as other post-compilation changes made as ECOs. The following section describes SignalProbe ECO flows with and without the Quartus II incremental compilation feature.

### *SignalProbe ECO Flow with Quartus II Incremental Compilation*

Beginning with Quartus II software version 6.1, the incremental compilation feature is turned on by default. The top-level design is automatically set to a design partition when the incremental compilation feature is on. A design partition during incremental compilation can have different netlist types. (Netlist types can be set to source HDL, post synthesis, or post-fit.) The netlist type indicates whether that partition should be resynthesized or refit during Quartus II incremental compilation. Incremental compilation saves you time and preserves the placement of unchanged partitions in your design if small changes must be made to some partitions late in the design cycle.



For more information about the Quartus II incremental compilation feature, refer to the *Quartus II Incremental Compilation Feature for Hierarchical and Team-Based Design* chapter in volume 1 of the *Quartus II Handbook*.

The behavior of SignalProbe pins during an incremental compilation depends on the Netlist Type setting. If the top-level partition netlist type is set to **post-fit**, SignalProbe ECOs are retained when you recompile the design.

If some SignalProbe sources from lower-level partitions are set to a netlist type other than post-fit, during re-compilation, the Quartus II Fitter uses the post-fit netlist type for those partitions as well, and a warning message appears in the message window.

All of the partitions containing SignalProbe ECOs are linked together and must use the post-fit netlist type. The same rule applies when your top-level partition is set to **post-synthesis** and one of the lower-level partitions' netlist type is set to **post-fit**. When you recompile your design, the Quartus II Fitter uses the post-fit netlist for the top-level partition and SignalProbe ECOs are retained.

The behavior is different in the case that your top-level partition netlist type is set to **post-synthesis** and you have no other lower-level partitions defined, or the lower-level partition netlist types are also set to **post-synthesis**. If you create SignalProbe ECOs and re-compile the design, your SignalProbe ECOs are not retained and a warning message appears in the messages window. The warning indicates that ECO modifications are discarded; however, all of the ECO information is retained in the Change Manager. In this case, you can apply SignalProbe ECOs from the Change Manager and perform the **Check and Save All Netlist Changes** step, as described in ["SignalProbe ECO Flow without Quartus Incremental Compilation" on page 13–10](#).

#### *SignalProbe ECO Flow without Quartus Incremental Compilation*

If you do not use the Quartus II incremental compilation feature and you implement SignalProbe pins after the initial compilation of your design, SignalProbe ECOs are not retained during recompilation. However, all of the SignalProbe ECOs remain in the Change Manager.

To apply a SignalProbe ECO, right-click Change Manager and select **Apply Selected Change** ([Figure 13–6](#)). (If the Change Manager window is not visible at the bottom of your screen, from the View menu, point to **Utility Windows** and click **Change Manager**.)

**Figure 13–6. Applying SignalProbe ECOs**

Alternately, you can use the **SignalProbe Pins** dialog box to enable the ECOs (Figure 13–7). This has the same effect as applying the SignalProbe ECOs within the Change Manager.

**Figure 13–7. Enabling ECOs in the SignalProbe Pins Dialog Box**

After applying the selected SignalProbe ECO, you can either click **Check and Save All Netlist Changes** from the menu within the Change Manager (Figure 13–8) or from Processing menu, point to **Start** and click **Start Check and Save All Netlist Changes** to perform the ECO compilation.

**Figure 13–8. Check and Save All Netlist Changes**

## Common Questions About the SignalProbe Feature

The following are answers to common questions about the SignalProbe feature.

### *Why Did I Get the Following Error Message, “Error: There are No Enabled SignalProbes to Process”?*

This error message is generated when a SignalProbe compilation was attempted with either no SignalProbe pins to route, or with all SignalProbe pins disabled.

This may occur if you perform a SignalProbe compilation after a full compilation. For example, when a full compilation is performed, all SignalProbe pins are disabled. You can create or re-enable your SignalProbe pins in the **SignalProbe Pins** dialog box.

### *How Can I Retain My SignalProbe ECOs during Re-compilation of My Design?*

To retain your existing ECOs during recompilation of your design, you must use Quartus II incremental compilation. To learn more about the flow, refer to “[SignalProbe ECO Flow with Quartus II Incremental Compilation](#)” on page 13–9.

### *Why Did My SignalProbe Source Disappear in the Change Manager?*

The SignalProbe source information for each SignalProbe is stored in the project database (**db** directory). SignalProbe pins are post-compilation changes to your netlist and are interpreted as ECOs. These changes are stored in the project **db** and if the project database is removed, the SignalProbe source information is lost and will not appear in the

**SignalProbe Pins** dialog box. To restore your SignalProbe pins after the design compilation step, source the **signalprobe\_qsfc.tcl** script located in your project directory.

You can restore your SignalProbe source information by typing the following command from a command prompt:

```
quartus_cdb -t signalprobe_qsfc.tcl
```

 After compilation with the Quartus II software, you must close your design project before typing the above command. Once the command finishes, you can open your design project again. The change manager shows the sources for SignalProbe pins.

### *What is an ECO and Where Can I Find More Information on ECO?*

ECOs are late design cycle changes made to your design that do not alter functionality and timing.



For more information about ECO and using the Change Manager, refer to the *Engineering Change Management with the Chip Planner* chapter in volume 2 of the *Quartus II Handbook*.

### *How Do I Migrate My Previous SignalProbe Assignments in the Quartus II Software Versions 5.1 and below to Versions 6.0 and Higher?*

In earlier versions of the Quartus II software, SignalProbe pins were stored in the Quartus II Settings File (.qsfc). These assignments are automatically converted into ECO changes when you open the **SignalProbe** dialog box or when you start a SignalProbe compilation in the Quartus II software versions 6.0 and higher.

For example, the SignalProbe source assignment from a Quartus II Settings File is removed and added to the Change Manager as an ECO after the **SignalProbe** dialog box is opened, or when you perform a SignalProbe compilation. **Example 13-1** shows SignalProbe assignments in the .qsfc file, and **Example 13-2** shows the same assignments after opening the **SignalProbe Pins** dialog box.

---

#### **Example 13-1. SignalProbe Assignments in the Quartus II Settings File**

```
set_location_assignment PIN_C22 -to my_signalprobe_pin
set_instance_assignment -name RESERVE_PIN "AS SIGNALPROBE_OUTPUT" -to my_signalprobe_pin
set_instance_assignment -name IO_STANDARD LVTTL -to my_signalprobe_pin
set_instance_assignment -name SIGNALPROBE_ENABLE ON -to my_signalprobe_pin
set_instance_assignment -name SIGNALPROBE_SOURCE inst5[0] -to my_signalprobe_pin
```

---

---

**Example 13–2. SignalProbe Assignments in the Quartus II Settings File after Opening the SignalProbe Pins Dialog Box**

```
set_location_assignment PIN_C22 -to my_signalprobe_pin
set_instance_assignment -name RESERVE_PIN "AS SIGNALPROBE OUTPUT" -to my_signalprobe_pin
set_instance_assignment -name IO_STANDARD LVTTL -to my_signalprobe_pin
set_instance_assignment -name SIGNALPROBE_ENABLE ON -to my_signalprobe_pin
```

---

*What are all the Changes for the SignalProbe Feature between the Quartus II Software Version 5.1 and Earlier, and Version 6.0 and Later?*

The following list of changes affect users of the SignalProbe feature in the Quartus II software versions 5.1 and below with Stratix series, Cyclone series, and MAX II device families.

- In Quartus II software versions 5.1 and earlier, the **SignalProbe Pins** dialog box was accessed on the Assignments menu. To access it with the Quartus II software version 6.0 and later, on the Tools menu, click **SignalProbe Pins**.
- A full compilation is required before making SignalProbe connections. However, you can still reserve pins before compilation for later use by SignalProbe. You can reserve pins by creating a SignalProbe in the **SignalProbe** dialog box without specifying a source. This is the same behavior as in the Quartus II software version 5.1.
- To route the SignalProbe pins, you must perform a SignalProbe compilation after a full compilation. The **Automatically route SignalProbe signals during compilations** and **Modify latest fitting results during SignalProbe compilation** options are no longer supported.
- After subsequent compiles, full or incremental, existing SignalProbe pins are disabled and are not present in the post-compilation netlist. To add them back, enable the SignalProbe pins and perform a SignalProbe compilation.
- SignalProbe pins are not controlled via assignments in the Quartus II Settings File because they are now ECOs. Existing Quartus II Settings Files automatically convert to ECOs when a SignalProbe compilation is performed or when the **SignalProbe** dialog box is opened.
- The Tcl interface for creating SignalProbe pins has improved and is a part of the Chip Planner package `::quartus::chip_editor`. Refer to “[Scripting Support](#)” on page 13–15.
- Previously, the `quartus_fit --signalprobe` command was used to perform a SignalProbe compilation. This is not supported in the Quartus II software version 6.0 and later, and is replaced by the improved Tcl interface and the `check_netlist_and_save` Tcl command.

- The SignalProbe timing report generated after a successful SignalProbe compilation is not available in the Quartus II software version 6.0 and later. You can view the timing results of your SignalProbe pins in the SignalProbe Fitting Results, under the Fitter report, or in the  $t_{CO}$  results page of the Timing report.
- You can not make SignalProbe pins in the Assignment Editor. Use the **SignalProbe Pins** dialog box to make and edit your SignalProbe pins.

## Scripting Support

You can run procedures and make settings described in this chapter in a Tcl script. You can also run some procedures at a command prompt. For detailed information about scripting command options, refer to the Quartus II command-line and Tcl API Help browser. To run the Help browser, type the following command at the command prompt:

```
quartus_sh --qhelp ↵
```

The *Scripting Reference Manual* includes the same information in PDF form.



For more information about Tcl scripting, refer to the *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*. For more information about all settings and constraints in the Quartus II software, refer to the *Quartus II Settings File Reference Manual*. For more information about command-line scripting, refer to the *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*.

### Make a SignalProbe Pin

You can make a SignalProbe pin by typing the following command:

```
make_sp [-h | -help] [-long_help] [-clk <clk>] [-io_std <io_std>] \
-loc <loc> -pin_name <pin name> [-regs <regs>] [-reset <reset>] \
-src_name <source name> ↵
```

### Delete a SignalProbe Pin

You can delete a SignalProbe pin by typing the following command:

```
delete_sp [-h | -help] [-long_help] -pin_name <pin name> ↵
```

### *Enable a SignalProbe Pin*

You can enable a SignalProbe pin by typing the following command:

```
enable_sp [-h | -help] [-long_help] -pin_name <pin name> ↵
```

### *Disable a SignalProbe Pin*

You can disable a SignalProbe pin by typing the following command:

```
disable_sp [-h | -help] [-long_help] -pin_name <pin name> ↵
```

### *Perform a SignalProbe Compilation*

You can perform a SignalProbe compilation by typing the following command:

```
check_netlist_and_save ↵
```

### *Migrate Previous SignalProbe Pins to the Quartus II Software Versions 6.0 and Later*

You can migrate previous SignalProbe pins to the Quartus II software versions 6.0 and later by typing the following command:

```
convert_signal_probes ↵
```

### *Script Example*

**Example 13-3** is a script that creates a SignalProbe pin called `sp1` and connecting it to source node `reg1` in a project that was already compiled.

---

#### **Example 13-3. Creating a SignalProbe Pin Called `sp1`**

```
Package require ::quartus::chip_editor
Project_open project
Read_netlist
Make_sp -pin_name sp1 -src_name reg1
Check_netlist_and_save
Project_close
```

---

# Using SignalProbe with the APEX Device Family

APEX devices do not support post-fit netlist changes made as ECOs. You can use SignalProbe compilation to route internal signals to output pins incrementally. The SignalProbe incremental routing feature does not affect design behavior.

To use the SignalProbe feature, follow these steps:

1. Reserve SignalProbe pins. For more information, refer to ["Reserve the SignalProbe Pins" on page 13-2](#).
2. Assign a SignalProbe source to each SignalProbe pin.
3. Perform a SignalProbe compilation.
4. Analyze the results of a SignalProbe compilation.

## Adding SignalProbe Sources

A SignalProbe source is a signal in the post-compilation design database with a possible route to an output pin. You can assign a SignalProbe source to a SignalProbe pin or an unused output pin by performing the following steps:

1. On the Tools menu, click **SignalProbe Pins**. The **SignalProbe Pins** dialog box appears.
2. In the **Current and potential SignalProbe pins** list, select the SignalProbe pin to which you want to add a SignalProbe source.
3. Click **Browse** and select a SignalProbe source.
4. Click **OK**.

The **Node Finder** dialog box displays with the SignalProbe filter selected ([Figure 13-9](#)). Click **List** to view all of the available SignalProbe sources. If you cannot find a specific node with the

SignalProbe filter, the node has either been removed by the Quartus II software during optimization or placed in the device where there are no possible routes to a pin.

**Figure 13–9. Available SignalProbe Sources in the Node Finder**



5. In the **Assign SignalProbe Pins** dialog box, click **Add** if a source has not been assigned to the SignalProbe pin.

*or*

Click **Change** for a SignalProbe pin that has a source already assigned.

 When the source of the SignalProbe pin is added or changed, the SignalProbe pin is automatically enabled. To disable a SignalProbe pin, turn off **SignalProbe enable**.

6. Click **OK**.

## Performing a SignalProbe Compilation

You can start a SignalProbe compilation manually or automatically after a full compilation. A SignalProbe compilation includes the following:

- Validates SignalProbe pins
- Validates your specified SignalProbe sources
- If applicable, adds registers into SignalProbe paths
- Attempts to route from SignalProbe sources through registers to SignalProbe pins

To run the SignalProbe compilation automatically after a full compilation, on the Tools menu, click **SignalProbe Pins**. In the **SignalProbe Pins** dialog box, turn on **Automatically route SignalProbe signals during compilation**.

To run a SignalProbe compilation manually after a full compilation, on the Processing menu, point to **Start** and click **Start SignalProbe Compilation**.



You must run the Fitter before a SignalProbe compilation. The Fitter generates a list of all internal nodes that can be used as SignalProbe sources.

You can enable and disable each SignalProbe pin by turning the **SignalProbe enable** option on and off in the **SignalProbe Pins** dialog box.

### *Running SignalProbe with Smart Compilation*

Optimally, you can run a smart compilation, which reduces compilation time by running only necessary modules during compilation. However, a full compilation is required if any design files, Analysis and Synthesis settings, or Fitter settings have changed.

To turn on smart compilation, on the Assignments menu, click **Settings**. In the **Category** list, select **Compilation Process Settings** and turn on **Use Smart compilation**.

If you run a SignalProbe compilation with smart compilation turned on, and there are changes to a design file or settings related to the Analysis and Synthesis or Fitter modules, the following message is displayed:

Error: Can't perform SignalProbe compilation because design requires a full compilation.



You should turn smart compilation on, which allows you to work with the latest settings and design files.

### **Understanding the Results of a SignalProbe Compilation**

After a SignalProbe compilation, the results appear in two sections of the compilation report file. The fitting results and status (Table 13-1) of each SignalProbe pin is displayed in the **SignalProbe Fitting Result** screen in the Fitter section of the compilation report (Figure 13-10).

The timing results of each successfully routed SignalProbe pin is displayed in the **SignalProbe source to output delays** screen in the Timing Analysis section of the compilation report (Figure 13-11).



After a SignalProbe compilation, the processing screen of the Messages window also provides the results of each SignalProbe pin and displays slack information for each successfully routed SignalProbe pin.

**Table 13–1. Status Values**

| Status          | Description                                           |
|-----------------|-------------------------------------------------------|
| Routed          | Connected and routed successfully                     |
| Not Routed      | Not enabled                                           |
| Failed to Route | Failed routing during last SignalProbe compilation    |
| Need to Compile | Assignment changed since last SignalProbe compilation |

**Figure 13–10. SignalProbe Fitting Results Page in the Compilation Report Window**



**Figure 13–11. SignalProbe Source to Output Delays Page in the Compilation Report Window**



### Analyzing SignalProbe Routing Failures

The SignalProbe can begin compilation; however, one of the following reasons can prevent complete compilation:

- **Route unavailable**—the SignalProbe compilation failed to find a route from the SignalProbe source to the SignalProbe pin because of routing congestion
- **Invalid or nonexistent SignalProbe source**—you entered a SignalProbe source that does not exist or is invalid
- **Unusable output pin**—the output pin selected is found to be unusable

Routing failures can occur if the SignalProbe pin's I/O standard conflicts with other I/O standards in the same I/O bank.

If routing congestion prevents a successful SignalProbe compilation, you can allow the compiler to modify the routing to the specified SignalProbe source. On the Tools menu, click **SignalProbe Pins** and turn on **Modify latest fitting results during SignalProbe compilation**. This setting allows the Fitter to modify existing routing channels used by your design.

 Turning on **Modify latest fitting results during SignalProbe compilation** can change the performance of your design.

### SignalProbe Scripting Support for APEX Devices

You can run procedures and make settings described in this chapter in a Tcl script. You can also run some procedures at a command prompt. For detailed information about scripting command options, refer to the Quartus II Command-Line and Tcl API Help browser. To run the Help browser, type the following command at the command prompt:

```
quartus_sh --qhelp ↵
```

The *Scripting Reference Manual* includes the same information in PDF form.



For more information about Tcl scripting, refer to the *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*. Refer to the *Quartus II Settings File Reference Manual* for information about all settings and constraints in the Quartus II software. For more information about command-line scripting, refer to the *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*.

## Reserving SignalProbe Pins

Use the following Tcl commands to reserve a SignalProbe pin.

```
set_location_assignment <location> -to <SignalProbe pin name>  
  
set_instance_assignment -name RESERVE_PIN \  
"AS SIGNALPROBE OUTPUT" -to <SignalProbe pin name> ↵
```

Valid locations are pin location names, such as Pin\_A3.

For more information about reserving SignalProbe pins, refer to “[Reserve the SignalProbe Pins](#)” on page 13–2.

## Adding SignalProbe Sources

Use the following Tcl commands to add SignalProbe sources. For more information about adding SignalProbe sources, refer to “[Adding SignalProbe Sources](#)” on page 13–17. The following command assigns the node name to a SignalProbe pin:

```
set_instance_assignment -name SIGNALPROBE_SOURCE \  
<node name> -to <SignalProbe pin name> ↵
```

The next command turns on SignalProbe routing. You can turn off individual SignalProbe pins by specifying OFF instead of ON with the following command:

```
set_instance_assignment -name SIGNALPROBE_ENABLE ON \  
-to <SignalProbe pin name> ↵
```

## Assigning I/O Standards

Use the following Tcl command to assign an I/O standard to a pin:

```
set_instance_assignment -name IO_STANDARD \  
<I/O standard> -to <SignalProbe pin name> ↵
```



For a list of valid I/O standards, refer to the I/O Standards general description in the Quartus II Help.

## Adding Registers for Pipelining

Use the following Tcl commands to add registers for pipelining:

```
set_instance_assignment -name SIGNALPROBE_CLOCK \  
<clock name> -to <SignalProbe pin name>
```

```
set_instance_assignment \  
-name SIGNALPROBE_NUM_REGISTERS <number of registers> \  
-to <SignalProbe pin name> ↵
```

## Run SignalProbe Automatically

Use the following Tcl command to run SignalProbe automatically after a full compile.

```
set_global_assignment -name \  
SIGNALPROBE_DURING_NORMAL_COMPILATION ON
```

For more information about running SignalProbe automatically, refer to “[Performing a SignalProbe Compilation](#)” on page 13–18.

## Run SignalProbe Manually

You can run SignalProbe manually with a Tcl command or the `quartus_fit` command at a command prompt.

```
execute_flow -signalprobe ↵
```

The `execute_flow` command is in the `flow` package. At a command prompt, type the following command:

```
quartus_fit <project name> --signalprobe ↵
```

For more information about running SignalProbe manually, refer to “[Performing a SignalProbe Compilation](#)” on page 13–18.

## Enable or Disable All SignalProbe Routing

Use the Tcl command in [Example 13-4](#) to turn on or turn off SignalProbe routing. In the `set_instance_assignment` command, specify ON to turn on SignalProbe routing or OFF to turn off SignalProbe routing.

---

### **Example 13-4. Turning SignalProbe On or Off with Tcl**

```
set spe [get_all_assignments -name SIGNALPROBE_ENABLE] \
foreach_in_collection asgn $spe {
    set signalprobe_pin_name [lindex $asgn 2]
    set_instance_assignment -name SIGNALPROBE_ENABLE -to \
$signalprobe_pin_name <ON|OFF> } ↵
```

---

For more information about enabling or disabling SignalProbe routing, refer to [page 13-18](#).

## Running SignalProbe with Smart Compilation

Use the following Tcl command to turn on **Smart Compilation**:

```
set_global_assignment -name SMART_RECOMPILE ON ↵
```

For more information, refer to “[Running SignalProbe with Smart Compilation](#)” on [page 13-19](#).

## Allow SignalProbe to Modify Fitting Results

Use the following Tcl command to turn on **Modify latest fitting results**.

```
set_global_assignment -name \
SIGNALPROBE_ALLOW_OVERUSE ON ↵
```

For more information, refer to “[Analyzing SignalProbe Routing Failures](#)” on [page 13-21](#).

## Conclusion

Using the SignalProbe feature can significantly reduce the time required compared to a full recompilation. You can use the SignalProbe feature to get quick access to internal design signals to perform system-level debugging.

## Referenced Documents

This chapter references the following documents:

- *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*
- *Engineering Change Management with the Chip Planner* chapter in volume 2 of the *Quartus II Handbook*
- *Section V. In-System Design Debugging* in the *Quartus II Handbook*
- *Quartus II Incremental Compilation for Hierarchical and Team-Based Design* chapter in volume 1 of the *Quartus II Handbook*
- *Quartus II Settings File Reference Manual*
- *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*

## Document Revision History

Table 13–2 shows the revision history for this chapter.

| <b>Table 13–2. Document Revision History</b> |                                                                                                                                                                                                                                                                                                                                                         |                                                                                                        |
|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| <b>Date and Document Version</b>             | <b>Changes Made</b>                                                                                                                                                                                                                                                                                                                                     | <b>Summary of Changes</b>                                                                              |
| May 2008<br>v8.0.0                           | <ul style="list-style-type: none"> <li>Added “Arria GX” to the list of supported devices</li> <li>Removed the “On-Chip Debugging Tool Comparison” and replaced with a reference to the Section V Overview on page 13–1</li> <li>Added hyperlinks to referenced documents throughout the chapter</li> <li>Minor editorial updates</li> </ul>             | Organizational changes for the Quartus II software version 8.0 release.                                |
| October 2007<br>v7.2.0                       | Reorganized “Referenced Documents” on page 12–26.                                                                                                                                                                                                                                                                                                       | —                                                                                                      |
| May 2007<br>v7.1.0                           | Added Referenced Documents, minor updates to address ADoQS issues.                                                                                                                                                                                                                                                                                      | —                                                                                                      |
| March 2007 v7.0.0                            | Updated Quartus II software 7.0 revision and date only. No other changes made to chapter.                                                                                                                                                                                                                                                               | —                                                                                                      |
| November 2006<br>v6.1.0                      | Updated for the Quartus II software version 6.1.0: <ul style="list-style-type: none"> <li>New section (SignalProbe ECO flows) added to explain how SignalProbe pins' ECOs are affected during Quartus II Incremental Compilation.</li> <li>Q and A added to answer: How Can I Retain My SignalProbe ECOs during Re-compilation of My Design.</li> </ul> | Quartus II software version 6.1.0 added more ECO features; the chapter updated to reflect this change. |
| May 2006<br>v6.0.0                           | Updated for the Quartus II software version 6.0.0: <ul style="list-style-type: none"> <li>Documented new SignalTap features.</li> </ul>                                                                                                                                                                                                                 | —                                                                                                      |
| December 2005<br>v5.1.1                      | Added SMART_RECOMPILE assignment.                                                                                                                                                                                                                                                                                                                       | —                                                                                                      |
| October 2005<br>v5.1.0                       | Updated for the Quartus II software version 5.1.                                                                                                                                                                                                                                                                                                        | —                                                                                                      |
| May 2005<br>v5.0.0                           | <ul style="list-style-type: none"> <li>Minor updates for Quartus II software 5.0</li> </ul>                                                                                                                                                                                                                                                             | —                                                                                                      |
| December 2004<br>v2.1                        | <ul style="list-style-type: none"> <li>Chapter 9 was formerly Chapter 8.</li> <li>Updates to tables and figures.</li> <li>New functionality for Quartus II software 4.2.</li> </ul>                                                                                                                                                                     | —                                                                                                      |
| June 2004<br>v2.0                            | <ul style="list-style-type: none"> <li>Updates to tables, figures.</li> <li>New functionality for Quartus II software 4.1.</li> </ul>                                                                                                                                                                                                                   | —                                                                                                      |
| February 2004<br>v1.0                        | Initial release.                                                                                                                                                                                                                                                                                                                                        | —                                                                                                      |

### Introduction

The phenomenal growth in design size and complexity continues to make design verification a critical bottleneck for current FPGA systems.

Limited access to internal signals, complex FPGA packages, and PCB electrical noise all contribute to making design debugging the most challenging process of the design cycle. More than 50% of design cycle time can be spent on debugging and verifying the design. To help with the process of design debugging, Altera provides a solution that allows you to examine the behavior of internal signals, without using extra I/O pins, while the design is running at full speed on an FPGA device.

The SignalTap® II Embedded Logic Analyzer is scalable, easy to use, and is included with the Quartus® II software subscription. This logic analyzer helps debug an FPGA design by probing the state of the internal signals in the design without the use of external equipment. Defining custom trigger-condition logic provides greater accuracy and improves the ability to isolate problems. The SignalTap II Embedded Logic Analyzer does not require external probes, or changes to the design files to capture the state of the internal nodes or I/O pins in the design. All captured signal data is conveniently stored in device memory until you are ready to read and analyze the data.

The topics in this chapter include:

- “Design Flow Using the SignalTap II Logic Analyzer” on page 14–5
- “SignalTap II Logic Analyzer Task Flow” on page 14–6
- “Add the SignalTap II Logic Analyzer to Your Design” on page 14–8
- “Configure the SignalTap II Logic Analyzer” on page 14–16
- “Define Triggers” on page 14–31
- “Program the Target Device or Devices” on page 14–59
- “Run the SignalTap II Logic Analyzer” on page 14–60
- “View, Analyze, and Use Captured Data” on page 14–66
- “Other Features” on page 14–70
- “SignalTap II Scripting Support” on page 14–76
- “Design Example: Using SignalTap II Logic Analyzers in SOPC Builder Systems” on page 14–81
- “Custom Triggering Flow Application Examples” on page 14–81

The SignalTap II Embedded Logic Analyzer is a next-generation, system-level debugging tool that captures and displays real-time signal behavior in a system-on-a-programmable-chip (SOPC) or any FPGA design. The SignalTap II Embedded Logic Analyzer supports the highest

number of channels, largest sample depth, and fastest clock speeds of any embedded logic analyzer in the programmable logic market. [Figure 14–1](#) shows a block diagram of the components that make up the SignalTap II Embedded Logic Analyzer.

**Figure 14–1. SignalTap II Logic Analyzer Block Diagram** [Note \(1\)](#)



**Note to Figure 14–1:**

- (1) This diagram assumes that the SignalTap II Logic Analyzer was compiled with the design as a separate design partition using the Quartus II Incremental Compilation feature. This is the default setting for new projects in the Quartus II software. If incremental compilation is disabled or not used, the SignalTap II logic is integrated with the design. For information about the use of incremental compilation with SignalTap II, refer to ["Faster Compilations with Quartus II Incremental Compilation"](#) on page 14–53.

This chapter is intended for any designer who wants to debug their FPGA design during normal device operation without the need for external lab equipment. Because the SignalTap II Embedded Logic Analyzer is similar to traditional external logic analyzers, familiarity with external logic analyzer operations is helpful but not necessary. To take advantage of faster compile times when making changes to the SignalTap II Logic Analyzer, knowledge of the Quartus II Incremental Compilation feature is helpful.



For information about using the Quartus II Incremental Compilation feature, refer to the [Quartus II Incremental Compilation for Hierarchical and Team-Based Design](#) chapter in volume 1 of the *Quartus II Handbook*.

## Hardware and Software Requirements

The following components are required to perform logic analysis with the SignalTap II Embedded Logic Analyzer:

- Quartus II design software
  - or*
  - Quartus II Web Edition (with the TalkBack feature enabled)
  - or*
  - SignalTap II Logic Analyzer standalone software
- Download/upload cable
- Altera® development kit or user design board with JTAG connection to device under test

Captured data is stored in the device's memory blocks and transferred to the Quartus II software waveform display with a JTAG communication cable, such as EthernetBlaster or USB-Blaster™. **Table 14-1** summarizes some of the features and benefits of the SignalTap II Embedded Logic Analyzer.

**Table 14-1. SignalTap II Features and Benefits (Part 1 of 2)**

| Feature                                                                  | Benefit                                                                                                                                                     |
|--------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Multiple logic analyzers in a single device                              | Captures data from multiple clock domains in a design at the same time                                                                                      |
| Multiple logic analyzers in multiple devices in a single JTAG chain      | Simultaneously captures data from multiple devices in a JTAG chain                                                                                          |
| Plug-In Support                                                          | Easily specifies nodes, triggers, and signal mnemonics for IP, such as the Nios® II embedded processor                                                      |
| Up to 10 basic or advanced trigger conditions for each analyzer instance | Enables more complex data capture commands to be sent to the logic analyzer, providing greater accuracy and problem isolation                               |
| Power-Up Trigger                                                         | Captures signal data for triggers that occur after device programming but before manually starting the logic analyzer                                       |
| State-Based Triggering Flow                                              | Enables you to organize your triggering conditions to precisely define what your embedded logic analyzer will capture                                       |
| Incremental Compilation                                                  | Modifies the SignalTap II Logic Analyzer monitored signals and triggers without performing a full compilation, saving time                                  |
| Flexible buffer acquisition modes                                        | Allows more accurate data collection by setting each trigger to sample at different ranges relative to the triggering event, in circular or segmented modes |
| MATLAB integration with included MEX function                            | Acquires the SignalTap II Logic Analyzer captured data into a MATLAB integer matrix                                                                         |
| Up to 1,024 channels in each device                                      | Samples many signals and wide bus structures                                                                                                                |

**Table 14–1. SignalTap II Features and Benefits (Part 2 of 2)**

| Feature                           | Benefit                                                                                                                                |
|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Up to 128K samples in each device | Captures a large sample set for each channel                                                                                           |
| Fast clock frequencies            | Collects sample data at up to 270 MHz                                                                                                  |
| Resource usage estimator          | Provides estimate of logic and memory device resources used by SignalTap II Embedded Logic Analyzer configurations                     |
| No additional cost                | The SignalTap II Logic Analyzer is included with a Quartus II subscription and with the Quartus II Web Edition (with TalkBack enabled) |



The Quartus II software offers a portfolio of on-chip debugging solutions. For an overview and comparison of all of the tools available in the In-System Verification Tool set, refer to the *Section V. In-System Debugging* Overview.

## Design Flow Using the SignalTap II Logic Analyzer

Figure 14–2 shows a typical overall FPGA design flow for using the SignalTap II Logic Analyzer in your design. A SignalTap II file (.stp) is added to and enabled in your project, or a SignalTap II HDL function, created with the MegaWizard® Plug-In Manager, is instantiated in your design. The diagram shows the flow of operations from initially adding the SignalTap II Logic Analyzer to your design to final device configuration, testing, and debugging.

Figure 14–2. *SignalTap II FPGA Design and Debugging Flow*



## SignalTap II Logic Analyzer Task Flow

To use the SignalTap II Logic Analyzer to debug your design, you perform a number of tasks to add, configure, and run the logic analyzer. [Figure 14-3](#) shows a typical flow of the tasks you complete to debug your design. Refer to the appropriate section of this chapter for more information about each of these tasks.

**Figure 14-3. SignalTap II Logic Analyzer Task Flow**



## Add the SignalTap II Logic Analyzer to Your Design

Create an **.stp** file or create a parameterized HDL instance representation of the logic analyzer using the MegaWizard Plug-In Manager. If you want to monitor multiple clock domains simultaneously, add additional instances of the logic analyzer to your design, limited only by the available resources in your device.

## Configure the SignalTap II Logic Analyzer

Once the SignalTap II Logic Analyzer is added to your design, configure it to monitor the signals you want. You can manually add signals or use a plug-in, such as the Nios II plug-in, to quickly add entire sets of associated signals for a particular IP. You can also specify settings for the data capture buffer, such as its size, the method in which data is captured and stored, and the device memory type to use for the buffer in devices that support memory type selection.

## Define Triggers

The SignalTap II Logic Analyzer continuously captures data while it is running. To capture and store specific signal data, set up triggers that tell the logic analyzer under what conditions to stop capturing data. The SignalTap II Logic Analyzer lets you define Runtime Triggers that range from very simple, such as the rising edge of a single signal, to very complex, involving groups of signals, extra logic, and multiple conditions. Power-Up Triggers give you the ability to capture data from trigger events occurring immediately after the device enters user-mode after configuration.

## Compile the Design

With the **.stp** file configured and triggers defined, compile your project as usual to include the logic analyzer in your design. Since you may need to frequently change monitored signal nodes or adjust trigger settings during debugging, Altera recommends that you use the incremental compilation feature built into the SignalTap II Logic Analyzer, along with Quartus II incremental compilation, to reduce recompile times.

## Program the Target Device or Devices

When you are debugging a design with the SignalTap II Logic Analyzer, you can program a target device directly from the **.stp** file without using the Quartus II Programmer. You can also program multiple devices with different designs and simultaneously debug them.

## Run the SignalTap II Logic Analyzer

In normal device operation, you control the logic analyzer through the JTAG connection, specifying when to start looking for trigger conditions to begin capturing data. With Runtime or Power-Up Triggers, read and transfer the captured data from the on-chip buffer to the **.stp** file for analysis.

## View, Analyze, and Use Captured Data

Once you have captured data and read it into the **.stp** file, it is available for analysis and use in the debugging process. Either manually or with a plug-in, set up mnemonic tables to make it easier to read and interpret the captured signal data. To speed up debugging, use the Locate feature in the **SignalTap II** node list to find the locations of problem nodes in other tools in the Quartus II software. Save the captured data for later analysis, or convert it to other formats for sharing and further study.

## Add the SignalTap II Logic Analyzer to Your Design

Because the SignalTap II Logic Analyzer is implemented in logic on your target device, it must be added to your FPGA design as another part of the design itself. There are two ways to generate the SignalTap II Logic Analyzer and add it to your design for debugging:

- Create an **.stp** file and use the SignalTap II Editor to configure the details of the logic analyzer
- Create and configure the **.stp** file with the MegaWizard Plug-In Manager and instantiate it in your design

## Creating and Enabling a SignalTap II File

To create an embedded logic analyzer, use an existing **.stp** file or create a new file. Once a file is created or selected, it must be enabled in the project where it is used.

### *Creating a SignalTap II File*

The **.stp** file contains the SignalTap II Logic Analyzer settings and the captured data for viewing and analysis. To create a new **.stp** file, perform the following steps:

1. On the File menu, click **New**.
2. In the **New** dialog box, click the **Other Files** tab and select **SignalTap II Logic Analyzer File**.
3. Click **OK**.

To open an existing .stp file already associated with your project, on the Tools menu, click **SignalTap II Logic Analyzer**. You can also use this method to create a new .stp file if no .stp file exists for the current project.

To open an existing file, on the File menu, click **Open** and select an .stp file (Figure 14-4).

**Figure 14-4. SignalTap II Editor**



### *Enabling and Disabling a SignalTap II File for the Current Project*

Whenever you save a new .stp file, the Quartus II software asks you if you want to enable the file for the current project. However, you can add this file manually, change the selected .stp file, or completely disable the logic analyzer by performing the following steps:

1. On the Assignments menu, click **Settings**. The **Settings** dialog box appears.
2. In the **Category** list, select **SignalTap II Logic Analyzer**. The **SignalTap II Logic Analyzer** page appears.
3. Turn on **Enable SignalTap II Logic Analyzer**. Turn off this option to disable the logic analyzer, completely removing it from your design.
4. In the **SignalTap II File name** box, type the name of the .stp file you want to include with your design, or browse to and select a file name.
5. Click **OK**.

### **Using the MegaWizard Plug-In Manager to Create Your Embedded Logic Analyzer**

Alternatively, you can create a SignalTap II Logic Analyzer instance by using the MegaWizard Plug-In Manager. The MegaWizard Plug-In Manager generates an HDL file that you instantiate in your design. You can also use a hybrid approach in which you instantiate the MegaWizard Plug-In Manager file in your HDL, and then use the method described in “[Creating and Enabling a SignalTap II File](#)” on page 14–8.

#### *Creating an HDL Representation Using the MegaWizard Plug-In Manager*

The Quartus II software allows you to easily create your SignalTap II Logic Analyzer using the MegaWizard Plug-In Manager. To implement the SignalTap II megafunction, perform the following steps:

1. On the Tools menu, click **MegaWizard Plug-In Manager**. Page 1 of the **MegaWizard Plug-In Manager** dialog box appears.
2. Select **Create a new custom megafunction variation**.
3. Click **Next**.

4. In the **Installed Plug-Ins** list, expand the **JTAG-accessible Extensions** folder and select **SignalTap II Logic Analyzer**. Select an output file type and enter the desired name of the SignalTap II megafunction. You can choose AHDL (.tdf), VHDL (.vhd), or Verilog HDL (.v) as the output file type (Figure 14–5).

**Figure 14–5. Creating the SignalTap II Logic Analyzer in the MegaWizard Plug-In Manager**



5. Click **Next**.
6. Configure the analyzer by specifying the **Sample depth**, **RAM Type**, **Data input port width**, **Trigger levels**, **Trigger input port width**, whether to enable an external **Trigger in** or **Trigger out**, and whether to enable the **Segmented** memory buffer option. (Figure 14–6).

For information about these settings, refer to “[Configure the SignalTap II Logic Analyzer](#)” on page 14–16 and “[Define Triggers](#)” on page 14–31.

Figure 14–6. Select Logic Analyzer Parameters



7. Click **Next**.
8. Set the **Trigger level** options by selecting **Basic** or **Advanced** (Figure 14–7). If you select **Advanced** for any trigger level, the next page of the MegaWizard Plug-In Manager displays the Advanced Trigger Condition Editor. You can configure an advanced trigger expression using the number of signals you specified for the trigger input port width.



You cannot define a Power-Up Trigger using the MegaWizard Plug-In Manager. Refer to “[Define Triggers](#)” on page 14–31 to learn how to do this using the .stp file.

Figure 14–7. *MegaWizard Basic and Advanced Trigger Options*

9. On the final page of the MegaWizard Plug-In Manager, select any additional files you want to create and click **Finish** to create an HDL representation of the SignalTap II Logic Analyzer.

For information about the configuration settings options in the MegaWizard Plug-In Manager, refer to “[Configure the SignalTap II Logic Analyzer](#)” on page 14–16. For information about defining triggers, refer to “[Define Triggers](#)” on page 14–31.

### SignalTap II Megafunction Ports

Table 14–2 provides information about the SignalTap II megafunction ports.



For the most current information about the ports and parameters for this megafunction, refer to the latest version of the Quartus II Help.

| <b>Table 14–2. SignalTap II Megafunction Ports</b> |             |                 |                                                                                                          |
|----------------------------------------------------|-------------|-----------------|----------------------------------------------------------------------------------------------------------|
| <b>Port Name</b>                                   | <b>Type</b> | <b>Required</b> | <b>Description</b>                                                                                       |
| acq_data_in                                        | Input       | No              | This set of signals represents the set of signals that are monitored in the SignalTap II Logic Analyzer. |
| acq_trigger_in                                     | Input       | No              | This set of signals represents the set of signals that are used to trigger the analyzer.                 |
| acq_clk                                            | Input       | Yes             | This port represents the sampling clock that the SignalTap II Logic Analyzer uses to capture data.       |
| trigger_in                                         | Input       | No              | This signal is used to trigger the SignalTap II Logic Analyzer.                                          |
| trigger_out                                        | Output      | No              | This signal is enabled when the trigger event occurs.                                                    |

### Instantiating the SignalTap II Logic Analyzer in Your HDL

Instantiating the logic analyzer in your HDL is similar to instantiating any other Verilog HDL or VHDL megafunction in your design. Add the code from the files that are generated by the MegaWizard Plug-In Manager to your design, mapping the signals in your design to the appropriate SignalTap II megafunction ports. You can instantiate up to 127 analyzers in your design, or as many as physically fit in the FPGA. Once you have instantiated the .stp file in your HDL file, compile your Quartus II project to fit the logic analyzer in the target FPGA.

To capture and view the data, create an .stp file from your SignalTap II HDL output file. To do this, on the File menu, point to **Create/Update** and click **Create SignalTap II File from Design Instance(s)**.

If you make any changes to your design or the SignalTap II instance, recreate or update the .stp file using the **Create/Update** command. This ensures that the .stp file is always compatible with the SignalTap II instance in your design. If the .stp file is not compatible with the SignalTap II instance in your design, you may not be able to control the SignalTap II Logic Analyzer after it is programmed into your device.

For information about .stp file compatibility with programmed SignalTap II instances, refer to “[Program the Target Device or Devices](#)” on page 14–59.

## Embedding Multiple Analyzers in One FPGA

The SignalTap II Logic Analyzer includes support for multiple logic analyzers in an FPGA device. This feature allows you to create a unique logic analyzer for each clock domain in the design. As multiple instances of the analyzer are added to the **.stp** file, resource usage increases proportionally.

In addition to debugging multiple clock domains, this feature allows you to apply the same SignalTap II settings to a group of signals in the same clock domain. For example, if you have a set of signals that must use a sample depth of 64K and another set of signals in the same clock domain requires a sample depth of 1K, you can create two instances to meet these needs.

To create multiple analyzers, on the Edit menu, click **Create Instance**, or right-click in the Instance Manager window and click **Create Instance**.

You can configure each instance of the SignalTap II Logic Analyzer independently. The icon in the Instance Manager for the currently active instance that is available for configuration is highlighted in color and surrounded by a blue box. To configure a different instance, double-click the icon or name of another instance in the Instance Manager.

## Monitoring FPGA Resources Used by the SignalTap II Logic Analyzer

The SignalTap II Logic Analyzer has a built-in resource estimator that calculates the logic resources and amount of memory that each logic analyzer instance uses. Furthermore, because the most demanding on-chip resource for the embedded logic analyzer is memory usage, the resource estimator reports the ratio of total RAM usage in your design to the total amount of RAM available, given the results of the last compilation. The resource estimator provides a warning if a potential for a “no-fit” occurs.

You can see resource usage of each logic analyzer instance and total resources used in the columns of the Instance Manager section of the SignalTap II Editor. Use this feature when you know that your design is running tight on resources.

The logic element value reported in the resource usage estimator may vary by as much as 10% from the actual resource usage.

Table 14–3 shows the SignalTap II Logic Analyzer M4K memory block resource usage for the listed devices per signal width and sample depth.

| <b>Table 14–3. SignalTap II Logic Analyzer M4K Block Utilization for Stratix® II, Stratix, Stratix GX, and Cyclone® Devices Note (1)</b> |                 |     |       |       |
|------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----|-------|-------|
| Signals (Width)                                                                                                                          | Samples (Depth) |     |       |       |
|                                                                                                                                          | 256             | 512 | 2,048 | 8,192 |
| 8                                                                                                                                        | < 1             | 1   | 4     | 16    |
| 16                                                                                                                                       | 1               | 2   | 8     | 32    |
| 32                                                                                                                                       | 2               | 4   | 16    | 64    |
| 64                                                                                                                                       | 4               | 8   | 32    | 128   |
| 256                                                                                                                                      | 16              | 32  | 128   | 512   |

**Note to Table 14–3:**

- (1) When you configure a SignalTap II Logic Analyzer, the Instance Manager reports an estimate of the memory bits and logic elements required to implement the given configuration.

## Configure the SignalTap II Logic Analyzer

The .stp file provides many options for configuring instances of the logic analyzer. Some of the settings are similar to those found on traditional external logic analyzers. Other settings are unique to the SignalTap II Logic Analyzer because of the requirements for configuring an embedded logic analyzer. All settings give you the ability to configure the logic analyzer the way you want to help debug your design.



Some settings can only be adjusted when you are viewing Run-Time Trigger conditions instead of Power-Up Trigger conditions. To learn about Power-Up Triggers and viewing different trigger conditions, refer to “[Creating a Power-Up Trigger](#)” on page 14–47.

### Assigning an Acquisition Clock

Assign a clock signal to control the acquisition of data by the SignalTap II Logic Analyzer. The logic analyzer samples data on every positive (rising) edge of the acquisition clock. The logic analyzer does not support sampling on the negative (falling) edge of the acquisition clock. You can use any signal in your design as the acquisition clock. However, for best results, Altera recommends that you use a global, non-gated clock for data acquisition. Using a gated clock as your acquisition clock can result in unexpected data that does not accurately reflect the behavior of your design. The Quartus II Classic Timing Analyzer shows the maximum acquisition clock frequency at which you can run your design.

To assign an acquisition clock, perform the following steps:

1. In the SignalTap II Logic Analyzer window, click the **Setup** tab.
2. In the Signal Configuration pane, next to the **Clock** field, click **Browse**. The **Node Finder** dialog box appears.
3. From the **Filter** list, select **SignalTap II: post-fitting** or **SignalTap II: pre-synthesis**.
4. In the **Named** field, type the exact name of a node that you want to use as your sample clock, or search for a node using a partial name and wildcard characters.
5. To start the node search, click **List**.
6. In the **Nodes Found** list, select the node that represents the design's global clock signal.
7. Add the selected node name to the **Selected Nodes** list by clicking “>” or by double-clicking the node name.
8. Click **OK**. The node is now specified as the acquisition clock in the SignalTap II Editor.

If you do not assign an acquisition clock in the SignalTap II Editor, the Quartus II software automatically creates a clock pin called `auto_stp_external_clk`.

You must make a pin assignment to this pin independently from the design. Ensure that a clock signal in your design drives the acquisition clock.



For information about assigning signals to pins, refer to the *I/O Management* chapter in volume 2 of the *Quartus II Handbook*.

## Adding Signals to the SignalTap II File

While configuring the logic analyzer, add signals to the node list in the `.stp` file to select which signals in your design you want to monitor. Selected signals are also used to define triggers. You can assign the following two types of signals to your `.stp` file:

- **Pre-synthesis**—This signal exists after design elaboration, but before any synthesis optimizations are done. This set of signals should reflect your Register Transfer Level (RTL) signals.

- **Post-fitting**—This signal exists after physical synthesis optimizations and place-and-route.



If you are not using incremental compilation, add only pre-synthesis signals to your **.stp** file. Using pre-synthesis is particularly useful if you want to add a new node after you have made design changes. To do this, on the Processing menu, point to **Start** and click **Start Analysis & Elaboration**.

Signals shown in blue text are post-fit node names. Signals shown in black text are pre-synthesis node names.

After successful Analysis and Elaboration, the signals shown in red text are invalid signals. Unless you are certain that these signals are valid, remove them from the **.stp** file for correct operation. The SignalTap II Status Indicator also indicates if an invalid node name exists in the **.stp** file.

As a general guideline, signals can be tapped if a routing resource (row or column interconnects) exists to route the connection to the SignalTap II instance. For example, signals that exist in the I/O element (IOE) cannot be directly tapped because there are no direct routing resources from the signal in an IOE to a core logic element. For input pins, you can tap the signal that is driving a logic array block (LAB) from an IOE, or, for output pins, you can tap the signal from the LAB that is driving an IOE.

When adding pre-synthesis signals, all connections made to the SignalTap II Logic Analyzer are made prior to synthesis. Logic and routing resources are allocated during recompilation to make the connection as if a change in your design files had been made. As such, pre-synthesis signal names for signals driving to and from IOEs coincide with the signal names assigned to the pin.

In the case of post-fit signals, connections that you make to the SignalTap II Logic Analyzer are the signal names from the actual atoms in your post-fit netlist. A connection can only be made if the signals are part of the existing post-fit netlist and existing routing resources are available from the signal of interest to the SignalTap II Logic Analyzer. In the case of post-fit output signals, tap the COMBOUT or REGOUT signal that drives the IOE block. For post-fit input signals, signals driving into the core logic coincide with the signal name assigned to the pin.



If you are tapping the signal from the atom that is driving an IOE, be aware that the signal may be inverted due to NOT-gate push back. You can check this by locating the signal in either the Resource Property Editor or the Technology Map Viewer. The Technology Map viewer and the Resource Property Editor are also helpful in finding post-fit node names.



For information about cross-probing to source design file and other Quartus II windows, refer to the *Analyzing Designs with Quartus II Netlist Viewers* chapter in volume 1 of the *Quartus II Handbook*.

For more information about the use of incremental compilation with the SignalTap II Logic Analyzer, refer to “[Faster Compilations with Quartus II Incremental Compilation](#)” on page 14–53.

### *Signal Preservation*

Many of your RTL signals are optimized during the process of synthesis and place-and-route. RTL signal names frequently may not appear in the post-fit netlist after optimizations. For example, the compilation process can add tildes (“~”) to nets that are fanning out from a node, making it difficult to decipher which signal nets they actually represent. This can cause a problem when you use the incremental compilation flow with the SignalTap II Logic Analyzer. Since only post-fitting signals can be added to the SignalTap II Logic Analyzer in partitions of type **post-fit**, RTL signals that you want to monitor may not be available, preventing their usage. To avoid this issue, use synthesis attributes to preserve signals during synthesis and place-and-route. When the Quartus II software encounters these synthesis attributes, it does not perform any optimization on the specified signals, forcing them to continue to exist in the post-fit netlist. However, if you do this, you could see an increase in resource utilization or a decrease in timing performance. The two attributes you can use are:

- **keep**—Ensures that combinational signals are not removed
- **preserve**—Ensures that registers are not removed



For more information about using these attributes, refer to the *Quartus II Integrated Synthesis* chapter in volume 1 of the *Quartus II Handbook*.

If you are debugging an IP core, such as the Nios II CPU, or other encrypted IP, you might need to preserve nodes from the core to make them available for debugging with the SignalTap II Logic Analyzer. This is often necessary when a plug-in is used to add a group of signals for a particular IP. To do this, on the Assignments menu, click **Settings**. In the

Category list, select **Analysis & Synthesis Settings**. Turn on **Create debugging nodes for IP cores** to make these nodes available to the SignalTap II Logic Analyzer.

### *Assigning Data Signals Using the Node Finder*

To assign data signals, perform the following steps:

1. Perform Analysis and Elaboration, Analysis and Synthesis, or fully compile your design.
2. In the SignalTap II Logic Analyzer window, click the **Setup** tab.
3. Double-click anywhere in the node list of the SignalTap II Editor to open the **Node Finder** dialog box.
4. In the **Fitter** list, select **SignalTap II: pre-synthesis** or **SignalTap II: post-fitting**. Only signals listed under one of these filters can be added to the **SignalTap II node** list. Signals cannot be selected from any other filters.



Altera recommends that you do not add a mix of pre-synthesis and post-fitting signals within the same partition. For more details, refer to ["Using Incremental Compilation with the SignalTap II Logic Analyzer" on page 14-54](#).

If you use Incremental Compilation flow with SignalTap II, pre-synthesis nodes will not be connected to the SignalTap II Logic Analyzer if the affected partition is of the post-fit type. Any pre-synthesis nodes added to a partition of type post-fit may not be connected to the SignalTap II Logic Analyzer. A critical warning is issued for all pre-synthesis node names that are not found in the post-fit netlist.

5. In the **Named** field, type a node name, or search for a particular node by entering a partial node name along with wildcard characters. To start the node name search, click **List**.
6. In the **Nodes Found** list, select the node or bus you want to add to the **.stp** file.
7. Add the selected node name(s) to the **Selected Nodes** list by clicking “>” or by double-clicking the node name(s).

8. To insert the selected nodes in the .stp file, click **OK**. With the default colors set for the SignalTap II Logic Analyzer, a pre-synthesis signal in the list is shown in black; a post-fitting signal is shown in blue.



You can also drag and drop signals from the **Node Finder** dialog box into an .stp file.

### Assigning Data Signals Using the Technology Map Viewer

Starting with Quartus II software version 8.0, you can easily add post-fit signal names that you find in the Technology map viewer. To do so, launch the Technology map viewer (post-fitting) after compiling your design. When you find the desired node, copy the node to either the active .stp file for your design or a new .stp file. [Figure 14–8](#) shows the right-click menu for adding a node using the Technology map viewer.

**Figure 14–8. Finding Data Signals Using the Technology Map Viewer**



### Node List Signal Use Options

Once a signal is added to the node list, you can select options that specify how the signal is used with the logic analyzer. You can turn off the ability of a signal to trigger the analyzer by disabling the **Trigger Enable** option

for that signal in the node list in the **.stp** file. This option is useful when you want to see only the captured data for a signal and you are not using that signal as part of a trigger.

You can turn off the ability to view data for a signal by disabling the **Data Enable** column. This option is useful when you want to trigger on a signal, but have no interest in viewing data for that signal.

For information about using signals in the node list to create SignalTap II trigger conditions, refer to “[Define Triggers](#)” on page 14–31.

### *Untappable Signals*

Not all of the post-fitting signals in your design are available in the **SignalTap II: post-fitting** filter in the **Node Finder** dialog box. The following signal types cannot be tapped:

- Post-fit output pins—You cannot tap a post-fit output pin directly. To make an output signal visible, tap the register or buffer that drives the output pin.
- Signals that are part of a carry chain—You cannot tap the carry out (cout<sub>0</sub> or cout<sub>1</sub>) signal of a logic element. Due to architectural restrictions, the carry out signal can only feed the carry in of another logic element (LE).
- JTAG Signals—You cannot tap the JTAG control (TCK, TDI, TDO, and TMS) signals.
- ALTGX<sub>B</sub> megafunction—You cannot directly tap any ports of an ALTGX<sub>B</sub> instantiation.
- LVDS—You cannot tap the data output from a serializer/deserializer (SERDES) block.

### **Adding Signals with a Plug-In**

Instead of adding individual or grouped signals through the **Node Finder**, you can add groups of relevant signals of a particular type of IP through the use of a plug-in. The SignalTap II Logic Analyzer comes with one plug-in already installed for the Nios II processor. Besides easy signal addition, plug-ins also provide a number of other features, such as pre-designed mnemonic tables, useful for trigger creation and data viewing, as well as the ability to disassemble code in captured data.

The Nios II plug-in, for example, creates one mnemonic table in the **Setup** tab and two tables in the **Data** tab:

- **Nios II Instruction (Setup tab)**—Capture all the required signals for triggering on a selected instruction address.

- **Nios II Instance Address (Data tab)**—Display address of executed instructions in hexadecimal format or as a programming symbol name if defined in an optional Executable and Linking Format (.elf) file.
- **Nios II Disassembly (Data tab)**—Displays disassembled code from the corresponding address.

For information about the other features plug-ins provided, refer to “[Define Triggers](#)” on page 14–31 and “[View, Analyze, and Use Captured Data](#)” on page 14–66.

To add signals to the .stp file using a plug-in, perform the following steps after running Analysis and Elaboration on your design:

1. Right-click in the node list. On the **Add Nodes with Plug-In** submenu, click the name of the plug-in you want to use, such as the included plug-in named **Nios II**.
 

 If the intellectual property (IP) for the selected plug-in does not exist in your design, a message appears informing you that you cannot use the selected plug-in.
2. The **Select Hierarchy Level** dialog box appears showing the IP hierarchy of your design (Figure 14–9). Select the IP that contains the signals you want to monitor with the plug-in and click **OK**.

**Figure 14–9. IP Hierarchy Selection**



3. If all the signals in the plug-in are available, a dialog box might appear, depending on the plug-in selected, where you can set any available options for the plug-in. With the Nios II plug-in, you can optionally select an Executable and Linking Format (.elf) file containing program symbols from your Nios II Integrated Development Environment (IDE) software design. Set options for the selected plug-in as desired and click **OK**.



To make sure all the required signals are available, turn on the **Create debugging nodes for IP cores** option in the Quartus II **Analysis & Synthesis** settings.

All the signals included in the plug-in are added to the node list.

## Debugging Finite State Machines

Finding the signals to debug Finite State Machines (FSM) can be challenging. Finding nodes from the post-fit netlist maybe impossible, as FSM encoding signals may be changed or optimized away during synthesis and place-and-route. If you are able to find all of the relevant nodes in the post-fit netlist or you used the nodes from the pre-synthesis netlist, an additional step is required to find and map FSM signal values to the state names that you specified in your HDL.

Beginning with Quartus II software version 8.0, the SignalTap II GUI can detect FSMs in your compiled design. The SignalTap II configuration automatically tracks the FSM state signals as well as state encoding through the compilation process. Right-click dialog boxes from the SignalTap II GUI allow you to add all of the FSM state signals to your embedded logic analyzer with a single command. For each FSM added to your SignalTap II configuration, the FSM debugging feature adds a mnemonic table to map the signal values to the state enumeration that you provided in your source code. The mnemonic tables enable you to visualize state machine transitions in the waveform viewer easily. The FSM debugging feature supports adding FSM signals from both the pre-synthesis and post-fit netlists.

Figure 14–10 shows the waveform viewer with decoded signal values from a state machine added with the FSM debugging feature.

**Figure 14–10. Decoded FSM Mnemonics**





For coding guidelines for specifying FSM in Verilog and VHDL, refer to the *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook*.

To add pre-synthesis FSM signals to the configuration file, perform the following steps after running Analysis and Elaboration on your design:

1. Create a new .stp file or use an existing .stp file.

 Any .stp files that the MegaWizard Plug-In Manager creates from instantiations are not supported for this feature.

2. In the SignalTap II setup tab, right-click anywhere on the node list and select **Add State Machine Nodes**. The **Add State Machine Nodes** dialog box appears. This dialog box lists all the FSMs that have been found in your design.
3. From the Netlist pull-down menu, select **Pre-Synthesis**.
4. Select the desired FSM.
5. Click **OK**. This adds the FSM nodes to the configuration file. A mnemonic table is automatically applied to the FSM signal group.

To add post-fit FSM signals to the configuration file, perform the following steps:

1. Set the design partition of the FSM that you want to debug to post-fit.
2. Enable the .stp file for the Quartus II project using the SignalTap II Logic Analyzer page of the **Settings** dialog box. You can either create a new .stp file or use an existing .stp file.

 For the SignalTap II GUI to detect post-fit state-machine signals, perform a full compile of your design with an .stp file enabled. If you do not have a valid .stp file, you can enable the SignalTap II Logic Analyzer for your project by adding the following assignment to your .qsf file:

```
set_global_assignment -name ENABLE_SIGNALTAP ON
```

3. Perform a full compile of the design.

4. In the SignalTap II setup tab, right-click anywhere on the node list and select **Add State Machine Nodes**. The **Add State Machine Nodes** dialog box appears. This dialog box lists all the FSMs that have been found in your design.
5. From the Netlist pull-down menu, select **Post-Fit**.
6. Select the desired FSM.
7. Click **OK**. This adds the FSM nodes to the configuration file. A mnemonic table is automatically applied to the FSM signal group.

### *Modifying and Restoring Mnemonic Tables for State Machines*

When you add FSM state signals via the FSM debugging feature, the SignalTap II GUI creates a mnemonic table using the format `<StateSignalName>_table`, where **StateSignalName** is the name of the state signals that you have declared in your RTL. You can edit any mnemonic table using the **Mnemonic Table Setup** dialog box.

If you want to restore a mnemonic table that was modified, right-click anywhere in the node list window and select **Recreate State Machine Mnemonics**. By default, restoring a mnemonic table overwrites the existing mnemonic table that you modified. If you would like to restore a FSM mnemonic table to a new record, uncheck the **Overwrite existing mnemonic table** option in the **Recreate State Machine Mnemonics** dialog box.



If you have added or deleted a signal from the FSM state signal group from within the setup tab, delete the modified register group and add the FSM signals back again.

For more information about using Mnemonics, refer to “[Creating Mnemonics for Bit Patterns](#)” on page 14–67.

### *Additional Considerations*

The SignalTap II configuration GUI recognizes state machines from your design only if you use Quartus II Integrated Synthesis (QIS). The state machine debugging feature is not able to track the FSM signals or state encoding if you have used a third-party synthesis tool.

If you are adding post-fit FSM signals, the SignalTap II FSM debug feature may not be able to track all of the optimization changes that are a part of the compilation process. There are two specific optimizations that the SignalTap II FSM debug feature is not able to support:

- If you have physical synthesis turned on, state registers may be resource balanced (register retiming) to improve  $f_{MAX}$ . The FSM debug feature does not list post-fit FSM state registers if register retiming occurs.
- The FSM debugging feature does not list state signals that have been packed into RAM and DSP blocks during QIS or fitter optimizations.

You are still able to use the FSM debugging feature to add pre-synthesis state signals.

## Specifying the Sample Depth

The sample depth specifies the number of samples that are captured and stored for each signal in the captured data buffer. To set the sample depth, select the desired number of samples to store in the **Sample Depth** list. The sample depth ranges from 0 to 128K.

If device memory resources are limited, you may not be able to successfully compile your design with the sample buffer size you have selected. Try reducing the sample depth to reduce resource usage.

## Capturing Data to a Specific RAM Type

When you use the SignalTap II Logic Analyzer with some devices, you have the option to select the RAM type where acquisition data is stored. RAM selection allows you to preserve a specific memory block for your design and allocate another portion of memory for SignalTap II data acquisition. For example, if your design implements a large buffering application such as a system cache, it is ideal to place this application into M-RAM blocks so that the remaining M512 or M4K blocks are used for SignalTap II data acquisition.

To select the RAM type to use for the SignalTap II buffer, select it from the **RAM type** list. Use this feature when the acquired data (as reported by the SignalTap II resource estimator) is not larger than the available memory of the memory type that you have selected in the FPGA.

## Choosing the Buffer Acquisition Mode

The Buffer Acquisition Type Selection feature in the SignalTap II Logic Analyzer lets you choose how the captured data buffer is organized and can potentially reduce the amount of memory that is required for

SignalTap II data acquisition. You can choose to use either a circular buffer, which allocates the entire sample depth to a single buffer, or a segmented buffer, which splits the buffer space into a number of separate even-sized segments. [Figure 14-11](#) illustrates the differences between the two buffer types.

**Figure 14-11. Buffer Type Comparison in the SignalTap II Logic Analyzer** [Note \(1\)](#)



**Note to Figure 14-11:**

- Both circular and segmented buffers can use a predefined trigger position or define a custom trigger position using the **State-Based Triggering** tab. Refer to ["Specifying the Trigger Position"](#) on page 14-46 for more details.

### Circular Buffer

The circular buffer shown in [Figure 14-11](#) (a) is the default buffer type used by the SignalTap II Logic Analyzer. While the logic analyzer is running, data is stored in the buffer until it fills up, at which point new data replaces the oldest data. This continues until a specified trigger event occurs. When this happens, the logic analyzer continues to capture data after the trigger event until the buffer is full, based on the circular buffer trigger position setting in the **Signal Configuration** pane in the .stp file. Select a setting from the list to choose whether to capture the majority of the data before (**Post trigger position**) or after (**Pre trigger position**) the trigger occurs or to center the trigger position in the data (**Center trigger position**). Another option is to use the custom state-based triggering flow to define your desired triggering position precisely.

For more information, refer to ["Specifying the Trigger Position"](#) on page 14-46.

### Segmented Buffer

The segmented buffer shown in Figure 14-11 (b) organizes the buffer into a number of separate, evenly sized segments. This type of buffer organization makes it easier to debug systems that contain relatively infrequent recurring events. Figure 14-12 shows an example of this type of buffer system.

**Figure 14-12. Example System that Generates Recurring Events**



The SignalTap II Logic Analyzer verifies the functionality of the design shown in Figure 14-12 to ensure that the correct data is written to the SRAM controller. Buffer acquisition in the SignalTap II Logic Analyzer allows you to monitor the RDATA port when H'0F0F0F0F is sent into the RADDR port. You can monitor multiple read transactions from the SRAM device without running the SignalTap II Logic Analyzer again. The buffer acquisition feature allows you to segment the memory so that you can capture the same event multiple times without wasting allocated memory. The number of cycles that are captured depends on the number of segments specified under the **Data** settings.

To enable and configure buffer acquisition, select **Segmented** in the SignalTap II Editor and select the number of segments to use. In the example, selecting sixty-four, 64-sample segments allows you to capture 64 read cycles when the RADDR signal is H'0F0F0F0F.



For more information about buffer acquisition mode, refer to *Setting the Buffer Acquisition Mode* in the Quartus II Help.

## Managing Multiple SignalTap II Files and Configurations

In some cases you may have more than one .stp file in one design. Each file potentially has a different group of monitored signals. These signal groups make it possible to debug different blocks in your design. In turn, each group of signals can also be used to define different sets of trigger conditions. Along with each .stp file, there is also an associated programming file (SRAM Object File [.sof]). The settings in a selected SignalTap II file must match the SignalTap II logic design in the associated .sof file for the logic analyzer to run properly when the device is programmed. Managing all of the .stp files and their associated settings and programming files is a challenging task. To help you manage everything, use the Data Log feature and the SOF Manager.

The Data Log allows you to store multiple SignalTap II configurations within a single .stp file. Figure 14–13 shows two signal set configurations with multiple trigger conditions in one .stp file. To toggle between the active configurations, double-click on an entry in the Data Log. As you toggle between the different configurations, the signal list and trigger conditions change in the Setup tab of the .stp file. The active configuration displayed in the .stp file is indicated by the blue square around the signal set in the Data Log. To store a configuration in the Data Log, on the Edit menu, click **Save to Data Log** or click the **Save to Data Log** button at the top of the Data Log.

**Figure 14–13. Data Log**



The SOF Manager allows you to embed multiple SOFs into one **.stp** file. Embedding an SOF in an **.stp** file lets you move the **.stp** file to a different location, either on the same computer or across a network, without the need to include the associated **.sof** as a separate file. To embed a new SOF in the **.stp** file, right-click in the SOF Manager, and click **Attach SOF File** (Figure 14–14).

**Figure 14–14. SOF Manager**



As you switch between configurations in the Data Log, you can extract the SOF that is compatible with that particular configuration and use the programmer in the SignalTap II Logic Analyzer to download the new SOF to the FPGA. In this way, you ensure that the configuration of your **.stp** file always matches the design programmed into the target device.

## Define Triggers

To capture the data you want at the right time, specify the conditions under which the signals you are monitoring display that data. In the SignalTap II Logic Analyzer, these conditions are referred to as triggers, just as they are in conventional external logic analyzers and oscilloscopes. You have many options for creating different types of triggers to help in debugging.

### Creating Basic Trigger Conditions

The simplest kind of trigger condition is a basic trigger. Select this from the list at the top of the **Trigger Conditions** column in the node list in the SignalTap II Editor. With the trigger type set to **Basic**, set the trigger

pattern for each signal you have added in the **.stp** file. To set the trigger pattern, right-click in the **Trigger Conditions** column and click the desired pattern. Set the trigger pattern to any of the following conditions:

- Don't Care
- Low
- High
- Falling Edge
- Rising Edge
- Either Edge

For buses, type a pattern in binary, or right-click and select **Insert Value** to enter the pattern in other number formats. Note that you can enter X to specify a set of “don't care” values in either your hexadecimal or your binary string. For signals added to the **.stp** file that have an associated mnemonic table, you can right-click and select an entry from the table to set pre-defined conditions for the trigger.

For more information about creating and using mnemonic tables, refer to [“View, Analyze, and Use Captured Data” on page 14–66](#), and in the Quartus II Help.

For signals added with certain plug-ins, you can easily create basic triggers using pre-defined mnemonic table entries. For example, with the Nios II plug-in, if you have specified an executable software (**.elf**) file from your Nios II IDE design, you can type the name of a function from your Nios II code. The logic analyzer triggers when the Nios II instruction address matches the address of the specified code function name.

Data capture stops and the data is stored in the buffer when the logical AND of all the signals for a given trigger condition evaluates to TRUE.

## Creating Advanced Trigger Conditions

Along with the SignalTap II Logic Analyzer's basic triggering capabilities, you can build more complex triggers utilizing extra logic that enable you to capture data when a particular combination of conditions exist. If you set the trigger type to **Advanced** at the top of the **Trigger Conditions** column in the node list of the SignalTap II Editor, a new tab named **Advanced Trigger** appears where you can build a complex trigger expression using a simple GUI. You can drag-and-drop operators into the Advanced Trigger Configuration Editor window to build the complex

trigger condition in an expression tree. To configure the operators' settings double-click or right-click the operators that you have placed and select **Properties**. [Table 14–4](#) lists the operators you can use.

**Table 14–4. Advanced Triggering Operators *Note (1)***

| Name of Operator         | Type             |
|--------------------------|------------------|
| Less Than                | Comparison       |
| Less Than or Equal To    | Comparison       |
| Equality                 | Comparison       |
| Inequality               | Comparison       |
| Greater Than             | Comparison       |
| Greater Than or Equal To | Comparison       |
| Logical NOT              | Logical          |
| Logical AND              | Logical          |
| Logical OR               | Logical          |
| Logical XOR              | Logical          |
| Reduction AND            | Reduction        |
| Reduction OR             | Reduction        |
| Reduction XOR            | Reduction        |
| Left Shift               | Shift            |
| Right Shift              | Shift            |
| Bitwise Complement       | Bitwise          |
| Bitwise AND              | Bitwise          |
| Bitwise OR               | Bitwise          |
| Bitwise XOR              | Bitwise          |
| Edge and Level Detector  | Signal Detection |

*Note to Table 14–4:*

- (1) For more information about each of these operators, refer to the Quartus II Help.

You can configure some of the settings for certain operators at run-time. This enables you to change one operator type to another operator type or adjust other settings for an operator without recompiling your design. Operator settings that have a white background on the operator symbol can be changed without recompiling the design.

Adding many objects to the Advanced Trigger Condition Editor can make the work space cluttered and difficult to read. To keep objects organized while you build your advanced trigger condition, use the right-click menu and select **Arrange All Objects**. You can also use the **Zoom-Out** command to fit more objects into the Advanced Trigger Condition Editor window.

### *Examples of Advanced Triggering Expressions*

The following examples show how to use Advanced Triggering:

- Trigger when bus `outa` is greater than or equal to `outb` (Figure 14–15).

**Figure 14–15. Bus outa is Greater Than or Equal to Bus outb**



- Trigger when bus `outa` is greater than or equal to bus `outb`, and when the enable signal has a rising edge (Figure 14–16).

**Figure 14–16. Enable Signal has a Rising Edge**

```
Result: outa>=outb&&ELD({enable})
```



- Trigger when bus outa is greater than or equal to bus outb, or when the enable signal has a rising edge. Or, when a bitwise AND operation has been performed between bus outc and bus outd, and all bits of the result of that operation are equal to 1 (Figure 14–17).

**Figure 14–17. Bitwise AND Operation**

```
Result: outa>=outb||ELD({enable})||(&outc&outd)
```



## Trigger Condition Flow Control

The SignalTap II Logic Analyzer offers multiple triggering conditions to give you precise control of the method data is captured into the acquisition buffers. Trigger Condition Flow allows you to define the relationship between a set of triggering conditions. The SignalTap II Logic Analyzer offers two flow control mechanisms for organizing trigger conditions:

- Sequential Triggering—The default triggering flow. This flow allows you to define up to ten triggering levels that must be satisfied before the acquisition buffer finishes capturing.
- Custom State-Based Triggering—This flow allows you the greatest control over your acquisition buffer. This method allows you to organize trigger conditions into states based on a conditional flow that you define.

You can use either method with both a circular buffer or a segmented buffer.

### *Sequential Triggering*

Sequential triggering flow allows you to cascade up to ten levels of triggering conditions. The SignalTap II Logic Analyzer sequentially evaluates each of the triggering conditions. When the last triggering condition evaluates to TRUE, the SignalTap II Logic Analyzer triggers the acquisition buffer. For segmented buffers, every acquisition segment after the first segment triggers on the last triggering condition that you have specified. Use the Simple Sequential Triggering feature with basic triggers, advanced triggers, or a mix of both. [Figure 14–18](#) illustrates the simple sequential triggering flow for circular and segmented buffers.



The external trigger is considered as trigger level 0. The external trigger must be evaluated before the main trigger levels are evaluated.

Figure 14–18. Sequential Triggering Flow Notes (1), (2)

**Notes to Figure 14–18:**

- (1) The acquisition buffer stops capture when all  $n$  triggering levels are satisfied, where  $n \leq 10$ .
- (2) An external trigger input, if defined, is evaluated before all other defined trigger conditions are evaluated. For more information about external triggers, refer to “[Using External Triggers](#)” on page 14–49.

To configure the SignalTap II Logic Analyzer for Sequential triggering, in the SignalTap II editor on the **Trigger flow control** list, select **Sequential**. Select the desired number of trigger conditions by using the **Trigger Conditions** pull-down list. After you select the desired number of trigger conditions, configure each trigger condition in the node list. To disable any trigger condition, click the check box next to the trigger condition at the top of the column in the node list. [Figure 14–19](#) shows the **Setup** tab for Sequential Triggering.

Figure 14–19. Setup Tab



### Custom State-Based Triggering

Custom state-based triggering gives you the most control of triggering condition arrangement. This flow gives you the ability to describe the relationship between triggering conditions precisely, using an intuitive GUI and the SignalTap II Trigger Flow Description Language, a simple description language based upon conditional expressions. Tooltips within the custom triggering flow GUI allow you to describe your desired flow quickly. The custom state-based triggering flow allows for more efficient use of the space available in the acquisition buffer because only specific samples of interest are captured.

Figure 14–20 illustrates the custom state-based triggering flow. Events that trigger the acquisition buffer are organized by a user-defined state diagram. All actions performed by the acquisition buffer are captured by the states and all transition conditions between the states are defined by the conditional expressions that you specify within each state.

Figure 14–20. Custom State-Based Triggering Flow Notes (1), (2)

**Notes to Figure 14–20:**

- (1) You are allowed up to 20 different states.
- (2) An external trigger input, if defined, is evaluated before any conditions in the custom state-based triggering flow are evaluated. For more information, refer to “[Using External Triggers](#)” on page 14–49.

Each state allows you to define a set of conditional expressions. Each conditional expression is a Boolean expression dependent on a combination of triggering conditions (configured within the **Setup** tab), counters, and status flags. Counters and status flags are resources provided by the Signal Tap II custom-based triggering flow.

Within each conditional expression you define a set of “actions”. Actions include triggering the acquisition buffer to stop capture, a modification to either a counter or status flag, or a state transition.

Trigger actions can apply to either a single segment of a segmented acquisition buffer or to the entire circular acquisition buffer. Each trigger action provides you with an optional count that specifies the number of samples to be captured before stopping acquisition of the current segment. The count argument allows you to control the amount of data captured precisely before and after triggering event.

Resource manipulation actions allow you to increment and decrement counters or set and clear status flags. The counter and status flag resources are used as optional inputs in conditional expressions. Counters and status flags are useful for counting the number of occurrences of particular events and for aiding in triggering flow control.

This Signal Tap II custom state-based triggering flow allows you to capture a sequence of events that may not necessarily be contiguous in time; for example, capturing a communication transaction between two devices that includes a handshaking protocol containing a sequence of acknowledgements.

The **State-Based Trigger Flow** tab is the control interface for the custom state-based triggering flow. To enable this tab, on the **Trigger Flow Control** pull-down list, select **State-based**. (Note that when the **Trigger Flow control** option is set to **Sequential**, the **State-Based Trigger Flow** tab is hidden.)

Figure 14–21 shows the **Custom Trigger Flow** tab.

**Figure 14–21. State-Based Trigger Flow Tab**



The **State-Based Trigger Flow** tab is partitioned into the following three panes.

- State Diagram Pane
- Resources Pane
- State Machine Pane

### State Diagram Pane

The **State Diagram** pane provides a graphical overview of the triggering flow that you define. It shows the number of states available and the state transitions between all of the states. You can adjust the number of available states by using the pull-down menu above the graphical overview.

### State Machine Pane

The **State Machine** pane contains the text entry boxes where you can define the triggering flow and actions associated with each state. You can define the triggering flow using the Signal Tap II Trigger Flow Description Language, a simple language based on “if-else” conditional statements. Tooltips appear when you move the mouse over the cursor, to guide command entry into the state boxes. The GUI provides a syntax check on your flow description in real-time and highlights any errors in the text flow.



For a full description of the SignalTap II Trigger Flow Description Language, refer to “[SignalTap II Trigger Flow Description Language](#)” on page 14-42. You can also refer to the Quartus II Help.

The State Machine description text boxes default to show one text box per state. You can optionally have the entire flow description shown in a single text field. This option can be useful when copying and pasting a flow description from a template or an external text editor. To toggle between one window per state, or all states in one window, select the appropriate option under **State Display mode**.

### Resources Pane

The **Resources** pane allows you to declare Status Flags and Counters for use in the conditional expressions in the Custom Triggering Flow. Actions to decrement and increment counters or to set and clear status flags are performed within the triggering flow that you define.

You can set up to 20 counters and 20 status flags. Counter and status flags values may be initialized by right-clicking the status flag or counter name after selecting a number of them from the respective drop-down list, and selecting **Set Initial Value**. To set counter width, right-click the counter name and select **Set Width**. Counters and flag values are dynamically updated after acquisition has started to assist in debugging your trigger flow specification.

**Runtime Reconfigurability**—The **configurable at runtime** options in the **Resources** pane allows you to configure the custom-flow control options that can be changed at runtime without requiring a recompilation.

**Table 14–5** contains a description of options that can be reconfigured at runtime.

| <b>Table 14–5. Runtime Reconfigurable Settings</b> |                                                                                                                                                                                                               |
|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Setting</b>                                     | <b>Description</b>                                                                                                                                                                                            |
| Destination of goto action                         | Allows you to modify the destination of the state transition at runtime.                                                                                                                                      |
| Comparison values                                  | Allows comparison values in Boolean expressions to be modifiable at runtime. In addition, it allows the <code>segment_trigger</code> and trigger action post-fill count argument to be modifiable at runtime. |
| Comparison operators                               | Allows comparison operators in Boolean expressions to be modifiable at runtime.                                                                                                                               |
| Logical operators                                  | Allows the logical operators in Boolean expressions to be modifiable at runtime.                                                                                                                              |

You can restrict changes to your SignalTap configuration to include only the options that do not require a recompilation by using the pull-down menu above the trigger list in the **Setup** tab. The option **Allow trigger condition changes only** restricts changes to only the configuration settings that have the **configurable at runtime** set. With this option enabled, to modify Trigger Flow conditions in the **Custom Trigger Flow** tab, click the desired parameter in the text box and select a new parameter from the menu that appears.



The runtime configurable settings for the **Custom Trigger Flow** tab are on by default. You may get some performance advantages by disabling some of the runtime configurable options. For details about the effects of turning off the runtime modifiable options, refer to “[Performance and Resource Considerations](#)” on page 14–57.

### *SignalTap II Trigger Flow Description Language*

The Trigger Flow Description Language is based on a list of conditional expressions per state to define a set of actions. Each line in [Example 14–1](#) shows a language format. Keywords are shown in bold. Non-terminals are delimited by “<>” and are further explained in the following sections. Optional arguments are delimited by “[]” (Example 14–1).



Examples of Triggering Flow descriptions for common scenarios using the Signal Tap II Custom Triggering Flow are provided in “[Custom Triggering Flow Application Examples](#)” on page 14–81.

**Example 14-1. Trigger Flow Description Language Format** *Note (1)*

```

state <State_label>:
<action_list>

if ( <Boolean_expression> )
<action_list>
[else if ( <boolean_expression> )
 <action_list>] (1)
[else
 <action_list>]

```

*Note to Example 14-1:*

- (1) Multiple else if conditions are allowed.

The priority for evaluation of conditional statements is assigned from top to bottom. The *<boolean\_expression>* in an if statement can contain a single event, or it can contain multiple event conditions. The action\_list embedded within an if or an else if clause must be delimited by the begin and end tokens when the action list contains multiple statements. When the boolean expression is evaluated true, the logic analyzer analyzes all of the commands in the action list concurrently. The possible actions include:

- Triggering the acquisition buffer
- Manipulating a counter or status flag resource
- Defining a state transition

*State Labels*

State labels are identifiers that can be used in the action goto.

**state** <state\_label>: begins the description of the actions evaluated when this state is reached.

The description of a state ends with the beginning of another state or the end of the whole trigger flow description.

*Boolean\_expression*

*Boolean\_expression* is a collection of logical operators, relational operators, and their operands that evaluate into a Boolean result. Depending on the operator, the operand can be a reference to a trigger condition, a counter and a register, or a numeric value. Within an expression, parentheses can be used to group a set of operands.

**Logical operators** accept any boolean expression as an operand. The supported logical operators are shown in [Table 14–6](#).

| <b>Table 14–6. Logical Operators</b> |                    |                |
|--------------------------------------|--------------------|----------------|
| <b>Operator</b>                      | <b>Description</b> | <b>Syntax</b>  |
| !                                    | NOT operator       | ! expr1        |
| &&                                   | AND operator       | expr1 && expr2 |
|                                      | OR operator        | expr1    expr2 |

**Relational operators** are performed on counters or status flags. The comparison value—the right operator—must be a numerical value. The supported relational operators are shown in [Table 14–7](#).

| <b>Table 14–7. Relational Operators</b> |                          |                                   |
|-----------------------------------------|--------------------------|-----------------------------------|
| <b>Operator</b>                         | <b>Description</b>       | <b>Syntax Notes (1) (2)</b>       |
| >                                       | Greater than             | <identifier> > <numerical_value>  |
| >=                                      | Greater than or Equal to | <identifier> >= <numerical_value> |
| ==                                      | Equals                   | <identifier> == <numerical_value> |
| !=                                      | Does not equal           | <identifier> != <numerical_value> |
| <=                                      | Less than or equal to    | <identifier> <= <numerical_value> |
| <                                       | Less than                | <identifier> < <numerical_value>  |

*Notes to Table 14–7:*

- (1) <identifier> indicates a counter or status flag.
- (2) <numerical\_value> indicates an integer.

### Action\_list

**Action\_list** is a list of actions that can be performed when a state is reached and a condition is also satisfied. If more than one action is specified, they must be enclosed by begin and end. The actions can be categorized as resource manipulation actions, buffer control actions, and state transition actions. Each action is terminated by a semicolon (;).

### Resource Manipulation Action

The resources used in the trigger flow description can be either counters or status flags. [Table 14–8](#) shows the description and syntax of each action.

| <b>Table 14–8. Resource Manipulation Action</b> |                                          |                                   |
|-------------------------------------------------|------------------------------------------|-----------------------------------|
| Action                                          | Description                              | Syntax                            |
| increment                                       | Increments a counter resource by 1       | increment <counter_identifier>;   |
| decrement                                       | Decrements a counter resource by 1       | decrement <counter_identifier>;   |
| reset                                           | Resets counter resource to initial value | reset <counter_identifier>;       |
| set                                             | Sets a status Flag to 1                  | set <register_flag_identifier>;   |
| clear                                           | Sets a status Flag to 0                  | clear <register_flag_identifier>; |

### Buffer Control Action

Buffer control actions specify an action to control the acquisition buffer. [Table 14–9](#) shows the description and syntax of each action.

| <b>Table 14–9. Buffer Control Action</b> |                                                                                                                                                                                                                                                                                                                                                                   |                                    |
|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| Action                                   | Description                                                                                                                                                                                                                                                                                                                                                       | Syntax                             |
| trigger                                  | Stops the acquisition for the current buffer and ends analysis. This command is required in every flow definition.                                                                                                                                                                                                                                                | trigger <post-fill_count>;         |
| segment_trigger                          | Ends the acquisition of the current segment. The Signal Tap II Logic Analyzer starts acquiring from the next segment on evaluating this command. If all segments are filled, the oldest segment is overwritten with the latest sample. The acquisition stops when a trigger action is evaluated.<br>This action cannot be used in non-segmented acquisition mode. | segment_trigger <post-fill_count>; |

Both **trigger** and **segment\_trigger** actions accept an optional post-fill count argument. If provided, the current acquisition acquires the number of samples provided by post-fill count and then stops acquisition. If no post-count value is specified, the trigger position for the affected buffer defaults to the trigger position specified in the **Setup** tab.



In the case of `segment_trigger`, acquisition of the current buffer stops immediately if a subsequent triggering action is issued in the next state, regardless of whether or not the post-fill count has been satisfied for the current buffer. The remaining unfilled post-count acquisitions in the current buffer are discarded and displayed as grayed-out samples in the data window.

### *State Transition Action*

The State Transition action specifies the next state in the custom state control flow. It is specified by the `goto` command. The syntax is as follows:

```
goto <state_label>;
```

### **Specifying the Trigger Position**

The SignalTap II Logic Analyzer allows you to specify the amount of data that is acquired before and after a trigger event. You can set the trigger position independently between a Runtime and Power-Up Trigger. Select the desired ratio of pre-trigger data to post-trigger data by choosing one of the following ratios:

- **Pre**—This selection saves signal activity that occurred after the trigger (12% pre-trigger, 88% post-trigger).
- **Center**—This selection saves 50% pre-trigger and 50% post-trigger data.
- **Post**—This selection saves signal activity that occurred before the trigger (88% pre-trigger, 12% post-trigger).

These pre-defined ratios apply to both circular buffers and segmented buffers.

If you use the custom-state based triggering flow, you can specify a custom trigger position. The `segment_trigger` and `trigger` actions accept a post-fill count argument. The post-fill count specifies the number of samples to capture before stopping data acquisition for the circular buffer or a data segment when using the `trigger` and `segment_trigger` commands, respectively. When the captured data is displayed in the SignalTap II data window, the trigger position appears as the number of post-count samples from the end of the acquisition segment or buffer. Refer to [Equation 1](#):

$$(1) \quad \text{Sample Number of Trigger Position} = (N - \text{Post-Fill Count})$$

In this case,  $N$  is the sample depth of either the acquisition segment or circular buffer.

For segmented buffers, the acquisition segments that have a post-count argument defined use the post-count setting. Segments that do not have a post-count setting default to the trigger position ratios defined in the **Setup** tab.

For more details about the custom state-based triggering flow, refer to “[Custom State-Based Triggering](#)” on page [14-38](#).

## Creating a Power-Up Trigger

Typically, the SignalTap II Logic Analyzer is used to trigger on events that occur during normal device operation. You start an analysis manually once the target device is fully powered on and the device’s JTAG connection is available. However, there may be cases when you would like to capture trigger events that occur during device initialization, immediately after the FPGA is powered on or reset. With the SignalTap II Power-Up Trigger feature, you can capture data from triggers that occur after device programming but before the logic analyzer is started manually.

### *Enabling a Power-Up Trigger*

You can add a different Power-Up Trigger to each logic analyzer instance in the SignalTap II Instance Manager. To enable the Power-Up Trigger for a logic analyzer instance, right-click the instance and click **Enable Power-Up Trigger**, or select the instance, and on the Edit menu, click **Enable Power-Up Trigger**. To disable a Power-Up Trigger, click **Disable Power-Up Trigger** in the same locations. **Power-Up Trigger** is shown as a child instance below the name of the selected instance with the default trigger conditions set in the node list. [Figure 14-22](#) shows the SignalTap II Editor when Power-Up Trigger is enabled.

Figure 14–22. *SignalTap II Editor with Power-Up Trigger Enabled*

### Managing and Configuring Power-Up and Runtime Trigger Conditions

When the Power-Up Trigger is enabled for a logic analyzer instance, you can create basic and advanced trigger conditions for it in the same way you do with the regular trigger, also called the Runtime Trigger.

Power-Up Trigger conditions that you can adjust are color coded light blue, while Run-Time Trigger conditions remain white. Since each instance now has two sets of trigger conditions—the Power-Up Trigger and the Run-Time Trigger—you can differentiate between the two with color coding. To switch between the trigger conditions of the Power-Up Trigger and the Runtime Trigger, double-click the instance name or the Power-Up Trigger name in the Instance Manager.

You cannot make changes to Power-Up Trigger conditions that would normally require a full recompile with Runtime Trigger conditions, such as adding signals, deleting signals, or changing between basic and advanced triggers. For these changes to be applied to the Power-Up Trigger conditions, first make the changes using the Runtime Trigger conditions.



Any change made to the Power-Up Trigger conditions requires that the SignalTap II Logic Analyzer be recompiled, even if a similar change to the Runtime Trigger conditions does not require a recompilation.

While creating or making changes to the trigger conditions for the Run-Time Trigger or the Power-Up Trigger, you may want to copy these conditions to the other trigger. This makes it easy to look for the same trigger during both power-up and runtime. To do this, right-click the instance name or the Power-Up Trigger name in the Instance Manager and click **Duplicate Trigger**, or select the instance name or the Power-Up Trigger name and, on the Edit menu, click **Duplicate Trigger**.

For information about running the SignalTap II Logic Analyzer instance with a Power-Up Trigger enabled, refer to “[Running with a Power-Up Trigger](#)” on page 14–64.

## Using External Triggers

You can create a trigger input that allows you to trigger the SignalTap II Logic Analyzer from an external source. The external trigger input behaves like trigger condition 1. It is evaluated and must be TRUE before any other configured trigger conditions are evaluated. The analyzer can also supply a signal to trigger external devices or other SignalTap II instances. These features allow you to synchronize external logic analysis equipment with the internal logic analyzer. Power-Up Triggers can use the external triggers feature, but they must use the same source or target signal as their associated Run-Time Trigger.

### *Trigger In*

To use Trigger In, perform the following steps:

1. In the SignalTap II Editor, click the **Setup** tab.
2. If a Power-Up Trigger is enabled, ensure you are viewing the Runtime Trigger conditions.
3. In the **Signal Configuration** pane, turn on **Trigger In**.
4. In the **Pattern** list, select the condition you want to act as your trigger event. You can set this separately for Runtime or Power-Up Trigger.
5. Click **Browse** next to the **Source** field in the **Trigger In** pane ([Figure 14–24 on page 14–52](#)). The **Node Finder** dialog box appears.

6. In the **Node Finder** dialog box, select the signal (either an input pin or an internal signal) that you want to drive the Trigger In source and click **OK**.

If you type a new signal name in the **Source** field, you create a new node that you can assign to an input pin in the Pin Planner or Assignment editor. If you leave the **Source** field blank, a default name is entered in the form `auto_stp_trigger_in_<SignalTap instance number>`.

### *Trigger Out*

To use Trigger Out, perform the following steps:

1. In the SignalTap II Editor, click the **Setup** tab.
2. If a Power-Up trigger is enabled, ensure you are viewing the Runtime Trigger conditions.
3. To signify that the trigger event is occurring, in the **Signal Configuration** pane, turn on **Trigger Out** (refer to [Figure 14-23 on page 14-51](#))
4. In the **Level** list, select the condition you want. You can set this separately for a Run-Time or a Power-Up Trigger.
5. Type a new signal name in the **Target** field. A new node name is created that you must assign to an output pin in the Pin Planner or Assignment editor.

If you leave the **Target** field blank, a default name is entered in the form `auto_stp_trigger_out_<SignalTap instance number>`. When the logic analyzer triggers, a signal at the level you indicated is output on the pin you assigned to the new node.

### *Using the Trigger Out of One Analyzer as the Trigger In of Another Analyzer*

An advanced feature of the SignalTap II Logic Analyzer is the ability to use the Trigger Out of one analyzer as the Trigger In to another analyzer. This feature allows you to synchronize and debug events that occur across multiple clock domains.

To perform this operation, first enable the **Trigger Out** of the source logic analyzer instance. On the Trigger out **Target** list, select the targeted logic analyzer instance. For example, if the instance named `auto_singaltap_0` should trigger `auto_singaltap_1`, select `auto_singaltap_1|trigger_in` from the list (Figure 14-23).

**Figure 14-23. Configuring the Trigger Out Signal**



- This automatically enables the Trigger In of the targeted logic analyzer instance and fills in the Trigger In **Source** field with the Trigger Out signal from the source logic analyzer instance. In this example, `auto_singaltap_0` is targeting `auto_singaltap_1`. The Trigger In **Source** field of `auto_singaltap_1` is automatically filled in with `auto_singaltap_0|trigger_out` (Figure 14-24).

Figure 14–24. Configuring the Trigger In Signal



## Compile the Design

When you add an .stp file to your project, the SignalTap II Logic Analyzer becomes part of your design. You must compile your project to incorporate the SignalTap II logic and enable the JTAG connection that is used to control the logic analyzer. When you are debugging with a traditional external logic analyzer, it is often necessary to make changes to the signals monitored as well as the trigger conditions. Since these adjustments often translate into recompilation time when using the SignalTap II Logic Analyzer, use the SignalTap II Logic Analyzer feature along with incremental compilation in the Quartus II software to reduce time spent recompiling.

## Faster Compilations with Quartus II Incremental Compilation

To use Incremental compilation with the SignalTap II Logic Analyzer, perform the following steps:

- Enable **Full Incremental Compilation** for your design
- Assign design partitions
- Set partitions to the proper preservation levels
- Enable **SignalTap** for your design
- Add signals to **SignalTap** using the appropriate netlist filter in the node finder (either SignalTap II: pre-synthesis or SignalTap II: post-fitting).

When you compile your design with an **.stp** file, the **s1d\_signaltap** and **s1d\_hub** entities are automatically added to the compilation hierarchy. These two entities are the main components of the SignalTap II Logic Analyzer, providing the trigger logic and JTAG interface required for operation.

Incremental compilation enables you to preserve the synthesis and fitting results of your original design and add the SignalTap II Logic Analyzer to your design without recompiling your original source code. This feature is also useful when you want to modify the configuration of the **.stp** file. For example, you can modify the buffer sample depth or memory type without performing a full compilation after the change is made. Only the SignalTap II Logic Analyzer, configured as its own design partition, must be recompiled to reflect the changes.

To use incremental compilation, first enable **Full Incremental Compilation** for your design if it is not already enabled, assign design partitions if necessary, and set the design partitions to the correct preservation levels. Incremental compilation is the default setting for new projects in the Quartus II software, so you can establish design partitions immediately in a new project. However, it is not necessary to create any design partitions to use the SignalTap II Incremental Compilation feature. Once your design is set up to use full incremental compilation, the SignalTap II Logic Analyzer acts as its own separate design partition. You can begin taking advantage of incremental compilation by using the **SignalTap II: post-fitting filter** in the **Node Finder** to add signals for logic analysis.

### *Enabling Incremental Compilation for Your Design*

To enable Incremental Compilation if it is not already enabled, perform the following steps:

1. On the Assignments menu, click the **Design Partitions** window.

2. In the **Incremental Compilation** list, select **Full Incremental Compilation**.
3. Create user-defined partitions if desired and set the **Netlist Type** to **Post-fit** for all partitions.



The netlist type for the top-level partition defaults to source. To take advantage of incremental compilation, set the Netlist types for the partitions you wish to tap as post-fit.

4. On the Processing menu, click **Start Compilation**, or, on the toolbar, click **Start Compilation**.

Your project is fully compiled the first time, establishing the design partitions you have created. When enabled for your design, the SignalTap II Logic Analyzer is always a separate partition. After the first compilation, you can use the SignalTap II Logic Analyzer to analyze signals from the post-fit netlist. If your partitions are set correctly, subsequent compilations due to SignalTap II settings are able to take advantage of the shorter compilation times.



For more information about configuring and performing Incremental Compilation, refer to the *Quartus II Incremental Compilation for Hierarchical and Team-Based Design* chapter in volume 1 of the *Quartus II Handbook*.

### *Using Incremental Compilation with the SignalTap II Logic Analyzer*

The SignalTap II Logic Analyzer is automatically configured to work with the incremental compilation flow. For all signals that you want to connect to the SignalTap II Logic Analyzer from the post-fit netlist, set the netlist type of the partition containing the desired signals to Post-Fit or Post-Fit (Strict) with a Fitter Preservation Level of Placement and Routing using the **Design Partitions** window. Use the **SignalTap II: post-fitting filter** in the **Node Finder** to add the signals of interest to your SignalTap II configuration file. If you want to add signals from the pre-synthesis netlist, set the netlist type to **Source File** and use the **SignalTap II: pre-synthesis filter** in the **Node Finder**. Do not use the netlist type **Post-Synthesis** with the SignalTap II Logic Analyzer.



Be sure to conform to the following guidelines when using post-fit and pre-synthesis nodes:

- Read all incremental compilation guidelines to ensure the proper partition of a project.
- To speed compile time, use only post-fit nodes for partitions set to preservation-level post-fit.

- Do not mix pre-synthesis and post-fit nodes in any partition. If you must tap pre-synthesis nodes for a particular partition, make all tapped nodes in that partition pre-synthesis nodes and change the netlist type to **source** in the design partitions window.

Node names may be different between a pre-synthesis netlist and a post-fit netlist. In general, registers and user input signals share common names between the two netlists. During compilation, certain optimizations change the names of combinational signals in your RTL. If the type of node name chosen does not match the netlist type, the compiler may not be able to find the signal to connect to your SignalTap II Logic Analyzer instance for analysis. The compiler issues a critical warning to alert you of this scenario. The signal that is not connected is tied to ground in the **SignalTap II data** tab.

If you do use incremental compile flow with the SignalTap II Logic Analyzer and source file changes are necessary, be aware that you may have to remove compiler-generated post-fit net names. Source code changes force the affected partition to go through resynthesis. During synthesis, the compiler cannot find compiler-generated net names from a previous compilation.



Altera recommends using only registered and user-input signals as debugging taps in your **.stp** file whenever possible.

Both registered and user-supplied input signals share common node names in the pre-synthesis and post-fit netlist. As a result, using only registered and user-supplied input signals in your **.stp** file limits the changes you need to make to your SignalTap configuration.

To verify that your original design was not modified, examine the messages in the **Partition Merge** section of the Compilation Report. [Figure 14–25](#) shows an example of the messages displayed.

Figure 14–25. Compilation Report Messages



Unless you make changes to your design partitions that require recompilation, only the SignalTap II design partition is recompiled. If you make subsequent changes to only the **.stp** file, only the SignalTap II design partition must be recompiled, reducing your recompilation time.

## Preventing Changes Requiring Recompilation

You can configure the **.stp** file to prevent changes that normally require recompilation. To do this, by select a lock mode from above the node list in the **Setup** tab. Whether you are using incremental compilation or not, lock your configuration by choosing to allow only trigger condition changes.

For more information about the use of lock modes, refer to Quartus II Help.

## Timing Preservation with the SignalTap II Logic Analyzer

In addition to verifying functionality, timing closure is one of the most crucial processes in successfully completing a design. When you compile a project with a SignalTap II Logic Analyzer without the use of incremental compilation, you add IP to your existing design. Therefore, you can affect the existing placement, routing, and timing of your design. To minimize the effect that the SignalTap II Logic Analyzer has on your design, Altera recommends that you use incremental compilation for your project. Incremental compilation is the default setting in new

designs and can be easily enabled and configured in existing designs. With the SignalTap II Logic Analyzer in its own design partition, it has little to no affect on your design.

In addition to using the incremental compilation flow for your design, you can use the following techniques to help maintain timing:

- Avoid adding critical path signals to your .stp file.
- Minimize the number of combinational signals you add to your .stp file and add registers whenever possible.
- Specify an  $f_{MAX}$  constraint for each clock in your design.



For an example of timing preservation with the SignalTap II Logic Analyzer, refer to the *Area and Timing Optimization* chapter in volume 2 of the *Quartus II Handbook*.

## Performance and Resource Considerations

There is an inherent trade-off between runtime flexibility of the SignalTap II Logic Analyzer, timing performance of the Signal Tap II Logic Analyzer, and resource usage. The SignalTap II Logic Analyzer allows you to select the runtime configurable parameters to balance the need for runtime flexibility, speed, and area. The default values have been chosen to provide maximum flexibility so you can reach debugging closure as quickly as possible; however, you can adjust these settings to determine whether there is a more optimal configuration for your design.

The suggestions in this section provide some tips to provide extra timing slack if you have determined that the SignalTap II logic is in your critical path, or to alleviate the resource requirements that the SignalTap II Logic Analyzer consumes if your design is resource-constrained.

If SignalTap II logic is part of your critical path, the following suggestions can help to speed up the performance of the SignalTap II Logic Analyzer:

- **Disable runtime configurable options**—Certain resources are allocated to accommodate for runtime flexibility. If you are using either advanced triggers or state-based triggering flow, disable runtime configurable parameters for a boost in  $f_{MAX}$  of the SignalTap II logic. If you are using state-based triggering flow, try disabling the **Goto state destination** option and performing a recompilation before disabling the other runtime configurable options. The **Goto state destination** option has the greatest impact on  $f_{MAX}$  as compared to the other runtime configurable options.

- **Minimize the number of signals that have Trigger Enable selected**—All of the signals that you add to the .stp file have Trigger Enable turned on. Turn off Trigger Enable for signals that you do not plan to use as triggers.
- **Turn on Physical Synthesis for register retiming**—If you have a large number of triggering signals enabled (greater than the number of inputs that would fit in a LAB) that fan-in to logic gate-based triggering condition, such as a basic trigger condition or a logical reduction operator in the advanced trigger tab, turn on the **Perform register retiming** option. This can help balance combinational logic across LABs.

If your design is resource constrained, the following suggestions can help to reduce the amount of logic or memory used by the SignalTap II Logic Analyzer:

- **Disable runtime configurable options**—Disabling runtime configurability for advanced trigger conditions or runtime configurable options in the state-based triggering flow results in using fewer LEs.
- **Minimize the number of segments in the acquisition buffer**—You can reduce the number of logic resources used for the SignalTap II Logic Analyzer by limiting the number of segments in your sampling buffer to only those required.
- **Disable the Data Enable for signals that are used for triggering only**—By default, both the **data enable** and **trigger enable** options are selected for all signals. Turning off the **data enable** option for signals used as trigger inputs only saves on memory resources used by the SignalTap II Logic Analyzer.

Because performance results are design-dependent, try these options in different combinations until you achieve the desired balance between functionality, performance, and utilization.



For more information about area and timing optimization, refer the *Area and Timing Optimization* chapter in volume 2 of the *Quartus II Handbook*.

## Program the Target Device or Devices

Once your project, including the SignalTap II Logic Analyzer, is compiled, configure the FPGA target device. When you are using the SignalTap II Logic Analyzer for debugging, configure the device from the **.stp** file instead of the Quartus II Programmer. Because you configure from the **.stp** file, you can open more than one **.stp** file and program multiple devices to debug multiple designs simultaneously.

The settings in an **.stp** file must be compatible with the programming **.sof** file used to program the device. An **.stp** file is considered compatible with an **.sof** file when the settings for the logic analyzer, such as the size of the capture buffer and the signals selected for monitoring or triggering, match the way the target device will be programmed. If the files are not compatible, you can still program the device, but you will not be able to run or control the logic analyzer from the SignalTap II Editor.

To ensure programming compatibility, make sure to program your device with the latest SOF created from the most recent compilation.

Before starting a debugging session, do not make any changes to the **.stp** file settings that would require the project to be recompiled. You can check the SignalTap II status display at the top of the Instance Manager to see if a change you made requires the design to be recompiled, producing a new SOF. This gives you the opportunity to undo the change, so that a recompilation is not necessary. To prevent any such changes, enable lock mode in the **.stp** file.

### Programming a Single Device

To configure a single device for use with the SignalTap II Logic Analyzer, perform the following steps:

1. In the **JTAG Chain Configuration** pane in the SignalTap II Editor, select the connection you use to communicate with the device from the **Hardware** list. If you need to add your communication cable to the list, click **Setup** to configure your connection.
2. Click **Browse** in the **JTAG Chain Configuration** pane and select the **.sof** file that includes the compatible SignalTap II Logic Analyzer.
3. Click **Scan Chain**. The Scan Chain operation enumerates all of the JTAG devices within your JTAG chain.
4. In the **Device** list, select the device to which you want to download the design. The device list shows an ordered list of all devices in the JTAG chain.

All of the devices are numbered sequentially according to their position in the JTAG chain, prefixed with the “@”. For example: @1 : EP3C25 (0x020F30DD) lists a Cyclone III device as the first device in the chain with the JTAG ID code of 0x020F30DD.

5. Click the **Program Device** icon.

## Programming Multiple Devices to Debug Multiple Designs

You can simultaneously debug multiple designs using one instance of the Quartus II software by performing the following steps:

1. Create, configure, and compile each project that includes an **.stp** file.
  2. Open each **.stp** file.
-  You do not have to open a Quartus II project to open an **.stp** file.
3. Use the **JTAG Chain Configuration** pane controls to select the target device in each **.stp** file.
  4. Program each FPGA.
  5. Run each analyzer independently.

Figure 14–26 shows a JTAG chain and its associated **.stp** files.

**Figure 14–26. JTAG Chain**



## Run the SignalTap II Logic Analyzer

After the device is configured with your design that includes the SignalTap II Logic Analyzer, perform debugging operations in a manner similar to the use of an external logic analyzer. You “arm” the logic analyzer by starting an analysis. When your trigger event occurs, the captured data is stored in the memory buffer on the device and then transferred to the **.stp** file over the JTAG connection. You can also perform the equivalent of a “force trigger” that lets you view the captured data currently in the buffer without a trigger event occurring.

Figure 14–27 illustrates a flow that shows how you operate the

SignalTap II Logic Analyzer. The flowchart indicates where Power-Up and Runtime Trigger events occur and when captured data from these events is available for analysis.

**Figure 14-27. Power-Up and Runtime Trigger Events Flowchart**



The SignalTap II toolbar in the Instance Manager has four options for running the analyzer:

- **Run Analysis**—The SignalTap II Logic Analyzer runs until the trigger event occurs. When the trigger event occurs, monitoring and data capture stops once the acquisition buffer is full.
- **AutoRun Analysis**—The SignalTap II Logic Analyzer continuously captures data until the **Stop Analysis** button is clicked, ignoring all trigger event conditions.
- **Stop Analysis**—SignalTap II analysis stops. The acquired data does not appear automatically if the trigger event has not occurred.
- **Read Data**—Captured data is displayed. This button is useful if you want to view the acquired data even if the trigger has not occurred.

## Capturing Data Using Segmented Buffers

Segmented Acquisition buffers allow you to perform multiple captures with a separate trigger condition for each acquisition segment. This feature allows you to capture an recurring event or sequence of events that span over a long period time efficiently. Each acquisition segment acts as a circular buffer, continuously capturing data when it is activated. When you run an analysis with the **segmented buffer** option enabled, the SignalTap II Logic Analyzer performs back-to-back data captures for each acquisition segment within your data buffer. The trigger flow, or the type and order in which the trigger conditions evaluate for each buffer, is defined by either the Sequential trigger flow control or the Custom State-based trigger flow control. [Figure 14–28](#) shows a segmented acquisition buffer with four segments represented as four separate circular buffers.

**Figure 14–28. Segmented Acquisition Buffer**



The SignalTap II Logic Analyzer finishes an acquisition with a segment, and advances to the next segment to start a new acquisition. Depending when on a trigger condition occurs, it may affect the way the data capture appears in the waveform viewer. [Figure 14–28](#) illustrates the method data is captured. In this diagram, Trigger 1, Trigger 2, Trigger 3 and Trigger 4

refer the evaluation of the `segment_trigger` and `trigger` commands in the Custom State-based trigger flow and the trigger conditions in the **Setup** tab for the sequential trigger flow.

If the Segment 1 Buffer is the active segment and Trigger 1 occurs, the SignalTap II Logic Analyzer starts evaluating Trigger 2 immediately. Data Acquisition for Segment 2 buffer starts when either Segment Buffer 1 finishes its post-fill count, or when Trigger 2 evaluates as TRUE, whichever condition occurs first. Thus, trigger conditions associated with the next buffer in the data capture sequence can preempt the post-fill count of the current active buffer. This is necessary so the SignalTap II Logic Analyzer can capture all of the trigger conditions that have occurred accurately. Samples that have not been used appear as a blank space in the waveform viewer.

Figure 14–29 shows an example of a capture using sequential flow control with the trigger condition for each segment set to “don’t care”. Each segment before the last captures only one sample, because the next trigger condition immediately preempts capture of the current buffer. The trigger position for all segments is set to pre-trigger (10% of the data is before the trigger condition and 90% of the data is after the trigger position). Because the last segment starts immediately with the trigger condition, the segment contains only post-trigger data. The three empty samples in the last segment is the space left over from the pre-trigger samples that the SignalTap II Logic Analyzer allocated to the buffer.

**Figure 14–29. Segmented Capture with Preemption of Acquisition Segments Note (1)**

| Node  |       |         | click to insert time bar |    |   |    |   |
|-------|-------|---------|--------------------------|----|---|----|---|
| Type  | Alias | Name    | 0                        | 1  | 2 | 3  | 4 |
| Scope |       | + state | -2                       | 14 | 0 | 16 | 0 |

1h      1h      1h

**Note to Figure 14–29:**

- (1) A segmented acquisition buffer using the sequential trigger flow with a trigger condition set to “don’t care”. Each segment before the last captures only one sample because the next trigger condition immediately preempts capture of the current buffer.

For the sequential trigger flow, the **Trigger Position** option applies to every segment in the buffer. For maximum flexibility on how the trigger position is defined, use the custom state-based trigger flow. By adjusting the trigger position that is specific to your debugging scenario, you can help maximize the use of the allocated buffer space.

## Running with a Power-Up Trigger

If you have enabled and set up a Power-Up Trigger for an instance of the SignalTap II Logic Analyzer, the captured data may already be available for viewing if the trigger event occurred after device configuration. To download the captured data or to check if the Power-Up Trigger is still running, click **Run Analysis** in the Instance Manager. If the Power-Up Trigger occurred, the logic analyzer immediately stops, and the captured data is downloaded from the device. The data can now be viewed on the **Data** tab of the SignalTap II Editor. If the Power-Up Trigger did not occur, no captured data is downloaded, and the logic analyzer continues to run. You can wait for the Power-Up Trigger event to occur, or, to stop the logic analyzer, click **Stop Analysis**.

## Running with Runtime Triggers

You can arm and run the SignalTap II Logic Analyzer manually after device configuration to capture data samples based on the Runtime Trigger. You can do this immediately if there is no Power-Up Trigger enabled. If a Power-Up Trigger is enabled, you can do this after the Power-Up Trigger data is downloaded from the device or once the logic analyzer is stopped because the Power-Up Trigger event did not occur. Click **Run Analysis** in the SignalTap II Editor to start monitoring for the trigger event. You can start multiple SignalTap II instances at the same time by selecting all of the required instances before you click **Run Analysis** on the toolbar.

Unless the logic analyzer is stopped manually, data capture begins when the trigger event evaluates to TRUE. When this happens, the captured data is downloaded from the buffer. You can view the data in the **Data** tab of the SignalTap II Editor.

## Performing a Force Trigger

Sometimes when you use an external logic analyzer or oscilloscope, you want to see the current state of signals without setting up or waiting for a trigger event to occur. This is referred to as a “force trigger” operation, because you are forcing the test equipment to capture data without regard to any set trigger conditions. With the SignalTap II Logic Analyzer, you can choose to run the analyzer and capture data immediately or run the analyzer and capture data when you want.



For more information, refer to the *Design Debugging Using In-System Sources and Probes* chapter in volume 3 of the *Quartus II Handbook*.

To run the analyzer and immediately capture data, disable the trigger conditions by turning off each **Trigger Condition** column in the node list. This operation does not require a recompilation. Click **Run Analysis** in the Instance Manager. The SignalTap II Logic Analyzer immediately triggers, captures, and downloads the data to the **Data** tab of the SignalTap II Editor. If the data does not download automatically, click **Read Data** in the Instance Manager.

If you want to choose when to capture data manually, it is not required that you disable the trigger conditions. To start the logic analyzer, click **Autorun Analysis**; to capture data, click **Stop Analysis**. If the data does not download to the **Data** tab of the SignalTap II Editor automatically, click **Read Data**.



You can also use In-System Sources and Probes in conjunction with the SignalTap II Logic Analyzer to force trigger conditions. The In-System Sources and Probes feature allows you to drive and sample values on to selected nets over the JTAG chain. For more information, refer to the *Design Debugging Using In-System Sources and Probes* chapter in volume 3 of the *Quartus II Handbook*.

## SignalTap II Status Messages

Table 14–10 describes the text messages that might appear in the SignalTap II Status Indicator in the Instance Manager before, during, and after a data acquisition. Use these messages to know the state of the logic analyzer or what operation it is performing.

**Table 14–10. Text Messages in the SignalTap II Status Indicator (Part 1 of 2)**

| Message                                   | Message Description                                                                                                                                                                  |
|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Not running                               | The SignalTap II Logic Analyzer is not running. There is no connection to a device or the device is not configured.                                                                  |
| (Power-Up Trigger) Waiting for clock (1)  | The SignalTap II Logic Analyzer is performing a Runtime or Power-Up Trigger acquisition and is waiting for the clock signal to transition.                                           |
| Acquiring (Power-Up) pre-trigger data (1) | The trigger condition has not been evaluated yet. A full buffer of data is collected if the circular buffer acquisition mode is selected.                                            |
| Trigger In conditions met                 | Trigger In condition has occurred. The SignalTap II Logic Analyzer is waiting for the condition of the first trigger condition to occur. This can appear if Trigger In is specified. |
| Waiting for (Power-up) trigger (1)        | The SignalTap II Logic Analyzer is now waiting for the trigger event to occur.                                                                                                       |

| <b>Table 14–10. Text Messages in the SignalTap II Status Indicator (Part 2 of 2)</b> |                                                                                                                                                                                                                                                      |
|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Message</b>                                                                       | <b>Message Description</b>                                                                                                                                                                                                                           |
| Trigger level <x> met                                                                | The condition of trigger condition $x$ has occurred. The SignalTap II Logic Analyzer is waiting for the condition specified in condition $x + 1$ to occur.                                                                                           |
| Acquiring (power-up) post-trigger data (1)                                           | The whole trigger event has occurred. The SignalTap II Logic Analyzer is acquiring the post-trigger data. The amount of post-trigger data collected is user-defined between 12%, 50%, and 88% when the circular buffer acquisition mode is selected. |
| Offload acquired (Power-Up) data (1)                                                 | Data is being transmitted to the Quartus II software through the JTAG chain.                                                                                                                                                                         |
| Ready to acquire                                                                     | The SignalTap II Logic Analyzer is waiting for the user to arm the analyzer.                                                                                                                                                                         |

**Note to Table 14–10:**

- (1) This message can appear for both Runtime and Power-Up Trigger events. When referring to a Power-Up Trigger, the text in parentheses is added.



In segmented acquisition mode, pre-trigger and post-trigger do not apply.

## View, Analyze, and Use Captured Data

Once a trigger event has occurred or you capture data manually, you can use the SignalTap II interface to examine the data, and use your findings to help debug your design.

### Viewing Captured Data

You can view captured SignalTap II data in the **Data** tab of the **.stp** file (Figure 14–30). Each row of the **Data** tab displays the captured data for one signal or bus. Buses can be expanded to show the data for each individual signal on the bus. Click on the data waveforms to zoom in on the captured data samples; right-click to zoom out.

Figure 14–30. Captured SignalTap II Data



When viewing captured data, it is often useful to know the time interval between two events. Time bars enable you to see the number of clock cycles between two samples of captured data in your system. There are two types of time bars:

- **Master Time Bar**—The master time bar's label displays the absolute time of its location in bold. The master time bar is a thick black line in the **Data** tab. The captured data has only one master time bar.
- **Reference Time Bar**—The reference time bar's label displays the time relative to the master time bar. You can create an unlimited number of reference time bars.

To help you find a transition of signals relative to the master time bar location, use either the **Next Transition** or the **Previous Transition** button. This aligns the master time bar with the next or previous transition of a selected signal or group of selected signals. This feature is very useful when the sample depth is very large and the rate at which signals toggle is very low.

To quickly find bus values within the waveform, use the **Find bus value** option. After you select the bus, right-click and select **Find bus value**. A dialog box appears to enter search parameters.

## Creating Mnemonics for Bit Patterns

The mnemonic table feature allows you to assign a meaningful name to a set of bit patterns, such as a bus. To create a mnemonic table, right-click in the **Setup** or **Data** tab of an **.stp** file and click **Mnemonic Table Setup**. You create a mnemonic table by entering sets of bit patterns and

specifying a label to represent each pattern. Once you have created a mnemonic table, assign it to a group of signals. To assign a mnemonic table, right-click on the group, click **Bus Display Format** and select the desired mnemonic table.

The labels you create in a table are used in different ways on the **Setup** and **Data** tabs. On the **Setup** tab, you can create basic triggers with meaningful names by right-clicking an entry in any Trigger Conditions column and selecting a label from the table you assigned to the signal group. On the **Data** tab, if any captured data matches a bit pattern contained in an assigned mnemonic table, the signal group data is replaced with the appropriate label, making it easy to see when expected data patterns occur.

### Automatic Mnemonics with a Plug-In

When you use a plug-in to add signals to an **.stp** file, mnemonic tables for the added signals are automatically created and assigned to the signals defined in the plug-in. If you ever need to manually enable these mnemonic tables, right-click on the name of the signal or signal group. On the **Bus Display Format** submenu, click the name of the mnemonic table that matches the plug-in.

As an example, the Nios II plug-in makes it easy to monitor your design's signal activity as code is executed. If you have set up the logic analyzer to trigger on a function name in your Nios II code based on data from an **.elf** file, you can see the function name in the Instance Address signal group at the trigger sample, along with the corresponding disassembled code in the Disassembly signal group, as shown in Figure 14-31. Captured data samples around the trigger are referenced as offset addresses from the trigger function name.

**Figure 14-31. Data Tab when the Nios II Plug-In is Used**



## Locating a Node in the Design

When you find the source of a bug in your design using the SignalTap II Logic Analyzer, you can use the node locate feature to locate that signal in many of the tools found in the Quartus II software, as well as in your design files. This lets you find the source of the problem quickly so you can modify your design to correct the flaw. To locate a signal from the SignalTap II Logic Analyzer in one of the Quartus II software tools or your design files, right-click on the signal in the .stp file, and click **Locate in <tool name>**. You can locate a signal from the node list in any of the following locations:

- Assignment Editor
- Pin Planner
- Timing Closure Floorplan
- Chip Planner
- Resource Property Editor
- Technology Map Viewer
- RTL Viewer
- Design File



For more information about using these tools, refer to the appropriate chapters in the *Quartus II Handbook*.

## Saving Captured Data

The data log shows the history of captured data and the triggers used to capture the data. The analyzer acquires data, stores it in a log, and displays it as waveforms. When the logic analyzer is in auto-run mode and a trigger event occurs more than once, captured data for each time the trigger occurred is stored as a separate entry in the data log. This makes it easy to go back and review the captured data for each trigger event. The default name for a log is based on the time when the data was acquired. Altera recommends that you rename the data log with a more meaningful name.

The logs are organized in a hierarchical manner; similar logs of captured data are grouped together in trigger sets. If the **Data Log** pane is closed, on the View menu, select **Data Log** to reopen it. To enable data logging, turn on **Enable data log** in the **Data Log** (Figure 14-13). To recall a data log for a given trigger set and make it active, double-click the name of the data log in the list.

The Data Log feature is useful for organizing different sets of trigger conditions and different sets of signal configurations. For more information, refer to “[Managing Multiple SignalTap II Files and Configurations](#)” on page 14-30.

## Converting Captured Data to Other File Formats

You can export captured data in the following file formats, some of which can be used with other EDA simulation tools:

- Comma Separated Values File (.csv)
- Table File (.tbl)
- Value Change Dump File (.vcd)
- Vector Waveform File (.vwf)
- Graphics format files (.jpg, .bmp)

To export the SignalTap II Logic Analyzer's captured data, on the File menu, click **Export** and specify the **File Name**, **Export Format**, and **Clock Period**.

## Creating a SignalTap II List File

Captured data can also be viewed in an .stp list file. An .stp list file is a text file that lists all the data captured by the logic analyzer for a trigger event. Each row of the list file corresponds to one captured sample in the buffer. Columns correspond to the value of each of the captured signals or signal groups for that sample. If a mnemonic table was created for the captured data, the numerical values in the list are replaced with a matching entry from the table. This is especially useful with the use of a plug-in that includes instruction code disassembly. You can immediately see the order in which the instruction code was executed during the same time period of the trigger event. To create an .stp list file, on the File menu, select **Create/Update** and click **Create SignalTap II List File**.

## Other Features

The SignalTap II Logic Analyzer has a number of other features that do not necessarily belong to a particular task in the task flow.

### Using the SignalTap II MATLAB MEX Function to Capture Data

If you use MATLAB for DSP design, you can call the MATLAB MEX function `alt_signaltap_run`, built into the Quartus II software, to acquire data from the SignalTap II Logic Analyzer directly into a matrix in the MATLAB environment. If you use the MEX function repeatedly in a loop, you can perform as many acquisitions as you can when using SignalTap II in the Quartus II software environment in the same amount of time.



The SignalTap II MATLAB MEX function is available only in the Windows version of the Quartus II software. It is compatible with MATLAB Release 14 Original Release Version 7 and later.

To set up the Quartus II software and the MATLAB environment to perform SignalTap II acquisitions, perform the following steps:

1. In the Quartus II software, create an **.stp** file.
2. In the node list in the **Data** tab of the SignalTap II Editor, organize the signals and groups of signals into the order in which you want them to appear in the MATLAB matrix. Each column of the imported matrix represents a single SignalTap II acquisition sample, while each row represents a signal or group of signals in the order they are organized in the **Data** tab.



Signal groups acquired from the SignalTap II Logic Analyzer and transferred into the MATLAB environment with the MEX function are limited to a width of 32 signals. If you want to use the MEX function with a bus or signal group that contains more than 32 signals, split the group in smaller groups that do not exceed the 32 signal limit.

3. Save the **.stp** file and compile your design. Program your device and run the SignalTap II Logic Analyzer to ensure your trigger conditions and signal acquisition are working correctly.
4. In the MATLAB environment, add the Quartus II binary directory to your path with the following command:

```
addpath <Quartus install directory>\win ↵
```

You can view the help file for the MEX function by entering `alt_signaltap_run` in MATLAB without any operators.

Use the MEX function in the MATLAB environment to open the JTAG connection to the device and run the SignalTap II Logic Analyzer to acquire data. When you finish acquiring data, close the connection.

To open the JTAG connection and begin acquiring captured data directly into a MATLAB matrix called `stp`, use the following command:

```
stp = alt_signaltap_run ('<stp filename>',[('signed')|('unsigned')],[<instance names>],[ /  
'<signalset name>'[,<trigger name>']]]); ↵
```

When capturing data, *<stp filename>* is the name of the .stp file you want to use. This is required for using the MEX function. The other MEX function options are defined in [Table 14–11](#).

| <b>Table 14–11. SignalTap II MATLAB MEX Function Options</b>  |                                |                                                                                                                                                                                                                                                                                      |
|---------------------------------------------------------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Option</b>                                                 | <b>Usage</b>                   | <b>Description</b>                                                                                                                                                                                                                                                                   |
| signed<br>unsigned                                            | 'signed'<br>'unsigned'         | The <b>signed</b> option turns signal group data into 32-bit two's-complement signed integers. The MSB of the group as defined in the SignalTap II <b>Data</b> tab is the sign bit. The <b>unsigned</b> option keeps the data as an unsigned integer. The default is <b>signed</b> . |
| <i>&lt;instance name&gt;</i>                                  | 'auto_signaltap_0'             | Specify a SignalTap II instance if more than one instance is defined. The default is the first instance in the .stp file, auto_signaltap_0.                                                                                                                                          |
| <i>&lt;signal set name&gt;</i><br><i>&lt;trigger name&gt;</i> | 'my_signalset'<br>'my_trigger' | Specify the signal set and trigger from the SignalTap II data log if multiple configurations are present in the .stp file. The default is the active signal set and trigger in the file.                                                                                             |

You can enable or disable verbose mode to see the status of the logic analyzer while it is acquiring data. To enable or disable verbose mode, use the following commands:

```
alt_signaltap_run('VERBOSE_ON'); ←
alt_signaltap_run('VERBOSE_OFF'); ←
```

When you finish acquiring data, close the JTAG connection. Use the following command to close the connection:

```
alt_signaltap_run('END_CONNECTION'); ←
```

For more information about the use of MEX functions in MATLAB, refer to the MATLAB Help.

## Using SignalTap II in a Lab Environment

You can install a stand-alone version of the SignalTap II Logic Analyzer. This version is particularly useful in a lab environment where you do not have a workstation that meets the requirements for a complete Quartus II installation, or if you do not have a license for a full installation of the Quartus II software. The stand-alone version of the SignalTap II Logic Analyzer is included with the Quartus II stand-alone Programmer and is available from the Downloads page of the Altera website, [www.altera.com](http://www.altera.com).

## Remote Debugging Using the SignalTap II Logic Analyzer

You can use the SignalTap II Logic Analyzer to debug a design that is running on a device attached to a PC in a remote location.

To perform a remote debugging session, you must have the following setup:

- The Quartus II software installed on the local PC
- Stand-alone SignalTap II Logic Analyzer or the full version of the Quartus II software installed on the remote PC
- Programming hardware connected to the device on the PCB at the remote location
- TCP/IP protocol connection

### *Equipment Setup*

On the PC in the remote location, install the stand-alone version of the SignalTap II Logic Analyzer or the full version of the Quartus II software. This remote computer must have Altera programming hardware connected, such as the EthernetBlaster or USB-Blaster.

On the local PC, install the full version of the Quartus II software. This local PC must be connected to the remote PC across a LAN with the TCP/IP protocol.

### *Software Setup on the Remote PC*

To set up the software on the remote PC, perform the following steps:

1. In the Quartus II programmer, click **Hardware Setup**.
2. Click the **JTAG Settings** tab (Figure 14-32).

**Figure 14–32. Configure JTAG on Remote PC**

3. Click **Configure local JTAG Server**.
4. In the **Configure Local JTAG Server** dialog box (Figure 14–33), turn on **Enable remote clients to connect to the local JTAG server** and in the password box, type your password. In the **Confirm Password** box, type your password again and click **OK**.

**Figure 14–33. Configure Local JTAG Server on Remote**

### Software Setup on the Local PC

To set up your software on your local PC, perform the following steps:

1. Launch the Quartus II programmer.
2. Click **Hardware Setup**.

3. On the JTAG settings tab, click **Add server**.
4. In the **Add Server** dialog box (Figure 14–34), type the network name or IP address of the server you want to use and the password for the JTAG server that you created on the remote PC.

**Figure 14–34. Add Server Dialog Box**



5. Click **OK**.

*SignalTap II Setup on the Local PC*

To connect to the hardware on the remote PC, perform the following steps:

1. Click the **Hardware Settings** tab and select the hardware on the remote PC (Figure 14-35).

**Figure 14-35. Selecting Hardware on Remote PC**



2. Click **Close**.

You can now control the logic analyzer on the device attached to the remote PC as if it was connected directly to the local PC.

## SignalTap II Scripting Support

You can run procedures and make settings described in this chapter in a Tcl script. You can also run some procedures at a command prompt. For detailed information about scripting command options, refer to the Quartus II Command-Line and Tcl API Help browser. To run the Help browser, type the following command at the command prompt:

```
quartus_sh --qhelp ↵
```



The *Quartus II Scripting Reference Manual* includes the same information in PDF format.



For more information about Tcl scripting, refer to the *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*.



For more information about command-line scripting, refer to the *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*.

## SignalTap II Command Line Options

To compile your design with the SignalTap II Logic Analyzer using the command prompt, use the `quartus_stp` command. Table 14-12 shows the options that help you better understand how to use the `quartus_stp` executable.

**Table 14-12. SignalTap II Command-Line Options (Part 1 of 2)**

| Option   | Usage                                                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stp_file | <code>quartus_stp --stp_file &lt;stp_filename&gt;</code> | Assigns the specified <code>.stp</code> file to the <code>USE_SIGNALTAP_FILE</code> in the <code>.qsf</code> file.                                                                                                                                                                                                                                                                                                                                                                                                             |
| enable   | <code>quartus_stp --enable</code>                        | Creates assignments to the specified <code>.stp</code> file in the <code>.qsf</code> file and changes <code>ENABLE_SIGNALTAP</code> to <code>ON</code> . The SignalTap II Logic Analyzer is included in your design the next time the project is compiled. If no <code>.stp</code> file is specified in the <code>.qsf</code> file, the <code>--stp_file</code> option must be used. If the <code>--enable</code> option is omitted, the current value of <code>ENABLE_SIGNALTAP</code> in the <code>.qsf</code> file is used. |

**Table 14–12. SignalTap II Command-Line Options (Part 2 of 2)**

| Option                    | Usage                                          | Description                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------------|------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| disable                   | quartus_stp --disable                          | Removes the .stp file reference from the .qsf file and changes ENABLE_SIGNALTAP to OFF. The SignalTap II Logic Analyzer is removed from the design database the next time you compile your design. If the --disable option is omitted, the current value of ENABLE_SIGNALTAP in the .qsf file is used.                                                                                                   |
| create_signaltap_hdl_file | quartus_stp<br>--<br>create_signaltap_hdl_file | Creates an .stp file representing the SignalTap II instance in the design generated by the SignalTap II Logic Analyzer megafunction created with the MegaWizard Plug-in Manager. The file is based on the last compilation. You must use the --stp_file option to properly create an .stp file. Analogous to <b>Create SignalTap II File from Design Instance(s)</b> command in the Quartus II software. |

**Example 14–2** illustrates how to compile a design with the SignalTap II Logic Analyzer at the command line:

**Example 14–2.**

```
quartus_stp filtref --stp_file stp1.stp --enable ←
quartus_map filtref --source=filtref.bdf --family=CYCLONE ←
quartus_fit filtref --part=EP1C12Q240C6 --fmax=80MHz --tsu=8ns ←
quartus_tan filtref ←
quartus_asm filtref ←
```

The quartus\_stp --stp\_file stp1.stp --enable command creates the QSF variable and instructs the Quartus II software to compile the stp1.stp file with your design.

**Example 14-3** shows how to create a new .stp file after building the SignalTap II Logic Analyzer instance with the MegaWizard Plug-In Manager.

**Example 14-3.**

```
quartus_stp filtref --create_signaltap_hdl_file --stp_file stp1.stp ↵
```



For information about the other command line executables and options, refer to the *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*.

## SignalTap II Tcl Commands

The **quartus\_stp** executable supports a Tcl interface that allows you to capture data without running the Quartus II GUI. You cannot execute SignalTap II Tcl commands from within the Tcl console in the GUI. They must be run from the command line with the **quartus\_stp** executable. To run a Tcl file that has SignalTap II Tcl commands, use the following command:

```
quartus_stp -t <Tcl file> ↵
```

Table 14-13 shows the Tcl commands that you can use with SignalTap II.

| Table 14-13. SignalTap II Tcl Commands (Part 1 of 2) |                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                     |
|------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Command                                              | Argument                                                                                                                                                                                    | Description                                                                                                                                                                                                                                                                         |
| open_session                                         | -name <stp_filename>                                                                                                                                                                        | Opens the specified .stp file. All captured data is stored in this file.                                                                                                                                                                                                            |
| run                                                  | -instance <instance_name><br>-signal_set <signal_set><br>(optional)<br>-trigger <trigger_name><br>(optional)<br>-data_log <data_log_name><br>(optional)<br>-timeout <seconds><br>(optional) | Starts the analyzer. This command must be followed by all the required arguments to properly start the analyzer. You can optionally specify the name of the data log you want to create. If the Trigger condition is not met, you can specify a timeout value to stop the analyzer. |

**Table 14–13. SignalTap II Tcl Commands (Part 2 of 2)**

| Command            | Argument | Description                                                                                                                                                                                                                                                                                                                                                          |
|--------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| run_multiple_start | None     | Defines the start of a set of run commands. Use this command when multiple instances of data acquisition are started simultaneously. Add this command before the set of run commands that specify data acquisition. You must use this command with the run_multiple_end command. If the run_multiple_end command is not included, the run commands will not execute. |
| run_multiple_end   | None     | Defines the end of a set of run commands. Use this command when multiple instances of data acquisition are started simultaneously. Add this command after the set of run_commands.                                                                                                                                                                                   |
| stop               | None     | Stops data acquisition.                                                                                                                                                                                                                                                                                                                                              |
| close_session      | None     | Closes the currently open .stp file. You cannot run the analyzer after the .stp file is closed.                                                                                                                                                                                                                                                                      |



For more information about SignalTap II Tcl commands, refer to the Quartus II Help.

**Example 14–4** is an excerpt from a script that is used to continuously capture data. Once the trigger condition is met, the data is captured and stored in the data log.

---

**Example 14–4.**

```
#opens signaltap session
open_session -name stp1.stp
#start acquisition of instance auto_signaltap_0 and
#auto_signaltap_1 at the same time
#calling run_multiple_end will start all instances
#run after run_multiple_start call
run_multiple_start
run -instance auto_signaltap_0 -signal_set signal_set_1 -trigger /
trigger_1 -data_log log_1 -timeout 5
run -instance auto_signaltap_1 -signal_set signal_set_1 -trigger /
trigger_1 -data_log log_1 -timeout 5
run_multiple_end
#close signaltap session
close_session
```

---

Once the script is completed, open the .stp file that you used to capture data to examine the contents of the Data Log.

## Design Example: Using SignalTap II Logic Analyzers in SOPC Builder Systems



Altera Application Note, AN 323: *Using SignalTap II Embedded Logic Analyzers in SOPC Builder Systems* describes how to use the SignalTap II Logic Analyzer to monitor signals located inside a system module generated by SOPC Builder. The system in this example contains many components, including a Nios processor, a direct memory access (DMA) controller, on-chip memory, and an interface to external SDRAM memory. In this example, the Nios processor executes a simple C program from on-chip memory and waits for a button push. After a button is pushed, the processor initiates a DMA transfer, which you analyze using the SignalTap II Logic Analyzer.

For more information about this example and using the SignalTap II Logic Analyzer with SOPC builder systems refer to [AN 323: Using SignalTap II Embedded Logic Analyzers in SOPC Builder Systems](#) and [AN 446: Debugging Nios II Systems with the SignalTap II Logic Analyzer](#).

## Custom Triggering Flow Application Examples

The custom triggering flow in the SignalTap II Logic Analyzer is most useful for organizing a number of triggering conditions and for precise control over the acquisition buffer. This section provides two application examples for defining a custom triggering flow within the SignalTap II Logic Analyzer. Both examples can be easily copied and pasted directly into the state machine description box by using the state display mode **All states in one window**.



For additional triggering flow design examples, refer to the [Quartus II On-Chip Debugging Support Resources](#) page for on-chip debugging.

### Design Example 1: Specifying a Custom Trigger Position

Actions to the acquisition buffer can accept an optional post-count argument. This post-count argument enables you to define a custom triggering position for each segment in the acquisition buffer.

[Example 14-5](#) shows an example that applies a trigger position to all segments in the acquisition buffer. The example describes a triggering flow for an acquisition buffer split into four segments. If each acquisition segment is 64 samples in depth, the trigger position for each buffer will be at sample #34. The acquisition stops after all four segments are filled once.

**Example 14-5.**

```

if (c1 == 3 && condition1)
    trigger 30;
else if ( condition1 )
begin
    segment_trigger 30;
    increment c1;
end

```

Each segment acts as a circular buffer that continuously updates the memory contents with the signal values. The last acquisition before stopping the buffer is displayed on the **data** tab as the last sample number in the affected segment. The trigger position in the affected segment is then defined by  $N - \text{post count fill}$ , where  $N$  is the number of samples per segment. [Figure 14-36](#) illustrates the triggering position.

**Figure 14-36. Specifying a Custom Trigger Position**



### Design Example 2: Trigger When triggercond1 Occurs Ten Times between triggercond2 and triggercond3

The custom trigger flow description is often useful to count a sequence of events before triggering the acquisition buffer. [Example 14-6](#) shows such a sample flow. This example uses three basic triggering conditions configured in the SignalTap II **setup** tab.

---

This example triggers the acquisition buffer when condition1 occurs after condition3 and occurs ten times prior to condition3. If condition3 occurs prior to ten repetitions of condition1, the state machine transitions to a permanent wait state.

---

**Example 14-6.**

state ST1:

```
if ( condition2 )  
begin  
    reset c1;  
    goto ST2;  
end  
  
State ST2 :  
if ( condition1 )  
    increment c1;  
  
else if ( condition3 && c1 < 10 )  
    goto ST3;  
  
else if ( condition3 && c1 >= 10 )  
    trigger;  
  
ST3 :  
goto ST3;
```

---

## Conclusion

As the FPGA industry continues to make technological advancements, outdated methodologies need to be replaced with new technologies that maximize productivity. The SignalTap II Logic Analyzer gives you the same benefits as a traditional logic analyzer, without the many shortcomings of a piece of dedicated test equipment. This version of the SignalTap II Logic Analyzer provides many new and innovative features that allow you to capture and analyze internal signals in your FPGA, allowing you to find the source of a design flaw in the shortest amount of time.

## Referenced Documents

This chapter references the following documents:

- *AN 323: Using SignalTap II Embedded Logic Analyzers in SOPC Builder System*
- *AN 446: Debugging Nios II Systems with the SignalTap II Logic Analyzer*
- *Area and Timing Optimization chapter in volume 2 of the Quartus II Handbook*
- *Command-Line Scripting chapter in volume 2 of the Quartus II Handbook*
- *Design Debugging Using In-System Sources and Probes chapter in volume 3 of the Quartus II Handbook*
- *I/O Management chapter in volume 2 of the Quartus II Handbook*
- *In-System Debugging Using External Logic Analyzers chapter in volume 3 of the Quartus II Handbook*
- *Quartus II Handbook*
- *Quartus II Incremental Compilation for Hierarchical and Team-Based Design chapter in volume 1 of the Quartus II Handbook*
- *Quartus II Integrated Synthesis chapter in volume 1 of the Quartus II Handbook*
- *Quartus II Scripting Reference Manual*
- *Quartus II Settings File Reference Manual*
- *Quick Design Debugging Using SignalProbe chapter in volume 3 of the Quartus II Handbook*
- *Tcl Scripting chapter in volume 2 of the Quartus II Handbook*

# Document Revision History

Table 14–14 shows the revision history for this chapter.

| <b>Table 14–14. Document Revision History</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                          |
|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|
| <b>Date and Document Version</b>              | <b>Changes Made</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <b>Summary of Changes</b>                                |
| May 2008<br>v8.0.0                            | <p>Updated for the Quartus II software version 8.0:</p> <ul style="list-style-type: none"> <li>Added “Debugging Finite State Machines” on page 14–24</li> <li>Documented various GUI usability enhancements, including improvements to the resource estimator, the bus find feature, and the dynamic display updates to the counter and flag resources in the State-based trigger flow control tab</li> <li>Added “Capturing Data Using Segmented Buffers” on page 14–62</li> <li>Added hyperlinks to referenced documents throughout the chapter</li> <li>Minor editorial updates</li> </ul>                                    | Updated for the Quartus II software version 8.0 release. |
| October 2007<br>v7.2.0                        | <p>Updated for the Quartus II software version 7.2:</p> <ul style="list-style-type: none"> <li>Added new section: “Trigger Condition Flow Control” on page 13–34</li> <li>Documented the new feature for State-machine-based triggering</li> <li>Documented changes to “Using Incremental Compilation with the SignalTap II Logic Analyzer” on page 13–52</li> <li>Added additional information about node tappability</li> <li>Added section “Performance and Resource Considerations” on page 13–55, with information about performance and resource utilization considerations for the SignalTap II Logic Analyzer</li> </ul> | Updated for the Quartus II software version 7.2 release. |
| May 2007<br>v7.1.0                            | Added “Referenced Documents” on page 13–71, minor updates to address ADoQS issues.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | —                                                        |
| March 2007<br>v7.0.0                          | Added Cyclone III device support listed on page 13–4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | —                                                        |
| November 2006<br>v6.1.0                       | <p>Updated for the Quartus II software version 6.1:</p> <ul style="list-style-type: none"> <li>Updated Figure 13–4, 13–11, 13–16, 13–17, 13–18. Added new Figure 13–23.</li> <li>Miscellaneous changes throughout.</li> <li>Removed information about incremental routing (feature removed).</li> <li>Added more detail about the use of incremental compilation.</li> <li>Added more detail about the use of the Nios II plug-in.</li> <li>Added more information about SignalTap II file/SOF compatibility.</li> <li>Updated method for triggering one logic analyzer with another using trigger in/out.</li> </ul>            | Updated for the Quartus II software version 6.1.         |
| May 2006<br>v6.0.0                            | Updated for the Quartus II software version 6.0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | —                                                        |
| October 2005<br>v5.1.0                        | Updated for the Quartus II software version 5.1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | —                                                        |

**Table 14–14. Document Revision History**

| Date and Document Version | Changes Made                                                                                                                                               | Summary of Changes |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| May 2005<br>v5.0.0        | <ul style="list-style-type: none"><li>• Updated information.</li><li>• Updated figures.</li><li>• New functionality for Quartus II software 5.0.</li></ul> | —                  |
| December 2004<br>v1.0     | Initial release.                                                                                                                                           | —                  |

### Introduction

The phenomenal growth in design size and complexity continues to make the process of design verification a critical bottleneck for today's FPGA systems. Limited access to internal signals, advanced FPGA packages, and printed circuit board (PCB) electrical noise are all contributing factors in making design debugging and verification the most difficult process of the design cycle. You can easily spend more than 50% of your design cycle time debugging and verifying your design. To help you with the process of design debugging and verification, Altera provides a solution that allows you to examine the behavior of internal signals using an external logic analyzer and using a minimal number of FPGA I/O pins, while your design is running at full speed on your FPGA.



This chapter's use of the term "logic analyzer" includes both logic analyzers and oscilloscopes equipped with digital channels, commonly referred to as mixed signal analyzers or MSOs.

The Logic Analyzer Interface (LAI) is an application within the Quartus II software used to connect a large set of internal device signals to a small number of output pins. You can connect these output pins to an external logic analyzer for debugging purposes. In the Quartus II LAI, the internal signals are grouped together, distributed to a user-configurable multiplexer, and then output to available I/O pins on your FPGA. Instead of having a one-to-one relationship between internal signals to output pins, the Quartus II LAI enables you map many internal signals to a smaller number of output pins. The exact number of internal signals that you can map to an output pin varies based on the multiplexer settings in the Quartus II LAI.

This chapter details the following topics:

- "Debugging Your Design Using the Logic Analyzer Interface" on page 15-4
- "Advanced Features" on page 15-15

## Choosing a Logic Analyzer

The Quartus II software offers the following two general purpose on-chip debugging tools for debugging a large set of RTL signals from your design:

- SignalTap® II, the embedded logic analyzer
- An external logic analyzer, which connects to internal signals in your FPGA, by using the Quartus II LAI

Table 15–1 describes the advantages to both debugging technologies.

| Feature and Description                                                                                                                                                                                                                                                                                                              | Logic Analyzer Interface | SignalTap II Embedded Logic Analyzer |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--------------------------------------|
| <b>Sample Depth</b><br>You have access to a wider sample depth with an external logic analyzer. In the SignalTap II Embedded Logic Analyzer, the maximum sample depth is set to 128 Kb, which is a device constraint. However, with an external logic analyzer, there are no device constraints, providing you a wider sample depth. | ✓                        | —                                    |
| <b>Debugging Timing Issues</b><br>Using an external logic analyzer provides you with access to a “timing” mode, which enables you to debug combined streams of data.                                                                                                                                                                 | ✓                        | —                                    |
| <b>Performance</b><br>You frequently have limited routing resources available to place-and-route when you use SignalTap II with your design. An external logic analyzer adds minimal logic, which removes resource limits on place-and-route.                                                                                        | ✓                        | —                                    |
| <b>Triggering Capability</b><br>SignalTap II offers triggering capabilities that is comparable with external logic analyzers.                                                                                                                                                                                                        | ✓                        | ✓                                    |
| <b>Use of Output Pins</b><br>Using the SignalTap II Logic Analyzer, no additional output pins are required. Using an external logic analyzer requires the use of additional output pins.                                                                                                                                             | —                        | ✓                                    |
| <b>Acquisition Speed</b><br>With the SignalTap II Logic Analyzer, you can acquire data at speeds of over 200 MHz. You can achieve the same acquisition speeds with an external logic analyzer; however, you must consider signal integrity issues.                                                                                   | —                        | ✓                                    |



The Quartus II software offers a portfolio of on-chip debugging tools. For an overview and comparison of all tools available in the Quartus II software on-chip debugging tool suite, refer to [Section V. In-System Debugging](#) in volume 3 of the *Quartus II Handbook*.

## Required Components

You must have the following components to perform analysis using the Quartus II LAI:

- The Quartus II software starting with version 5.1 and later
- The device under test
- An external logic analyzer
- An Altera® communications cable
- A cable to connect the FPGA to the external logic analyzer

Figure 15–1 shows the LAI and the hardware setup.

**Figure 15–1. Logic Analyzer Interface and Hardware Setup**



**Notes to Figure 15–1:**

- (1) Configuration and control of the LAI using a computer loaded with the Quartus II software via the JTAG port.
- (2) Configuration and control of the LAI using a third-party vendor logic analyzer via the JTAG port. Support varies by vendor.

## FPGA Device Support

You can use the Quartus II Logic Analyzer Interface (LAI) with the following FPGA device families:

- Arria™ GX
- Stratix® series
- Cyclone® series
- MAX® II
- APEX™ 20K
- APEX II

# Debugging Your Design Using the Logic Analyzer Interface

Figure 15–2 shows the steps you must follow to debug your design with the Quartus II LAI.

**Figure 15–2. LAI Process Flow**



## Creating an LAI File

The Logic Analyzer Interface (.lai) file defines the interface that builds a connection between internal FPGA signals and your external logic analyzer. An example of an .lai file is shown in Figure 15–3.

**Figure 15–3. Example of an LAI Editor**

To define the Quartus II LAI, you can create a new **.lai** file or use an existing **.lai** file.

#### *Creating a New Logic Analyzer Interface File*

To create a new **.lai** file, perform the following steps:

1. In the Quartus II software, on the File menu, click **New**. The **New** dialog box opens.
2. Click the **Other Files** tab and select **Logic Analyzer Interface File** (Figure 15–4).

---

**Figure 15–4. Creating a New Logic Analyzer File**



- 
3. Click **OK**. The LAI editor opens. The file name is assigned by the Quartus II software (refer to [Figure 15–3 on page 15–5](#)). When you save the file, you will be prompted for a file name. Refer to [“Saving the External Analyzer Interface File” on page 15–6](#).

#### *Opening an Existing External Analyzer Interface File*

To open an existing **.lai** file, on the Tools menu, click **Logic Analyzer Interface Editor**. If no **.lai** file is enabled for the current project, the editor automatically creates a new **.lai** file. If an **.lai** file is currently enabled for the project, that file opens when you select the **Logic Analyzer Interface Editor**.

Another way to open an existing **.lai** file is on the File Menu, click **Open**, and select the **.lai** file you want to open.

#### *Saving the External Analyzer Interface File*

To save your **.lai** file, perform the following steps:

1. In the Quartus II software, on the File menu, click **Save As**. The **Save As** dialog box opens ([Figure 15–5](#)).
2. In the **File name** box, enter the desired file name. Click **Save** ([Figure 15–5](#)).

---

**Figure 15–5. Saving the Logic Analyzer Interface File**



---

## Configuring the Logic Analyzer Interface File Core Parameters

After you have created your .lai file, you must configure the .lai file core parameters.

To configure the .lai file core parameters, select **Core Parameters** from the **Setup View** list. Refer to [Figure 15–6](#).

---

**Figure 15–6. Logic Analyzer Interface File Core Parameters**



Table 15–2 lists the .lai file core parameters.

| <b>Table 15–2. Logic Analyzer Interface File Core Parameters</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Parameter</b>                                                 | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Pin Count                                                        | <p>The Pin Count parameter signifies the number of pins you want dedicated to your LAI. The pins must be connected to a debug header on your board. Within the FPGA, each pin is mapped to a user-configurable number of internal signals.</p> <p>The Pin Count parameter can range from 1 to 255 pins.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bank Count                                                       | <p>The Bank Count parameter signifies the number of internal signals that you want to map to each pin. For example, a Bank Count of 8 implies that you will connect eight internal signals to each pin.</p> <p>The Bank Count parameter can range from 1 to 255 banks.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Output/Capture Mode                                              | <p>The Output/Capture Mode parameter signifies the type of acquisition you perform. There are two options that you can select:</p> <p>Combinational/Timing—This acquisition uses your external logic analyzer's internal clock to determine when to sample data. Because Combinational/Timing acquisition samples data asynchronously to your FPGA, you need to properly determine the sample frequency you should use to debug and verify your system. This mode is effective if you want to measure timing information such as channel-to-channel skew. For more information about the sampling frequency and the speeds at which it can run, refer to the data sheet for your external logic analyzer.</p> <p>Registered/State—This acquisition uses a signal from your system under test to determine when to sample. Because Registered/State acquisition samples data synchronously with your FPGA, it provides you with a functional view of your FPGA while it is running. This mode is effective when you want to verify the functionality of your design.</p> |
| Clock                                                            | The clock parameter is available only when Output/Capture Mode is set to Registered State. You must specify the sample clock in the Core Parameters view. The sample clock can be any signal in your design. However, for best results, Altera recommends that you use a clock with an operating frequency fast enough to sample the data you would like to acquire.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Power-Up State                                                   | The Power-Up State parameter specifies the power-up state of the pins you have designated for use with the LAI. You have the option of selecting tri-stated for all pins, or selecting a particular bank that you have enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

## Mapping the Logic Analyzer Interface File Pins to Available I/O Pins

To configure the **.lai** file I/O pins parameters, select Pins from the Setup View list (Figure 15–7).

Figure 15–7. Logic Analyzer Interface File Pins Parameters



| Pin  |       |                         |          | I/O Standard |
|------|-------|-------------------------|----------|--------------|
| Type | Index | Name                    | Location |              |
|      | 0     | altera_reserved_lai_0_0 |          |              |
|      | 1     | altera_reserved_lai_0_1 |          |              |
|      | 2     | altera_reserved_lai_0_2 |          |              |
|      | 3     | altera_reserved_lai_0_3 |          |              |
|      | 4     | altera_reserved_lai_0_4 |          |              |
|      | 5     | altera_reserved_lai_0_5 |          |              |
|      | 6     | altera_reserved_lai_0_6 |          |              |
|      | 7     | altera_reserved_lai_0_7 |          |              |

To assign pin locations for the LAI, double-click the **Location** column next to the reserved pins in the **Name** column. This opens the Pin Planner.



For information about how to use the Pin Planner, refer to the *Pin Planner* section in the *I/O Management* chapter in volume 2 of the *Quartus II Handbook*.

## Mapping Internal Signals to the Logic Analyzer Interface Banks

After you have specified the number of banks to use in the **Core Parameters** settings page, you must assign internal signals for each bank in the LAI. Click the **Setup View** arrow and select **Bank n** or **ALL Banks** (Figure 15–8).

**Figure 15–8. Logic Analyzer Interface Bank Parameters**

| Setup View: Bank 0 |      | Node        |      |   |
|--------------------|------|-------------|------|---|
| Pin Index          | Type | Alias       | Name |   |
| 0                  | ○    | State Clock |      |   |
| 1                  | ○    |             | —    | — |
| 2                  | ○    |             | —    | — |
| 3                  | ○    |             | —    | — |
| 4                  | ○    |             | —    | — |
| 5                  | ○    |             | —    | — |
| 6                  | ○    |             | —    | — |
| 7                  | ○    |             | —    | — |

To view all of your bank connections, click **Setup View** and select **All Banks** (Figure 15–9).

**Figure 15–9. Logic Analyzer Interface All Bank Parameters**

| Setup View: All Banks |           | Node |       |      |
|-----------------------|-----------|------|-------|------|
| Bank Name             | Pin Index | Type | Alias | Name |
| Bank 0                | 0         | ○    |       | d[7] |
|                       | 1         | ○    |       | d[6] |
|                       | 2         | ○    |       | d[5] |
|                       | 3         | ○    |       | d[4] |
|                       | 4         | ○    |       | d[3] |
|                       | 5         | ○    |       | d[2] |
|                       | 6         | ○    |       | d[1] |
|                       | 7         | ○    |       | d[0] |
| Bank 1                | 0         | ○    |       | —    |
|                       | 1         | ○    |       | —    |
|                       | 2         | ○    |       | —    |
|                       | 3         | ○    |       | —    |
|                       | 4         | ○    |       | —    |
|                       | 5         | ○    |       | —    |
|                       | 6         | ○    |       | —    |
|                       | 7         | ○    |       | —    |

## Using the Node Finder

Before making bank assignments, on the View menu, point to **Utility Windows** and click **Node Finder**. Find the signals that you want to acquire, then drag and drop the signals from the **Node Finder** dialog box into the bank **Setup View**. When adding signals, use **SignalTap II: pre-synthesis** for non-incrementally routed instances and **SignalTap II: post-fitting** for incrementally routed instances.

As you continue to make assignments in the bank **Setup View**, the schematic of your LAI in the **Logical View** of your **.lai** file begins to reflect your assignments (Figure 15–10).

*Figure 15–10. A Logical View of the Logic Analyzer Interface Schematic*



Continue making assignments for each bank in the **Setup View** until you have added all of the internal signals for which you wish to acquire data.

 You can right-click to switch between the LAI schematic and the LAI **Setup** view.

## Enabling the Logic Analyzer Interface Before Compiling Your Quartus II Project

Compile your project after you have completed the following steps:

- Configure your LAI parameters
- Map the LAI pins to available I/O pins
- Map the internal signals to the LAI banks

## Compiling Your Quartus II Project

Before compilation, you must enable the LAI.

1. On the Assignments menu, click **Settings**. The **Settings** dialog box opens. Under Category, click **Logic Analyzer Interface**. The **Logic Analyzer Interface** displays. Turn on **Enable Logic Analyzer Interface**.
2. Click **Logic Analyzer Interface file name** and specify the full path name to your **.lai** file (Figure 15–11).

**Figure 15–11. Settings Dialog Box—Logic Analyzer Interface Settings**



After you have specified the name of your **.lai** file, you must compile your project. To compile your project, on the Processing menu, click **Start Compilation**.

To ensure the LAI is properly compiled with your project, expand the entity hierarchy in the Project Navigator. (To display the Project Navigator, on the View menu, point to **Utility Windows**, and click **Project Navigator**.) If the LAI compiled with your design, the `sld_hub` and `sld_multitap` entities are shown in the project navigator.

**Figure 15–12. Project Navigator**

| Entity                            | Logic Cells | LC Registers |
|-----------------------------------|-------------|--------------|
| ⚠️ Stratix: EP1S10B672C7          |             |              |
| └─ epr... test                    | 136 (1)     | 81           |
| └─ abd... sld_multitap:auto_lai_0 | 35 (11)     | 15           |
| └─ abd... sld_hub:sld_hub_inst    | 100 (25)    | 65           |

## Programming Your FPGA Using the Logic Analyzer Interface

After compilation completes, you must configure your FPGA before using the LAI. To configure a device for use with the LAI, follow these steps:

1. Open the `.lai` file Editor (Figure 15–13).
2. Under **JTAG Chain Configuration**, click **Hardware** and select your hardware communications device. You may have to click **Settings** to configure your hardware.
3. Click **Device** and select the FPGA device to which you want to download the design (it may be automatically detected). You may have to click **Scan Chain** to configure your device.
4. Click **File** and select the SRAM Object File (`.sof`) that includes the `.lai` file (it may be automatically detected).
5. If desired, turn on **Incremental Compilation**.
6. Save the `.lai` file.
7. Click the **Program Device** icon to program the device.

Figure 15–13. The JTAG Section of the Logic Analyzer Interface File



## Using the Logic Analyzer Interface with Multiple Devices

You can use the LAI with multiple devices in your JTAG chain. Your JTAG chain can also consist of devices that do not support the LAI or non-Altera, JTAG-compliant devices. To use the LAI in more than one FPGA, create a LAI and configure an **.lai** file for each FPGA that you want to analyze. To perform multi-FPGA analysis, perform the following steps:

1. Open the Quartus II software.
2. Create, configure, and compile an **.lai** file for each design.
3. Open one **.lai** file at a time.
 

 You do not have to open a Quartus II project to open an **.lai** file.
4. Follow Steps 2 through 6 under “Programming Your FPGA Using the Logic Analyzer Interface” on page 15–13.
5. Click the **Program Device** icon to program the device.
6. Control each **.lai** file independently.

## Configuring Banks in the Logic Analyzer Interface File

When you have programmed your FPGA, you can control which bank is mapped to the reserved .lai file output pins. To control which bank is mapped, in the schematic in the logical view, right-click the bank and click **Connect Bank** (Figure 15–14).

Figure 15–14. Configuring Banks

| Pin Index | Node      |             |         |
|-----------|-----------|-------------|---------|
|           | Type      | Alias       | Name    |
| 0         | clock     | State Clock |         |
| 1         | tri-state |             | addr[2] |
| 2         | tri-state |             | addr[1] |
| 3         | tri-state |             | addr[0] |
| 4         | tri-state |             | data[2] |
| 5         | tri-state |             | data[1] |
| 6         | tri-state |             | data[0] |
| 7         | clock     |             |         |

## Acquiring Data on Your Logic Analyzer

To acquire data on your logic analyzer, you must establish a connection between your device and the external logic analyzer.



For more information about this process and for guidelines on how to establish connections between debugging headers and logic analyzers, refer to the documentation for your logic analyzer.

## Advanced Features

This section describes the following advanced features:

- Using the Logic Analyzer Interface with Incremental Compilation
- Creating Multiple Logic Analyzer Interface Instances in One FPGA

## Using the Logic Analyzer Interface with Incremental Compilation

Using the LAI with Incremental Compilation enables you to preserve the synthesis and fitting of your original design, and add the LAI to your design without recompiling your original source code.

To use the LAI with Incremental Compilation, perform the following steps:

1. Start the Quartus II software.
2. Enable Design Partitions. To enable Partitions, perform the following steps:
  - a. On the Assignments menu, click **Design Partitions**.
  - b. In the **Incremental Compilation** list, select **Full Incremental Compilation**.
  - c. Create Design Partitions for the entities in your design, and set the Netlist Type to **Post-fit**.
  - d. On the Processing menu, click **Start Compilation**.
3. Enable LAI Incremental Compilation by performing these steps:
  - a. In your **.lai** file, under **Instance Manager**, click **Incremental Compilation**.



When you enable Incremental Compilation, all existing presynthesis signals will be converted into post-fitting signals. Only post-fitting signals can be used with the LAI with Incremental Compilation.

- b. Add Post-Fitting nodes to your **.lai** file.
- c. On the Processing menu, click **Start Compilation**.

## Creating Multiple Logic Analyzer Interface Instances in One FPGA

The LAI includes support for multiple interfaces in one FPGA. This feature is particularly useful when you want to build LAI configurations that contain different settings. For example, you can build one LAI instance to perform Registered/State analysis and build another instance that performs Combinational/Timing analysis on the same set of signals.

Another example would be if you want to perform Registered/State analysis on portions of your design that are in different clock domains.

To create multiple LAIs, on the Edit menu, click **Create Instance**. Alternatively, you can right-click the **Instance Manager** window, and click **Create Instance** (Figure 15-15).

---

Figure 15–15. Creating Multiple Logic Analyzer Interface Instances in One FPGA

| Instance   | Status        | Incremental Compilation  | LEs: 170 |
|------------|---------------|--------------------------|----------|
| auto_lai_0 | Not connected | <input type="checkbox"/> | 85 cells |
| auto_lai_1 | Not connected | <input type="checkbox"/> | 85 cells |

Context menu for 'auto\_lai\_1':

- Create Instance
- Delete Instance Del
- Rename Instance F2
- Instance Status
- Help

## Conclusion

As the FPGA industry continues to make technological advancements, outdated debugging methodologies must be replaced with new technologies that maximize productivity. The LAI feature enables you to connect many internal signals within your FPGA to an external logic analyzer with the use of a small number of I/O pins. This new technology in the Quartus II software enables you to use feature-rich external logic analyzers to debug your FPGA design, ultimately enabling you to deliver your product in the shortest amount of time.

## Referenced Documents

This chapter references the following documents:

- *Section V. In-System Debugging* in volume 3 of the *Quartus II Handbook*
- *I/O Management* chapter in volume 2 of the *Quartus II Handbook*

## Document Revision History

Table 15–3 shows the revision history for this chapter.

| <b>Table 15–3. Document Revision History</b> |                                                                                                                                                                                                                                                                                                                                                                                            |                                                               |
|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| <b>Date and Document Version</b>             | <b>Changes Made</b>                                                                                                                                                                                                                                                                                                                                                                        | <b>Summary of Changes</b>                                     |
| May 2008<br>v8.0.0                           | <ul style="list-style-type: none"> <li>● Updated device support list on page 15–3</li> <li>● Added links to referenced documents throughout the chapter</li> <li>● Added “Referenced Documents” on page 15–17</li> <li>● Added reference to <i>Section V. In-System Debugging</i> in volume 3 of the <i>Quartus II Handbook</i> on page 15–2</li> <li>● Minor editorial updates</li> </ul> | Updates made for the Quartus II software version 8.0 release. |
| October 2007<br>v7.2.0                       | No changes to content.                                                                                                                                                                                                                                                                                                                                                                     | —                                                             |
| May 2007<br>v7.1.0                           | Minor updates to address ADoQS issues.                                                                                                                                                                                                                                                                                                                                                     | —                                                             |
| March 2007<br>v7.0.0                         | Added Cyclone III device support listed on page 14–3.                                                                                                                                                                                                                                                                                                                                      | —                                                             |
| November 2006<br>v6.1.0                      | Added new revision history table format to this document.                                                                                                                                                                                                                                                                                                                                  | —                                                             |
| May 2006<br>v6.0.0                           | Chapter title changed.<br>Minor updates for the Quartus II software version 6.0.0.                                                                                                                                                                                                                                                                                                         | —                                                             |
| October 2005<br>v5.1.0                       | Initial release.                                                                                                                                                                                                                                                                                                                                                                           | —                                                             |

### Introduction

FPGA designs are growing larger in density and are becoming more complex. Designers and verification engineers require more access to the design that is programmed in the device to quickly identify, test, and resolve issues. The in-system updating of memory and constants capability of the Quartus® II software provides read and write access to in-system FPGA memories and constants through the Joint Test Action Group (JTAG) interface, making it easier to test changes to memory contents in the FPGA while the FPGA is functioning in the end system.

This chapter explains how to use the Quartus II In-System Memory Content Editor as part of your FPGA design and verification flow.

This chapter contains the following sections:

- “Device Megafunction Support” on page 16–2
- “Using In-System Updating of Memory and Constants with Your Design” on page 16–3
- “Creating In-System Modifiable Memories Constants” on page 16–3
- “Running the In-System Memory Content Editor” on page 16–4

### Overview

The ability to read and update memories and constants in a programmed device provides more insight into and control over your design. The Quartus II In-System Memory Content Editor gives you access to device memories and constants. When used in conjunction with the SignalTap® II Embedded Logic Analyzer, this feature provides the visibility required to debug your design in the hardware lab.



For more information about the SignalTap II embedded logic analyzer, refer to the *Design Debugging Using the SignalTap II Embedded Logic Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

The ability to read data from memories and constants allows you to quickly identify the source of problems. In addition, the write capabilities allow you to bypass functional issues by writing expected data. For example, if a parity bit in your memory is incorrect, you can use the In-System Content Editor to write the correct parity bit values into your RAM, allowing your system to continue functioning. You can also intentionally write incorrect parity bit values into your RAM to check your design’s error handling functionality.



The Quartus II software offers a portfolio of on-chip debugging tools. For an overview and comparison of all tools available in the Quartus II software on-chip debugging tool suite, refer to *Section V. In-System Debugging* in volume 3 of the *Quartus II Handbook*.

## Device Megafunction Support

The following tables list the devices and types of memories and constants that are currently supported by the Quartus II software. **Table 16–1** lists the types of memory supported by the MegaWizard® Plug-In Manager and the In-System Memory Content Editor.

**Table 16–1. MegaWizard Plug-In Manager Support**

| Installed Plug-Ins Category | Megafunction Name               |
|-----------------------------|---------------------------------|
| Gates                       | LPM_CONSTANT                    |
| Memory Compiler             | RAM: 1-PORT, ROM: 1-PORT        |
| Storage                     | ALTSYNCRAM, LPM_RAM_DQ, LPM_ROM |

**Table 16–2** lists support for in-system updating of memory and constants for the Stratix® series, Arria™ GX, Cyclone® series, APEX™ II, and APEX 20K device families.

**Table 16–2. Supported Megafunctions**

| Megafunction                      | Arria GX / Stratix Series |            |                | Cyclone Series | APEX II    | APEX 20K   |
|-----------------------------------|---------------------------|------------|----------------|----------------|------------|------------|
|                                   | M512 Blocks               | M4K Blocks | MegaRAM Blocks |                |            |            |
| LPM_CONSTANT                      | Read/Write                | Read/Write | Read/Write     | Read/Write     | Read/Write | Read/Write |
| LPM_ROM                           | Write                     | Read/Write | N/A            | Read/Write     | Read/Write | Write      |
| LPM_RAM_DQ                        | N/A                       | Read/Write | Read/Write     | Read/Write     | Read/Write | N/A (1)    |
| ALTSYNCRAM (ROM)                  | Write                     | Read/Write | N/A            | Read/Write     | N/A        | N/A        |
| ALTSYNCRAM (Single-Port RAM Mode) | N/A                       | Read/Write | Read/Write     | Read/Write     | N/A        | N/A        |

*Note to Table 16–2:*

- (1) Only write-only mode is applicable for this single-port RAM. In read-only mode, use LPM\_ROM instead of LPM\_RAM\_DQ.

## Using In-System Updating of Memory and Constants with Your Design

Using the In-System Updating of Memory and Constants feature requires the following steps:

1. Identify the memories and constants that you want to access.
2. Edit the memories and constants to be run-time modifiable.
3. Perform a full compilation.
4. Program your device.
5. Launch the In-System Memory Content Editor.

## Creating In-System Modifiable Memories Constants

When you specify that a memory or constant is run-time modifiable, the Quartus II software changes the default implementation. A single-port RAM is converted to dual-port RAM, and a constant is implemented in registers instead of look-up tables (LUTs). These changes enable run-time modification without changing the functionality of your design. For a list of run-time modifiable megafunctions, refer to [Table 16-1](#).

To enable your memory or constant to be modifiable, perform the following steps:

1. On the Tools menu, click **MegaWizard Plug-In Manager**.
2. If you are creating a new megafunction, select **Create a new custom megafunction variation**. If you have an existing megafunction, select **Edit an existing custom megafunction variation**.
3. Make the necessary changes to the megafunction based on the characteristics required by your design, turn on **Allow In-System Memory Content Editor to capture and update content independently of the system clock**, and type a value in the **Instance ID** text box. These parameters can be found on the last page of the wizard for megafunctions that support in-system updating.



The Instance ID is a four-character string used to distinguish the megafunction from other in-system memories and constants.

4. Click **Finish**.
5. On the Processing menu, click **Start Compilation**.

If you instantiate a memory or constant megafunction directly using ports and parameters in VHDL or Verilog HDL, add or modify the `lpm_hint` parameter as shown below.

In VHDL code, add the following:

```
lpm_hint => "ENABLE_RUNTIME_MOD = YES,  
  INSTANCE_NAME = <instantiation name>";
```

In Verilog HDL code, add the following:

```
defparam <megafunction instance name>.lpm_hint =  
  "ENABLE_RUNTIME_MOD = YES,  
  INSTANCE_NAME = <instantiation name>";
```

# Running the In-System Memory Content Editor

The In-System Memory Content Editor is separated into the Instance Manager, JTAG Chain Configuration, and the Hex Editor (Figure 16-1).

**Figure 16–1. In-System Memory Content Editor**



The Instance Manager displays all available run-time modifiable memories and constants in your FPGA device. The JTAG Chain Configuration section allows you to program your FPGA and select the Altera® device in the chain to update.

Using the In-System Memory Content Editor does not require that you open a project. The In-System Memory Content Editor retrieves all instances of run-time configurable memories and constants by scanning the JTAG chain and sending a query to the specific device selected in the JTAG Chain Configuration section.

Each In-System Memory Content Editor can access the in-system memories and constants in a single device. If you have more than one device containing in-system configurable memories or constants in a JTAG chain, you can launch multiple In-System Memory Content Editors within the Quartus II software to access the memories and constants in each of the devices.

## Instance Manager

Scan the JTAG chain to update the Instance Manager with a list of all run-time modifiable memories and constants in the design. The Instance Manager displays the Index, Instance, Status, Width, Depth, Type, and Mode of each element in the list.

You can read and write to in-system memory using the Instance Manager, as shown in Figure 16–2.

**Figure 16–2. Instance Manager Controls**



The following buttons are provided in the Instance Manager:

- **Read data from In-System Memory**—Reads the data from the device independently of the system clock and displays it in the Hex Editor
- **Continuously Read Data from In-System Memory**—Continuously reads the data asynchronously from the device and displays it in the Hex Editor

- **Stop In-System Memory Analysis**—Stops the current read or write operation
- **Write Data to In-System Memory**—Asynchronously writes data present in the Hex Editor to the device



In addition to the buttons available in the Instance Manager, you can also read and write data by selecting the command from the Processing menu, or the right button pop-up menu in the Instance Manager or Hex Editor.

The status of each instance is also displayed beside each entry in the Instance Manager. The status indicates if the instance is **Not running**, **Offloading data**, or **Updating data**. The health monitor provides useful information about the status of the editor.

The Quartus II software assigns a different index number to each in-system memory and constant to distinguish between multiple instances of the same memory or constant function. View the **In-System Memory Content Editor Settings** section of the compilation report to match an index with the corresponding instance ID ([Figure 16–3](#)).

**Figure 16–3. Compilation Report In-System Memory Content Editor Settings Section**



## Editing Data Displayed in the Hex Editor

You can edit the data read from your in-system memories and constants displayed in the Hex Editor by typing values directly into the editor or by importing memory files.

To modify the data displayed in the Hex Editor, click a location in the editor and type or paste in the new data. The new data appears in blue, indicating modified data that has not been written into the FPGA. On the Edit menu, choose **Value**, and click **Fill with 0's**, **Fill with 1's**, **Fill with Random Values**, or **Custom Fills** to update a block of data by selecting a block of data.

## Importing and Exporting Memory Files

The In-System Memory Content editor allows you specify a file to import and export data values to and from memories that have the In-System Updating feature enabled. Importing from a data files enables you to quickly load an entire memory image. Exporting to a data file enables you to save the contents of the memory for future use and analysis.

To import a file to memory using the In-System Memory Content Editor, select the memory or constant that you want to target from the instance manager. From the Edit menu, click **Import Data from File**, and specify the data file that you want to load to the targeted memory or constant. You can only import a memory file that is in either a Hexadecimal (Intel-Format) file (.hex) or memory initialization file (.mif) format.

Similarly, to export the contents of memory to a file using the In-System Memory Content Editor, select the memory or constant that you want to target from the instance manager. From the Edit menu, click **Export Data from File**, and specify the file name to which you want to save the data. You can export data to a .hex, .mif, Verilog Value Change Dump file (.vcd), or RAM Initialization file (.rif) format.

## Viewing Memories and Constants in the Hex Editor

For each instance of an in-system memory or constant, the Hex Editor displays data in hexadecimal representation and ASCII characters (if the word size is a multiple of 8 bits). The arrangement of the hexadecimal numbers depends on the dimensions of the memory. For example, if the word width is 16 bits, the Hex Editor displays data in columns of words that contain columns of bytes (Figure 16-4).

**Figure 16–4. Editing 16-Bit Memory Words Using the Hex Editor**

Unprintable ASCII characters are represented by a period (.). The color of the data changes as you perform reads and writes. Data displayed in black indicates the data in the Hex Editor was the same as the data read from the device. If the data in the Hex Editor changes color to red, the data previously shown in the Hex Editor was different from the data read from the device.

As you analyze the data, you can use the cursor and the status bar to quickly identify the exact location in memory. The status bar is located at the bottom of the In-System Memory Content Editor and displays the selected instance name, word position, and bit offset (Figure 16–5).

**Figure 16–5. Status Bar in the In-System Memory Content Editor**

The bit offset is the bit position of the cursor within the word. In the following example, a word is set to be 8-bits wide.

With the cursor in the position shown in Figure 16–6, the word location is 0x0000 and the bit position is 0x0007.

---

**Figure 16–6. Hex Editor Cursor Positioned at Bit 0x0007**

With the cursor in the position shown in Figure 16–7, the word location remains 0x0000 but the bit position is 0x0003.

---

**Figure 16–7. Hex Editor Cursor Positioned at Bit 0x0003**

## Scripting Support

The In-System Memory Content Editor supports reading and writing of memory contents via a Tcl script or Tcl commands entered at a command prompt. For detailed information about scripting command options, refer to the Quartus II command-line and Tcl API Help browser.

To run the Help browser, type the following command at the command prompt:

```
quartus_sh --qhelp ↵
```

The *Quartus II Scripting Reference Manual* includes the same information.



For more information about Tcl scripting, refer to the *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*. For more information about command-line scripting, refer to the *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*.

The commonly used commands for the In-System Memory Content Editor are as follows:

- Reading from memory:  
`read_content_from_memory`  
`[-content_in_hex]`  
`-instance_index <instance index>`  
`-start_address <starting address>`  
`-word_count <word count>`

- Writing to memory:  
`write_content_to_memory`
- Save memory contents to file:  
`save_content_from_memory_to_file`
- Update memory contents from File:  
`update_content_to_memory_from_file`



For descriptions about the command options and scripting examples, refer to the Tcl API Help Browser and the *Quartus II Scripting Reference Manual*.

## Programming the Device Using the In-System Memory Content Editor

If you make changes to your design, you can program the device from within the In-System Memory Content Editor. To program the device, follow these steps:

1. On the Tools menu, click **In-System Memory Content Editor**.
2. In the **JTAG Chain Configuration** panel of the In-System Memory Content Editor, select the SRAM object file (.sof) that includes the modifiable memories and constants.
3. Click **Scan Chain**.
4. In the **Device** list, select the device you want to program.
5. Click **Program Device**.

## Example: Using the In-System Memory Content Editor with the SignalTap II Embedded Logic Analyzer

The following scenario describes how you can use the In-System Updating of Memory and Constants feature with the SignalTap II embedded logic analyzer to efficiently debug your design in-system. Although both the In-System Content Editor and the SignalTap II embedded logic analyzer use the JTAG communication interface, you are able to use them simultaneously.

After completing your FPGA design, you find that the characteristics of your FIR filter design are not as expected.

1. To locate the source of the problem, change all your FIR filter coefficients to be in-system modifiable and instantiate the SignalTap II embedded logic analyzer.
2. Using the SignalTap II embedded logic analyzer to tap and trigger on internal design nodes, you find the FIR filter to be functioning outside of the expected cut-off frequency.
3. Using the **In-System Memory Content Editor**, you check the correctness of the FIR filter coefficients. Upon reading each coefficient, you discover that one of the coefficients is incorrect.
4. Because your coefficients are in-system modifiable, you update the coefficients with the correct data using the **In-System Memory Content Editor**.

In this scenario, you are able to quickly locate the source of the problem using both the In-System Memory Content Editor and the SignalTap II embedded logic analyzer. You are also able to verify the functionality of your device by changing the coefficient values before modifying the design source files.

An extension to this example would be to modify the coefficients with the In-System Memory Content Editor to vary the characteristics of the FIR filter (for example, filter attenuation, transition bandwidth, cut-off frequency, and windowing function).

## Conclusion

The In-System Updating of Memory and Constants feature provides access into a device for efficient debug in a hardware lab. You can use In-System Updating of Memory and Constants with the SignalTap II Embedded Logic Analyzer to maximize the visibility into an Altera FPGA. By increasing visibility and access to internal logic of the device, you can identify and resolve problems with your design more easily.

## Referenced Documents

This chapter references the following documents:

- *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*
- *Design Debugging Using the SignalTap II Embedded Logic Analyzer* chapter in volume 3 of the *Quartus II Handbook*
- *Quartus II Scripting Reference Manual*
- *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*

## Document Revision History

Table 16–3 shows the revision history of this chapter.

| <b>Table 16–3. Document Revision History</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                               |
|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| <b>Date and Version</b>                      | <b>Changes Made</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | <b>Summary of Changes</b>                                     |
| May 2008<br>v8.0.0                           | <ul style="list-style-type: none"> <li>Added reference to <a href="#">Section V. In-System Debugging</a> in volume 3 of the <a href="#">Quartus II Handbook</a> on page 16–2</li> <li>Removed references to the Mercury device, as it is now considered to be a “Mature” device</li> <li>Added links to referenced documents throughout document</li> <li>Minor editorial updates</li> </ul>                                                                                                    | Updates made for the Quartus II software version 8.0 release. |
| October 2007<br>v7.2.0                       | Reorganized “Referenced Documents” on page 15–11.                                                                                                                                                                                                                                                                                                                                                                                                                                               | —                                                             |
| May 2007<br>v7.1.0                           | <ul style="list-style-type: none"> <li>Added Scripting Support section on page 15–9.</li> <li>Added Referenced Documents on page 15–11.</li> </ul>                                                                                                                                                                                                                                                                                                                                              | Updates made for the Quartus II software version 7.1 release. |
| March 2007<br>v7.0.0                         | Added Cyclone III device support listed on page 15–2.                                                                                                                                                                                                                                                                                                                                                                                                                                           | —                                                             |
| November 2006<br>v6.1.0                      | <ul style="list-style-type: none"> <li>Added revision history to the document.</li> <li>Updated Table 15–2.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                          | Added information for Stratix III support.                    |
| May 2006<br>v6.0.0                           | Minor updates for the Quartus II software version 6.0.0                                                                                                                                                                                                                                                                                                                                                                                                                                         | —                                                             |
| October 2005<br>v5.1.0                       | <ul style="list-style-type: none"> <li>Updated for the Quartus II software version 5.1.</li> <li>Chapter 13 was formerly Chapter 12 in version 5.0.</li> </ul>                                                                                                                                                                                                                                                                                                                                  | —                                                             |
| May 2005<br>v5.0.0                           | <ul style="list-style-type: none"> <li>Chapter 12 was formerly in Section V of Vol 3 in 4.2.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                         | —                                                             |
| December 2004<br>v1.2                        | <ul style="list-style-type: none"> <li>Chapter 12 was formerly Chapter 11.</li> <li>Updated tables.</li> <li>Corrected the Verilog code for the <code>lpm_hint</code> parameter.</li> <li>Re-organized the “Making Changes” segment into the Editing Data Displayed in the Hex Editor and Importing and Exporting Memory Files segments. Added the Edit value menu.</li> <li>Added Example: Using the In-System Memory Content Editor with the SignalTap II Embedded Logic Analyzer.</li> </ul> | —                                                             |
| Aug. 2004 v1.1                               | Minor typographical corrections.                                                                                                                                                                                                                                                                                                                                                                                                                                                                | —                                                             |
| June 2004 v1.0                               | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | —                                                             |

## Introduction

Traditional debugging techniques often involve using an external pattern generator to exercise the logic and a logic analyzer to study the output waveforms during run-time. The SignalTap® II Logic Analyzer and SignalProbe allow you to read or “tap” internal logic signals during run-time as a way to debug your logic on-chip. While this is useful, you can enhance the debugging cycle efficiency with the ability to drive any internal signal manually within your design. By doing this you can perform the following activities:

- Force the occurrence of trigger conditions setup in the SignalTap II Logic Analyzer
- Create simple test vectors to exercise your design without using external test equipment
- Dynamically control run-time control signals with the JTAG chain

With the introduction of the In-System Sources and Probes feature in the Quartus® II software beginning with version 7.1, Altera extends the portfolio of verification tools. The In-System Sources and Probes feature allows you to easily control any internal signal, providing you with a completely dynamic debugging environment. Coupled with either the SignalTap II Logic Analyzer or SignalProbe, the In-System Sources and Probes feature gives you a powerful debugging environment in which to generate stimuli and solicit responses from your logic design.



The Virtual JTAG Megafunction and the In-System Memory Content Editor also give you the capability to drive virtual inputs into your design. The Quartus II software offers a portfolio of on-chip debugging tools. For an overview and comparison of all the tools available in the Quartus II software on-chip debugging tool suite, refer to *Section V. In-System Debugging* in volume 3 of the *Quartus II Handbook*.

This chapter addresses the following topics:

- “Design Flow Using In-System Sources and Probes” on page 17–4
- “Running the In-System Sources and Probes Editor” on page 17–9
- “Tcl Support” on page 17–15
- “Design Example: Dynamic PLL Reconfiguration” on page 17–19

## Overview

The In-System Sources and Probes feature consists of the altsource\_probe megafunction and an interface to control the altsource\_probe megafunction instances during run-time. Each altsource\_probe megafunction instance provides you with source output ports and probe input ports, where source ports drive selected signals and probe ports sample selected signals. Upon compilation, the altsource\_probe megafunction sets up a register chain to either drive or sample the selected nodes in your logic design. During runtime, the In-System Sources and Probes interface uses a JTAG connection to shift data to and from the altsource\_probe megafunction instances. [Figure 17-1](#) shows a block diagram of the components that make up the In-System Sources and Probes feature.

**Figure 17-1. In-System Sources and Probes Block Diagram**



The altsource\_probe megafunction hides the detailed transactions between the JTAG Hub and the registers instrumented in your design to give you a basic building block for stimulating and probing your design. Moreover, the In-System Sources and Probes feature provides

single-cycle samples and single-cycle writes to the selected logic nodes. This provides an easy way to input simple virtual stimuli and an easy way to capture the current value on instrumented nodes. Because In-System Sources and Probes gives you access to logic nodes within your design, this feature can be used during the debugging process to toggle the inputs of low-level components. If used in conjunction with the SignalTap II Logic Analyzer, you can force trigger conditions to help isolate your problem and shorten your debugging process.

Additionally, the ease of use of the In-System Sources and Probes feature makes it ideal for implementing control signals as virtual stimuli. This feature can be especially helpful for prototyping your design. Examples of such applications could include the ability to do the following:

- Create virtual push buttons
- Create a virtual front panel to interface with your design
- Mimic external sensor data
- Monitor and change run-time constants on the fly

In-System Sources and Probes supports Tcl commands to interface with all your altsource\_probe instances to increase the level of automation.

## Hardware and Software Requirements

The following components are required to use In-System Sources and Probes:

- Quartus II design software  
*or*
- Quartus II Web Edition (with TalkBack feature enabled)
- Download Cable (USB-Blaster™ download cable or ByteBlaster™ cable)
- Altera® development kit or user design board with JTAG connection to device under test

The In-System Sources and Probes feature supports the following device families:

- Arria™ GX
- Stratix® series
- HardCopy® II
- HardCopy Stratix
- Cyclone® series
- MAX® II
- APEX™ II
- APEX 20KE
- APEX 20KC
- APEX 20K

## Design Flow Using In-System Sources and Probes

In-System Sources and Probes supports an RTL flow in which your design nodes are instrumented in your HDL code via instantiation of the altsource\_probe megafunction. After your device is compiled with the design nodes that you want instrumented, you can control your altsource\_probe instances via the Sources and Probes Editor GUI or via a Tcl interface. The complete design flow is shown in [Figure 17-2](#).

Figure 17–2. FPGA Design Flow Using In-System Sources and Probes



## Configuring the altsource\_probes Megafunction

To add in-system sources and probes functionality to your design, you must first instantiate the altsource\_probe megafunction variation file. The altsource\_probe megafunction can be easily configured using the MegaWizard® Plug-In Manager. Each source or probe port can be up to 256 bits wide. You can have up to 128 instances of the altsource\_probe megafunction in your design. The following steps will guide you through the steps necessary to configure the altsource\_probe megafunction:

1. On the Tools menu, click **MegaWizard Plug-In Manager**.
2. Select **Create a new custom megafunction variation**.
3. Click **Next**.
4. On Page 2a, make the following selections:
  - a. In the Installed Plug-Ins list, expand the JTAG-accessible Extensions folder. In the JTAG-accessible Extensions list, select **In-System Sources and Probes**.
  - b. Make sure that the currently selected device family matches the device you are targeting.
  - c. Select an output file type and enter the desired name of the altsource\_probe megafunction. You can choose AHDL (.tdf), VHDL (.vhd), or Verilog HDL (.v) as the output file type.
5. Click **Next**.
6. On Page 3, make the following selections:
  - a. Make sure that the currently selected device family matches the device that you are targeting.
  - b. Under **Do you want to specify an Instance Index?**, turn on **Yes**.
  - c. Specify the Instance ID of this instance.
  - d. Specify the width of the probe port. The width can be from 1 bit to 256 bits wide.
  - e. Specify the width of the source port. The width can be from 1 bit to 256 bits wide.

7. On Page 3, you can click **Advanced Options** and specify other parameters. The following options are included:

- **What is the initial value of the source port, in hexadecimal?** This option allows you to specify the initial value driven on the source port at run-time.
- **Write data to the source port synchronously to the source clock.** This allows you to synchronize your source port write transactions with the clock domain of your choice.
- **Create an enable signal for the registered source port.** When enabled, this creates a clock enable input for the synchronization registers. This option is enabled only when the **Write data to the source port synchronously to the source clock** option is enabled.

**Table 17–1** summarizes the configurable fields for the altsource\_probe megafunction.



The In-System Sources and Probes feature does not support simulation. The megafunction instantiation must be removed before creating a simulation netlist.

**Table 17–1. MegaWizard Plug-In Manager —altsource\_probe (page 3) Options**

| Options                                                                                                                                                                                      | Description                                                                                                              |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| Currently selected device family                                                                                                                                                             | Specifies the device family.                                                                                             |
| Do you want to specify an Instance Index?                                                                                                                                                    | Specifies the numeric index of the megafunction instance during run-time (from 0 to 127).                                |
| The 'Instance ID' of this Instance (optional):                                                                                                                                               | Specifies the four character ID tag of the megafunction in the instance manager window of the Sources and Probes Editor. |
| How wide should the probe port be?                                                                                                                                                           | Specifies the number of signals to be read by In-System Sources and Probes.                                              |
| How wide should the source port be?                                                                                                                                                          | Specifies the number of signals to be driven by In-System Sources and Probes.                                            |
| What is the initial value of the source port? (under <b>Advanced Options</b> )                                                                                                               | Specifies the initial value driven on the source port at run time.                                                       |
| Write data to the source port synchronously to the source clock. Each bit in the source port will utilize two additional registers to achieve metastability (under <b>Advanced Options</b> ) | When turned on, allows you to synchronize your source port write transactions with the clock domain of your choice.      |
| Create an enable signal for the registered source port (configured under <b>Advanced Options</b> )                                                                                           | Turning on this option creates a clock enable input for the synchronization registers.                                   |

## Instantiating the altsource\_probe Megafunction

The MegaWizard Plug-in Manager produces the necessary variation file and the instantiation template based on your inputs to the MegaWizard. Use the template to instantiate the altsource\_probe megafunction variation file in your design. The port information is shown in [Table 17-2](#).

| <b>Table 17-2. altsource_probe Megafunction Port Information</b> |                  |                  |                                                                                                                                                                                   |
|------------------------------------------------------------------|------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Port Name</b>                                                 | <b>Required?</b> | <b>Direction</b> | <b>Comments</b>                                                                                                                                                                   |
| probe []                                                         | No               | Input            | The outputs from the user's design.                                                                                                                                               |
| source_clk                                                       | No               | Input            | Source Data is written synchronously to this clock. This input is required if the Source Clock option is turned on in the Advanced Options box in the MegaWizard Plug-in Manager. |
| source_ena                                                       | No               | Input            | Clock enable signal for source_clk. This input is required if specified in the Advanced Options box in the MegaWizard Plug-in Manager.                                            |
| source []                                                        | No               | Output           | Used to drive inputs to user design.                                                                                                                                              |

You can include up to 128 instances of the altsource\_probe megafunction in your design, provided that there are available logic resources in your device. Each instance of the altsource\_probe megafunction uses a pair of registers per signal for the width of the widest port it contains. Additionally, there will be some fixed overhead logic to accommodate communication between the altsource\_probe instances and the JTAG controller. An additional pair of registers per source port is added for synchronization if it is specified.

## Compiling the Design

When you compile your design with the In-System Sources and Probes megafunction instantiated, an instance of the altsource\_probe instance and sld\_hub megafunctions are added to your compilation hierarchy automatically. These two instances allow communication between the JTAG controller and your instrumented logic.

To modify your In-System Sources and Probes connections, you can modify the number of connections to your design by editing the altsource\_probe megafunction. To open the design instance you want to modify in the MegaWizard Plug-In Manager, double-click the desired instance in the Project Navigator. You can then modify the connections in the HDL source file. You must recompile your design when you are finished editing it.

Because the design cycle is iterative in nature, you can use the Quartus II incremental compilation feature to reduce compilation time. Incremental compilation allows you to organize your design into logical partitions. During recompilation of a design, incremental compilation preserves the compilation results and performance of unchanged partitions and reduces design iteration time by compiling only modified design partitions.



For more information about Incremental Compilation, refer to the *Quartus II Incremental Compilation for Hierarchical & Team-Based Design* chapter in volume 1 of the *Quartus II Handbook*.

## Running the In-System Sources and Probes Editor

The In-System Sources and Probes Editor is a GUI that gives you control over all of the altsource\_probe megafunction instances within your design. It displays all available run-time controllable instances of the altsource\_probe megafunction in your design, provides a push-button interface to drive all of your source nodes, and a logging feature to store your probe and source data.

To run the In-System Sources and Probes Editor, from the **Tools** menu, click **In-System Sources and Probes Editor**.

Figure 17–3 shows the Editor window.

Figure 17–3. In-System Sources and Probes Editor



The In-System Sources and Probes Editor is made up of three panes:

- **JTAG Chain Configuration**—Allows you to specify programming hardware, device, and file settings that the In-System Sources and Probes Editor uses to program and acquire data from a device.
- **Instance Manager**—Displays information about the instances generated when you compile a design, and allows you to control the data the In-System Sources and Probes Editor acquires.
- **Sources and Probes Editor**—Logs all the data read from the selected instance and allows you to modify source data to be written to your device.

Using the In-System Sources and Probes Editor does not require you to open a Quartus II project. The In-System Sources and Probes Editor retrieves all instances of the altsource\_probe megafunction by scanning the JTAG chain and sending a query to the specific device selected in the JTAG Chain Configuration pane. Also, you can use a previously saved configuration to run the In-System Sources and Probes Editor.

Each In-System Sources and Probes Editor window can access the altsource\_probe megafunction instances in a single device. If you have more than one device containing megafunction instances in a JTAG chain, you can launch multiple In-System Sources and Probes Editor windows to access the megafunction instances in each of the devices.

## Programming Your Device Using the JTAG Chain Configuration Window

After compilation is complete, you must configure your FPGA before using In-System Sources and Probes. To configure a device for use with the In-System Sources and Probes, perform the following steps:

1. Open the In-System Sources and Probes Editor.
2. Under JTAG Chain Configuration, point to **Hardware** and select the desired hardware communications device. You may be prompted to configure your hardware; in this case, click **Setup**.
3. From the **Device** list, select the FPGA device to which you want to download the design (it may be automatically detected). You may have to click **Scan Chain** to detect your target device.
4. In the JTAG Configuration window, click **Browse** and select the SRAM Object File (.sof) that includes the In-System Sources and Probes instance or instances. (Note that it may be automatically detected).
5. Click **Program Device** (next to **File:**) to program the target device.

## Instance Manager

The Instance Manager provides a list of all altsource\_probe instances in the design and allows you to configure how data is acquired from or written to those instances.

The Instance Manager is shown in [Figure 17–4](#).

**Figure 17–4. Instance Manager**



The following buttons and sub-panes are provided in the Instance Manager:

- **Read Probe Data**—Samples the probe data in the selected instance and displays it in the Sources and Probes Editor Window
- **Continuously Read Probe Data**—Continuously samples the probe data of the selected instance and displays it in the Sources and Probes Editor Window; you can modify the sample rate via the Probe read interval setting
- **Stop Continuously Reading Probe Data**—Cancels continuous sampling of probe of selected instance
- **Write Source Data** sub-pane —Writes data to all source nodes of the selected instance

- **Probe Read Interval** sub-pane—Displays the sample interval of all the In-system Sources and Probe instances in your design; you can modify the sample interval by clicking **Manual**
- **Event Log** sub-pane—controls the event log in the Sources and Probes Editor Window
- **Write Source Data** sub-pane—Allows you to manually or continuously write data to the system

The status of each instance is also displayed beside each entry in the Instance Manager. The status indicates if the instance is **Not running**, **Offloading data**, **Updating data**, or if an **Unexpected JTAG communication error** occurs. This status indicator provides useful information about the sources and probes instances in your design.

## Sources and Probes Editor Window

The Sources and Probes Editor window organizes and displays the data from all sources and probes in your design, organized according to the index number of the instance. The editor provides an easy way to manage your signals, allowing you to rename signals or to group them into buses. All data collected from source and probe nodes is recorded in the event log and displayed as a timing diagram.

### *Reading Probe Data*

You can read data by selecting the desired altsource\_probe instance in the Instance Manager and clicking **Read Probe Data**. This produces a single sample of the probe data and updates the data column of the selected index in the Sources and Probes Editor window. You can save the data to an event log by turning on the **Save data to event log** option in the Instance Manager.

If you want to sample data from your probe instance continuously, in the Instance Manager, click the instance you want to read, and then click **Continuously read probe data**. While reading, the status of the active instance will show **Unloading**. You can read continuously from multiple instances.

You can access read data by using the right-click menus in the Instance Manager.

To adjust the probe read interval, in the Instance Manager, turn on the **Manual** option in the **Probe read interval** sub-pane, and specify the desired sample rate in the text field next to the **Manual** option. The maximum sample rate depends on your computer setup. The actual sample rate is shown in the **Current interval** box. The event log window buffer size can be adjusted in the **Maximum Size** box.

### *Writing Data*

To modify the source data to be written into the altsource\_probe instance, click in the name field of the signal you want to change. For buses of signals, you can double-click on the data field and type in the value to be driven out to the altsource\_probe instance. The In-System Sources and Probes Editor stores the modified source data values in a temporary buffer. Modified values that have not been written out to the altsource\_probe instances appear in red. To update the altsource\_probe instance, highlight the instance in the Instance Manager and click **Write source data**. The **Write source data** function is also available via the shortcut menus in the Instance Manager.

You can choose to have the values stored in the In-System Sources and Probes Editor continuously update the altsource\_probe instances. By doing so, any modifications you make to the source data buffer are written immediately to the altsource\_probe instances. To continuously update the altsource\_probe instances, change the **Write source data** field from **Manually** to **Continuously**.

### *Data Organization*

The main editor window allows you to group signals into buses, and allows you to modify the display options of the data buffer.

To create a group of signals, select the node names you want to group, right-click and select **Group**. You can modify the display format in the Bus Display Format and the Bus Bit order submenus.

The Sources and Probes Editor Window allows you to rename any signal. To rename a signal, double-click the name of the desired signal and type in the new name.

The event log contains a record of the most recent samples. The buffer size is adjustable, up to 128k samples. The time stamp for each sample is logged and is displayed above the event log of the instance being examined as you move your mouse pointer over the data samples.

You can save the changes that you have made and the recorded data into a Sources and Probes File (**.spf**). To save changes, on the File menu, click **Save**. The file contains all of the modifications you made to the signal groups, as well as the current data event log.

## Tcl Support

To support automation, In-system Sources and Probes supports the procedures described in this chapter in the form of Tcl commands. The Tcl package for In-System Sources and Probes is included by default when you run `quartus_stp`.

The Tcl interface for In-System Sources and Probes provides a powerful platform to help you debug your design. It is especially helpful for debugging designs that require toggling multiple sets of control inputs. You can aggregate multiple commands using a Tcl script to define your own custom command set.



For more information about Tcl scripting, refer to the *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*. For more information about settings and constraints in the Quartus II software, refer to the *Quartus II Settings File Reference Manual*. For more information about command-line scripting, refer to the *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*.

Table 17–3 shows the Tcl commands you can use with In-System Sources and Probes.

**Table 17–3. In-System Sources and Probes Tcl Commands (Part 1 of 2)**

| Command                                              | Argument                                                                                           | Description                                                                                                                                                                                                                                   |
|------------------------------------------------------|----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>start_insystem_source_probe</code>             | <code>-device_name &lt;device name&gt;</code><br><code>-hardware_name &lt;hardware name&gt;</code> | Opens a handle to a device using the specified hardware.<br>Call this command before starting any transactions.                                                                                                                               |
| <code>get_insystem_source_probe_instance_info</code> | <code>-device_name &lt;device name&gt;</code><br><code>-hardware_name &lt;hardware name&gt;</code> | Returns a list of all <code>altsource_probe</code> instances in your design. Each record returned will be in the following format:<br><code>{&lt;instance Index&gt;, &lt;source width&gt;, &lt;probe width&gt;, &lt;instance name&gt;}</code> |
| <code>read_probe_data</code>                         | <code>-instance_index &lt;instance_index&gt;</code><br><code>-value_in_hex (optional)</code>       | Retrieves the current value of the probe.<br>A string is returned specifying the status of each probe, with the MSB as the left-most bit.                                                                                                     |
| <code>read_source_data</code>                        | <code>-instance_index &lt;instance_index&gt;</code><br><code>-value_in_hex (optional)</code>       | Retrieves the current value of the sources.<br>A string is returned specifying the status of each source, with the MSB as the left-most bit.                                                                                                  |

| <b>Table 17–3. In-System Sources and Probes Tcl Commands (Part 2 of 2)</b> |                                                                                   |                                                                                                                |
|----------------------------------------------------------------------------|-----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| <b>Command</b>                                                             | <b>Argument</b>                                                                   | <b>Description</b>                                                                                             |
| write_source_data                                                          | -instance_index<br><instance_index><br>-value <value><br>-value_in_hex (optional) | Sets the value of the sources. A binary string is sent to the source ports, with the MSB as the left-most bit. |
| end_interactive_probe                                                      | None                                                                              | Releases the JTAG chain. Issue this command when all transactions are finished.                                |

Example 17–1 shows an excerpt from a Tcl script with procedures that control the altsource\_probe instances of the design as shown in Figure 17–5. The example design contains a DCFIFO with altsource\_probe instances to read from and write to the DCFIFO. A set of control muxes are added into the design to control the flow of data to the DCFIFO between the input pins and the altsource\_probe instances. A pulse generator is added to the read request and write request control lines to guarantee a single sample read or write. The altsource\_probe instances, when used with the script in Example 17–1, provide visibility into the contents of the FIFO by performing single sample write and read operations and reporting the state of the full and empty status flags.

The Tcl script can be useful in debugging situations where you may want to either empty or preload the FIFO in your design. As an example, you can use this feature to preload the FIFO to match a trigger condition you have set up within the Signal Tap II Logic Analyzer.

Figure 17–5. A DCFIFO Example Design Controlled by the Tcl Script in Example 17–1



---

**Example 17–1. Tcl Script Procedures for Reading and Writing to the DCFIFO in Figure 17–5**

```
## Setup USB hardware - assumes only USB Blaster is installed and
## an FPGA is the only device in the JTAG chain

set usb [lindex [get_hardware_names] 0]
set device_name [lindex [get_device_names -hardware_name $usb] 0]
## write procedure : argument value is integer

proc write {value} {

    global device_name usb
    variable full

    start_insystem_source_probe -device_name $device_name -hardware_name \
    $usb

    #read full flag
    set full [read_probe_data -instance_index 0]

    if {$full == 1} {end_insystem_source_probe
    return "Write Buffer Full"
    }

    ##toggle select line, drive value onto port, toggle enable
    ##bits 7:0 of instance 0 is S_data[7:0]; bit 8 = S_write_req;
    ##bit 9 = Source_write_sel

    ##int2bits is custom procedure that returns a bitstring from an integer
    ## argument

    write_source_data -instance_index 0 -value /[int2bits [expr 0x200 | \
    $value]]
    write_source_data -instance_index 0 -value [int2bits [expr 0x300 | \
    $value]]

    ##clear transaction

    write_source_data -instance_index 0 -value 0

    end_insystem_source_probe
}

proc read {} {

    global device_name usb
    variable empty
    start_insystem_source_probe -device_name $device_name -hardware_name \
    $usb
```

```

##read empty flag : probe port[7:0] reads FIFO output; bit 8 reads
##empty_flag

set empty [read_probe_data -instance_index 1]

if {[regexp {1.....} $empty]} { end_insystem_source_probe
return "FIFO empty" }

## toggle select line for read transaction
## Source_read_sel = bit 0; s_read_reg = bit 1

## pulse read enable on DC FIFO
write_source_data -instance_index 1 -value 0x1 -value_in_hex
write_source_data -instance_index 1 -value 0x3 -value_in_hex

set x [read_probe_data -instance_index 1]

end_insystem_source_probe

return $x
}

```

## Design Example: Dynamic PLL Reconfiguration

The ease of use of the In-System Sources and Probes feature can be extremely helpful in creating a virtual front panel during the prototyping phase of your design. Relatively simple designs of high functionality can be created in a short amount of time. The following PLL reconfiguration example demonstrates how the In-System Sources and Probes feature is used to provide a GUI to dynamically reconfigure a Stratix PLL.

Stratix PLLs allows you to dynamically update PLL coefficients during run-time. Each enhanced PLL within the Stratix device contains a register chain that allows you to modify the pre-scale counters ( $m$  and  $n$  values), output divide counters, and delay counters. In addition, the `altpll_reconfig` megafunction provides an easy interface to access the register chain counters. The `altpll_reconfig` megafunction provides a cache containing all modifiable PLL parameters. After you have updated all of the PLL parameters in the cache, the `alt_pll_reconfig` megafunction drives the PLL register chain to update the PLL with the updated parameters. [Figure 17-6](#) shows a Stratix-enhanced PLL with reconfigurable coefficients.



Stratix II and Stratix III devices also allow you to dynamically reconfigure PLL parameters. For more information about these families, refer to the appropriate data sheet. For more information about dynamic PLL reconfiguration, refer to [AN 282: Implementing PLL Reconfiguration in Stratix & Stratix GX Devices](#) or [AN 367: Implementing PLL Reconfiguration in Stratix II Devices](#).

**Figure 17–6. Stratix-Enhanced PLL with Reconfigurable Coefficients**



The following design example uses an altsource\_probe instance to update the PLL parameters in the altpll\_reconfig megafunction cache. The altpll\_reconfig megafunction connects to an enhanced PLL in a Stratix FPGA to drive the register chain containing the PLL reconfigurable coefficients. This design example uses a Tcl/Tk script to generate a GUI where you can enter in new  $m$  and  $n$  values for the enhanced PLL. The Tcl script extracts the  $m$  and  $n$  values from the GUI, shifts the values out to the altsource\_probe instances to update the values in the altpll\_reconfig megafunction cache and asserts the reconfig signal on the altpll\_reconfig megafunction. The reconfig signal on the altpll\_reconfig megafunction

starts the register chain transaction to update all PLL reconfigurable coefficients. A block diagram of a design example is shown in Figure 17–7. The Tk GUI is shown in Figure 17–8.

**Figure 17–7. Block Diagram of Dynamic PLL Reconfiguration Design Example**



**Figure 17–8. Interactive PLL Reconfiguration GUI Created with Tk and In-System Sources and Probes Tcl Package**



This design example was created using a Nios® II Development Kit, Stratix Edition. The file **sourceprobe\_DE\_dynamic\_pll.zip** contains all of the necessary files for running this design example:

- **Readme.txt**—A text file that describes the files contained in the Design Example and provides instructions on running the Tk GUI shown in Figure 17–8.
- **Interactive\_Reconfig.qar**—The archived Quartus II project for this Design Example

You can download the **sourceprobe\_DE\_dynamic\_pll.zip** file associated with this chapter.

## Conclusion

In-System Sources and Probes can provide stimuli and get responses from the target design during run-time. With its simple and intuitive interface, you can provide virtual inputs into your design during run-time without using external equipment. When used in conjunction with SignalTap II, you can use In-System Sources and Probes to provide greater control of the signals in your design, and thus help shorten the verification cycle. Also, with its ability to create virtual inputs into your design, you can create simple, yet powerful applications to interact with your design.

## Referenced Documents

This chapter references the following documents:

- *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*
- *sld\_virtual\_jtag* *Megafunction User Guide*
- *Quartus II Incremental Compilation for Hierarchical & Team-Based Design* chapter in volume 1 of the *Quartus II Handbook*
- *Quartus II Settings File Reference Manual*
- *Section V. In-System Debugging* in volume 3 of the *Quartus II Handbook*
- *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*

## Document Revision History

Table 17–4 shows the revision history for this chapter.

**Table 17–4. Document Revision History**

| Date and Version       | Changes Made                                                                                                                                                                                                                                                                                                                                                     | Summary of Changes                                              |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|
| May 2008<br>v. 8.0.0   | <ul style="list-style-type: none"> <li>● Documented that this feature does not support simulation on <a href="#">page 17–7</a></li> <li>● Updated <a href="#">Figure 17–8 on page 17–21</a> for Interactive PLL reconfiguration manager</li> <li>● Added hyperlinks to referenced documents throughout the chapter</li> <li>● Minor editorial updates</li> </ul> | Updates related to the Quartus II software version 8.0 release. |
| October 2007<br>v7.2.0 | Reorganized “Referenced Documents” on page 16–21.                                                                                                                                                                                                                                                                                                                | —                                                               |
| May 2007<br>v7.1.0     | Initial Release.                                                                                                                                                                                                                                                                                                                                                 | —                                                               |

The Quartus® II software easily interfaces with EDA formal design verification tools such as the Cadence Encounter Conformal and Synplicity Synplify software. In addition, the Quartus II software has built-in support for verifying the logical equivalence between the synthesized netlist from Synplicity Synplify and the post-fit Verilog Quartus Mapped (.vqm) files using Cadence Encounter Conformal software.

This section discusses formal verification, how to set-up the Quartus II software to generate the **.vqm** file and Cadence Encounter Conformal script, and how to compare designs using Cadence Encounter Conformal software.

This section includes the following chapter:

- [Chapter 18, Cadence Encounter Conformal Support](#)

 For information about the revision history for chapters in this section, refer to each individual chapter for that chapter's revision history.



### Introduction

The Quartus® II software provides formal verification support for Altera® designs through interfaces with a formal verification EDA tool, the Cadence Encounter Conformal software.

Use the Encounter Conformal software to verify the functional equivalence of a post-synthesis Verilog Quartus Mapping (.vqm) netlist file from Synplicity Synplify Pro software and/or the post-fit Verilog Output File (.vo) from the Quartus II software. You can also use the Encounter Conformal software to verify the functional equivalence of the register transfer level (RTL) source code and post-fit .vo file with the Quartus II software when using Quartus II integrated synthesis. These formal verification flows support designs for the Arria™ GX, Stratix® III, Stratix II, Stratix, Stratix II GX, Stratix GX, Cyclone® III, Cyclone II, Cyclone, and HardCopy® II device families.

The two types of formal verification are equivalence checking and model checking. This chapter discusses equivalence checking with the Cadence Encounter Conformal software.

This chapter contains the following sections:

- “Formal Verification Design Flow” on page 18–2
- “RTL Coding Guidelines for Quartus II Integrated Synthesis” on page 18–5
- “Black Boxes in the Encounter Conformal Flow” on page 18–10
- “Generating the Post-Fit Netlist Output File and the Encounter Conformal Setup Files” on page 18–12
- “Understanding the Formal Verification Scripts for Encounter Conformal” on page 18–19
- “Comparing Designs Using Encounter Conformal” on page 18–22
- “Known Issues and Limitations” on page 18–24
- “Black Box Models” on page 18–27
- “Conformal Dofile/Script Example” on page 18–30

Equivalence checking uses mathematical techniques to compare the logical equivalence of two versions of the same design rather than using test vectors to perform simulation. The two compared versions could be post-map design and post-fit design, or RTL design and post-fit design. Equivalence checking greatly shortens the verification cycle of the design.

## Formal Verification Versus Simulation

Formal verification cannot be considered as a replacement to the vector-based simulation. Formal verification only complements the existing vector-based simulation techniques to speed up the verification cycle. Vector-based simulation techniques of gate level designs can take a considerable amount of time.

You can use Vector-based simulation techniques to do the following:

- Verify design functionality
- Verify timing specifications
- Debug designs

### Formal Verification: What You Need to Know

If you use formal verification techniques to verify logic equivalence of your design, you can save time by forgoing a comprehensive vector-based simulation of the gate level design. However, there might be an impact on area and performance during recompilation of your design with the Quartus II software if you choose to use formal verification flow for Cadence Conformal LEC software. The area and performance of your design might be affected by the following factors:

- Hierarchy preservation
- ROM implementation by logic elements (LEs)
- Disabled retiming is disabled

Refer to “[Known Issues and Limitations](#)” on page 18–24 before you consider using the formal verification flow in your design methodology.

## Formal Verification Design Flow

Altera supports formal verification using the Encounter Conformal software for the following two synthesis tools:

- Quartus II Integrated Synthesis
- Synplify Pro

The following sections describe the supported design flows for these synthesis tools.

## Quartus II Integrated Synthesis

The design flow for formal verification using the Quartus II integrated synthesis is shown in [Figure 18–1](#). This flow performs equivalency checking for the RTL source code and the post-fit netlist generated by the Quartus II software. The RTL source code can be in Verilog HDL or VHDL format. The post-fit netlist generated by the Quartus II software is always in Verilog HDL format.

**Figure 18–1. Formal Verification Using Quartus II Integrated Synthesis and the Encounter Conformal Software**



## EDA Tool Support for Quartus II Integrated Synthesis

The formal verification flow using the Quartus II software and Cadence Encounter Conformal software supports the following software versions and operating systems:

- Quartus II software beginning with version 4.2
- Cadence Encounter Conformal software beginning with 4.3.5A
- Solaris and Linux operating systems

## Synplify Pro

The design flow for formal verification using Synplify Pro Synthesis performs equivalency checking for the post-synthesis netlist from Synplify Pro and the post fit netlist generated by Quartus II software, as shown in [Figure 18–2](#).



For additional information about performing equivalency checking between RTL and post-synthesis netlist generated from Synplify Pro software, refer to the Synplify Pro documentation.

**Figure 18–2. Formal Verification Flow Using Synplify Pro and the Encounter Conformal Software**



### EDA Tool Support for Synplify Pro

The formal verification flow using the Quartus II software, the Synplicity Synplify Pro, and the Cadence Encounter Conformal software supports the software versions and operating systems shown in [Table 18–1](#).

**Table 18–1. Compatible Software Versions**

| Quartus II Software Version | Cadence Conformal LEC Version | Synplify Pro Version |
|-----------------------------|-------------------------------|----------------------|
| 4.1                         | 4.3.0.a                       | 7.6.1                |
| 4.2                         | 4.3.5.a                       | 8.0                  |
| 5.0                         | 5.1                           | 8.1                  |
| 5.1                         | 5.1                           | 8.4                  |
| 6.0                         | 5.2                           | 8.5                  |
| 6.1                         | 6.1                           | 8.6.2                |
| 7.0                         | 6.1                           | 8.6.2                |
| 7.1                         | 6.2                           | 8.8.1                |
| 7.2                         | 7.1                           | 9.0                  |
| 8.0                         | 7.1                           | 9.4                  |

# RTL Coding Guidelines for Quartus II Integrated Synthesis

The Cadence Encounter Conformal software can compare the RTL code against the post-fit netlist generated by the Quartus II software. The Encounter Conformal software and the Quartus II integrated synthesis parse and compile the RTL description in slightly different ways. The Quartus II software supports some RTL features that the Encounter Conformal software does not support and vice versa. The style of the RTL code is of particular concern because neither tool supports some constructs, leading to potential formal verification mismatches; for example, state machine extraction, wherein different encoding mechanisms can result in different structures. Therefore, for successful verification, both tools must interpret the RTL code in the same manner.

The following section provides information on recognizing and preventing problems that can arise in the formal verification flow.



For more details about RTL coding styles for Quartus II integrated synthesis, refer to the *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook*.



Some of the coding guidelines apply to both the Quartus II integrated synthesis and Synplify Pro flow, as indicated in each of the guidelines in the following sections.

## Synthesis Directives and Attributes

Synthesis directives, also known as pragmas, play an important role in successful verification of RTL against the post-fit .vo netlist file from the Quartus II software.

Pragmas and trigger keywords that are supported in Quartus II integrated synthesis and Encounter Conformal are also supported in the formal verification flow. The Quartus II integrated synthesis and Encounter Conformal both support the trigger keywords “synthesis” and “synopsys.” When the Quartus II software does not recognize a keyword such as “verplex” the keyword is disabled in the formal verification scripts produced for use with the Cadence Conformal software. Therefore, it is important to use caution with unsupported pragmas because they can lead to verification mismatches.

For example, you can use the Quartus II integrated synthesis to synthesize RTL code with the synthesis directive `read_comments_as_HDL`.

---

**Example 18–1. Verilog HDL Example of Read Comments as HDL**

```
// synthesis read_comments_as_HDL on
// my_rom lpm_rom (.address (address),
// .data (data));
// synthesis read_comments_as_HDL off
```

---

**Example 18–2. VHDL Example of Read Comments as HDL**

```
-- synthesis read_comments_as_HDL on
-- my_rom : entity lpm_rom
-- port map (
-- address => address,
-- data => data, );
-- synthesis read_comments_as_HDL off
```

---



The Encounter Conformal software does not support the synthesis directive `read_comments_as_HDL`, and the directive has no affect on the Encounter Conformal software.

Table 18–2 lists supported pragmas and trigger keywords for formal verification.

**Table 18–2. Supported Pragmas and Trigger Keywords for Formal Verification**

| Pragmas (1)                                                                                                                                                                                       | Trigger Keywords                                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|
| <code>full_case</code><br><code>parallel_case</code><br><code>pragma</code><br><code>synthesis_off</code><br><code>synthesis_on</code><br><code>translate_off</code><br><code>translate_on</code> | <code>synthesis</code><br><code>synopsys</code> |

*Note to Table 18–2:*

- (1) Do not use Verilog 2001-style pragma declarations. The Quartus II software and the Encounter Conformal software support this style of pragma in different manners.

## Stuck-at Registers

Quartus II integrated synthesis eliminates registers that have their output stuck at a constant value. Quartus II integrated synthesis gives a warning message and adds an entry to the corresponding report panel in the formal verification folder of the Analysis & Synthesis section of the Compilation Report. If Conformal LEC does not find the same optimizations, it can lead to unmapped points in the golden netlist. Example 18-3 illustrates the issue.

---

### Example 18-3. Verilog HDL Example Showing Stuck at Registers

```
module stuck_at_example {clk, a,b,c,d,out};  
input a,b,c,d,clk;  
output out;  
reg e,f,g;  
    always @ (posedge clk) begin  
        e <= a and g; // e is stuck at 0  
        g <= c and e; // g is stuck at 0  
        f <= e | b;  
    end  
assign out = f and d;  
endmodule
```

---

In this module description, registers e and g are tied to logic 0. In this example, the Quartus II software generates the following warning message:

```
Warning: Reduced register "g" with stuck data_in port to stuck value GND  
Warning: Reduced register "e" with stuck data_in port to stuck value GND
```

Quartus II integrated synthesis then adds a command to the formal verification scripts telling Conformal LEC that a register is stuck at a constant value, as shown in Example 18-4.

---

### Example 18-4. Conformal LEC Script Showing Commands for Instance Equivalence

```
// report floating signals  
// Instance-constraints commands for constant-value registers removed  
// during compilation  
// add instance constraints 0 e -golden  
// add instance constraints 0 g -golden
```

---

The command is commented in the formal verification script, forcing the Encounter Conformal software to treat the register as stuck at a constant value and potentially hiding a compilation error. You must verify that input to the `e` and `g` registers is constant in the design and uncomment the command to obtain accurate results.



Altera recommends recoding your design to eliminate “stuck-at” registers.

The stuck-at register information in this section also applies to the Synplify Pro flow.

## ROM, LPM\_DIVIDE, and Shift Register Inference

For the purpose of formal verification, the Quartus II integrated synthesis implements both ROM and shift registers in the form of LEs instead of using dedicated on-chip memory resources. Using LEs can be less area-efficient than inferring a megafunction that can be implemented in a RAM block. However, the Quartus II software generates a warning message indicating that the megafunction was not inferred. Quartus II integrated synthesis also reports a suggested ROM or shift register instantiation that enables you to either use the MegaWizard® Plug-In Manager to create the appropriate megafunction explicitly, or to isolate the corresponding logic in a separate entity that you can set as a black box. By setting black box properties on a particular module or entity, you are telling the formal verification tool not to peek inside the module or entity for formal verification. If the black box properties are set on the corresponding megafunction before synthesis, you can verify the megafunction with the Encounter Conformal software. For details about setting black box properties on a particular module, refer to [Table 18–3](#).

If the design contains division functionality, the Quartus II software infers an LPM\_DIVIDE megafunction, which is treated as a black box for the purpose of formal verification.

## RAM Inference

When the Quartus II software infers the LPM ALTSYNCRAM megafunction from the RTL code, the Quartus II software generates the following warning message:

Created node "<mem\_block\_name>" as a RAM by generating altsyncram megafunction to implement register logic with M512 or M4K memory block or M-RAM. Expect to get an error or a mismatch for this block in the formal verification tool.

This warning is generated because the memory block (`alt syncram`) is a new instance in the post-fit netlist that is handled as a black box by the formal verification tool. However, no such instance exists in the original RTL design, resulting in mismatch or error reporting in the formal verification tool.

## Latch Inference

A latch is implemented in the Quartus II integrated synthesis using a combinational feedback loop. The Encounter Conformal software infers a latch primitive in the Encounter Conformal library (DLAT) to implement a latch. This results in having a DLAT on the golden side and a combinational loop with a cut point on the revised side, leading to verification mismatches. The Quartus II software issues a warning message whenever a latch is inferred, and the Quartus II software adds an entry to the report panel in the Formal Verification folder of the Analysis & Synthesis report. Altera recommends that you avoid latches in your design; however, if latches are necessary, Altera recommends using the corresponding LPM\_LATCH megafunction.



For more information about the problems related to latches, refer to the *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook*.

## Combinational Loops

If the design consists of an intended combinational loop, you must define an appropriate cut point for both the RTL and the post-fit `.v` netlist file. A warning that a combinational loop exists in the design is found in the Formal Verification subfolder of the Quartus II software Analysis and Synthesis report.

For more information on issues with combinational loops, refer to “[Known Issues and Limitations](#)” on page 18–24.

## Finite State Machine Coding Styles

When a state machine is inferred by the Encounter Conformal software, it uses sequential encoding as the default encoding when no user encoding is present. The Quartus II software selects the encoding most suited for the inferred state machine if the **State Machine Processing** settings is set to the default value **Auto**. To do this, perform the following steps:

1. On the Assignments menu, click **Settings**. The **Settings** dialog box appears.

2. In the **Category** list, select **Analysis & Synthesis Settings**. The **Analysis & Synthesis Settings** page appears.
3. Click **More Settings**. The **More Analysis & Synthesis Settings** dialog box appears.
4. Under **Option**, in the **Name** list, select **State Machine Processing**. In the **Setting** list, select **Auto**.
5. Click **OK**.
6. Click **OK**.

Therefore, it is important to use the coding style described in the *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook* on RTL when writing finite state Machines (FSMs). This allows the Quartus II integrated synthesis and the Encounter Conformal software to infer a similar state machine for the same RTL code.

## Black Boxes in the Encounter Conformal Flow

The Quartus II software usually generates a flattened netlist; However, you must treat some modules in the design as black boxes. The following is a list of some of these modules:

- LPMs and megafunctions without formal verification models
- Encrypted IP functions
- Entities not implemented in Verilog HDL or VHDL

To perform equivalence checking of a design between its version consisting of the modules listed above and its implemented version, the modules have to be treated as black boxes by the Encounter Conformal software. To facilitate the formal verification flow, the Quartus II software reconstructs the hierarchy on the black boxes with a port interface that is identical to the module on the golden side of the design.

If your golden netlist (.vqm netlist file from Synplify Pro or RTL) includes any design entity not having a corresponding formal verification model, that entity is handled as a black box with its boundary interface preserved. There are three types of black boxes and required user actions, depending upon circumstances. [Table 18-4](#) describes these three types of black boxes and the required user actions in detail.

Verilog Output netlist files written by the Quartus II software contain the black box hierarchy when you make the following assignments for a module:

- An EDA Formal Verification Hierarchy assignment with the value BLACKBOX
- A Preserve Hierarchical Boundary assignment with the value FIRM

If these two assignments are not made for a module, the Quartus II software implements that module with logic cells. When this happens, the .vo netlist file no longer contains the black box hierarchy and does not preserve the port interface, resulting in a mismatch within the Encounter Conformal software.

**Table 18–3. Black Boxes and Required User Action**

| Type of Black Box                                                                                                           | Required User Action                                                                                                          |
|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| Altera library of parameterized modules (LPMs) and megafunctions (refer to <a href="#">Table 18–5</a> for a complete list). | No action required. The Quartus II software automatically creates a black box list of components and preserves the hierarchy. |
| Any parametrized entity other than those listed in <a href="#">Table 18–5</a> .                                             | User must designate the wrapper that instantiates the parameterized entity as a black box.                                    |
| Non-parameterized entities that the user wants designate as a black box.                                                    | User can designate the entity itself as a black box.                                                                          |

You can also use Tcl commands or Quartus II GUI to set the black box property on the entities, which the formal verification tool does not compare.

#### *Tcl Command*

Use the Tcl commands of [Example 18–5](#) to preserve the boundary interface of a black box entity: dram.

---

#### **Example 18–5. Tcl Command to Create a Black Box**

---

```
set_instance_assignment -name PRESERVE_HIERARCHICAL_BOUNDARY FIRM -to | -entity dram
set_instance_assignment -name EDA_FV_HIERARCHY BLACKBOX -to | -entity dram
```

---

*GUI*

To preserve the boundary interface of an entity using the GUI, perform the following steps:

1. Make an EDA Formal Verification Hierarchy assignment to the entity with the value BLACKBOX.
2. Make a Preserve Hierarchical Boundary assignment to the entity with the value Firm (Figure 18–3).

**Figure 18–3. Setting the Black-Box Property on a Module**



## Generating the Post-Fit Netlist Output File and the Encounter Conformal Setup Files

The following steps describe how to set up the Quartus II software environment to generate the post-fit .v0 netlist file and the Encounter Conformal script for use in formal verification. With the exception of step 2, the steps are identical for both of the Synthesis tools:

To create a new Quartus II project or open an existing project, perform the following steps:

1. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.

2. In the **Category** list, click **EDA Tool Settings**.

If you are using the Quartus II integrated synthesis, perform the following steps:

- a. In the **Category** list, under **EDA Tool Settings**, select **Design Entry/Synthesis**. Select **<None>** from the **Tool name** list.
- b. In the **Category** list, under **EDA Tool Settings**, select **Formal Verification**. Select **Conformal LEC** from the **Tool name** list (Figure 18–4).

**Figure 18–4. Compilation Process Settings**



If you are using Synplify Pro, perform the following steps:

- a. In the **Category** list, under **EDA Tool Settings**, select **Design Entry/Synthesis**. Select **Synplify Pro** from the **Tool name** list.
- b. In the **Category** list, under **EDA Tool Settings**, select **Formal Verification**. Select **Conformal LEC** from the **Tool name** list.

3. In the **Category** list, click the “+” icon to expand **Compilation Process Settings**, and select **Incremental Compilation**. The **Incremental Compilation** page appears.
4. Select **Full Incremental Compilation** to turn on Incremental Compilation.

*or*

Turn on Incremental Compilation by typing the following Tcl command in the Quartus II software Tcl console:

```
set_global_assignment -name INCREMENTAL_COMPILATION \
FULL_INCREMENTAL_COMPILATION
```



Altera requires that Incremental Compilation be turned **On** for Formal Verification, and that your design does not contain any user created partitions. Starting with Quartus II software version 6.1 and later, the incremental compilation feature is **On** by default.

5. In the **Category** list click the “+” icon to expand **Analysis and Synthesis Settings**, and click **Synthesis Netlist Optimizations**. The **Synthesis Netlist Optimizations** page appears.
6. Turn off **Perform gate-level register retiming** ([Figure 18-5](#)).



If **Perform gate-level register retiming** is not turned off, the Encounter Conformal script can display a different set of compare points, making the resulting netlist difficult to compare against the reference netlist file.

**Figure 18–5. Synthesis Netlist Optimizations**

7. In the **Category** list, click the “+” icon to expand **Fitter Settings**, and select **Physical Synthesis Optimizations**. The **Physical Synthesis Optimizations** page appears.
  - a. Under **Physical synthesis for registers**, turn off **Perform register retiming**.
  - b. Under **Physical Synthesis for Fitting**, turn off both **Perform physical synthesis for combinational logic** and **Perform logic to memory mapping** to prevent logic from being mapped to RAMs (Figure 18–6).

**Figure 18–6. Fitter Settings**

Retiming a design, either during the synthesis step or during the fitting step, usually results in moving and merging registers along the critical path and is not well supported by the equivalence checking tools. Because equivalence checkers compare the cone of logic terminating at registers, do not use retiming to move the registers during optimization in the Quartus II software.



If the **Perform gate-level register retiming** (Figure 18–5) and **Perform register retiming** options (Figure 18–6) are not turned off, the Encounter Conformal script displays a different set of compare points, making the resulting netlist difficult to compare against the reference netlist file. If you use retiming in your design during compilation, you cannot generate a netlist for formal verification.



To learn more about physical synthesis, refer to the *Netlist Optimizations and Physical Synthesis* chapter in volume 2 of the *Quartus II Handbook*.

8. Perform a full compilation of the design. On the Processing menu, click **Start Compilation**, or click the **Start Compilation** icon on the Toolbar.

## The Quartus II Software Generated Files, Formal Verification Scripts, and Directories

After successful compilation, the Quartus II software generates a list of files, formal verification scripts, and directories in the `<project_directory>fv/conformal/` directory (Table 18-4).

**Table 18-4. The Quartus II Software Compiler-Generated Files and Directories (Part 1 of 2)**

| File or Directory | Name                                      | Details                                                                                                                                                                                                                                                                                                                                         |
|-------------------|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .vo file          | <code>&lt;proj rev&gt;.vo</code>          | The Quartus II software-generated netlist for formal verification.                                                                                                                                                                                                                                                                              |
| Script file       | <code>&lt;proj rev&gt;.ctc</code>         | The <code>&lt;proj rev&gt;.ctc</code> file references <code>&lt;proj rev&gt;.clg</code> and <code>&lt;proj rev&gt;.clr</code> that read the library files and black box descriptions. The <code>&lt;proj rev&gt;.ctc</code> file also references the <code>&lt;proj rev&gt;.cmc</code> file containing information about the mapped points. (1) |
|                   | <code>&lt;proj rev&gt;.cec</code>         | The <code>&lt;proj rev&gt;.cec</code> file contains the information for instance equivalences.                                                                                                                                                                                                                                                  |
|                   | <code>&lt;proj rev&gt;.cep</code>         | The <code>&lt;proj rev&gt;.cep</code> file contains the information for black box pin equivalences in the design.                                                                                                                                                                                                                               |
|                   | <code>&lt;proj rev&gt;.cmp</code>         | The <code>&lt;proj rev&gt;.cmp</code> file contains the information for the black box pin mapping between the golden and revised sides. (2)                                                                                                                                                                                                     |
|                   | <code>&lt;proj rev&gt;.cmc</code>         | The <code>&lt;proj rev&gt;.cmc</code> file contains information about the additional points to be mapped in addition to the points selected by the tool.                                                                                                                                                                                        |
|                   | <code>&lt;proj rev&gt;_trivial.cmc</code> | This <code>&lt;proj rev&gt;_trivial.cmc</code> file contains mapping information for all the key points in the design. (3)                                                                                                                                                                                                                      |
|                   | <code>&lt;proj rev&gt;.clr</code>         | The <code>&lt;proj rev&gt;.clr</code> file contains information about the macros and libraries for the revised design.                                                                                                                                                                                                                          |
|                   | <code>&lt;proj rev&gt;.clg</code>         | The <code>&lt;proj rev&gt;.clg</code> file contains information about the macros and libraries for the golden design.                                                                                                                                                                                                                           |

**Table 18–4. The Quartus II Software Compiler-Generated Files and Directories (Part 2 of 2)**

| File or Directory           | Name                                                      | Details                                                                                                                                                                                                                                                                                            |
|-----------------------------|-----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>blackboxes</b> directory | <project directory>/fv/conformal/<project rev>_blackboxes | This directory contains top-level module descriptions for all the user-defined black box entities and contains modules with definitions other than Verilog HDL or VHDL, for example, Block Design File (.bdf) in the design directory<br><project directory>/fv/conformal/<project rev>_blackboxes |

**Notes to Table 18–4:**

- (1) This file is used with the Encounter Conformal software.
- (2) This file is called from the <proj rev>.ctc script file. By default, the line where this file is called is commented out. These files are only useful for HardCopy® II device families.
- (3) In some cases, Encounter Conformal software performs incorrect key point mapping, resulting in formal verification mismatches. To overcome the verification mismatches, the Quartus II software writes out the <proj rev>\_trivial.cmc file that contains mapping information for all the key points in the design. Reading this file during the formal verification setup can result in increased run time. Therefore, the Quartus II software writes out the top-level script file <proj rev>.ctc with the command to read the <proj rev>\_trivial.cmc file commented. If the formal verification results are not acceptable, the user can uncomment the command and read the <proj rev>\_trivial.cmc file. The command in the <proj rev>.ctc file is:

```
//Trivial mappings with same name registers
//read mapped points $PROJECT/fv/conformal/<proj rev>_trivial.cmc
```

The script file contains the setup and constraints information to use with the formal verification tool. The file <entity>.v in the **blackboxes** directory contains the module description of entities that are not defined in the formal verification library. The file also contains entities that you specify as black boxes. For example, if there is a reference to a black box for an instance of the ALTDPRAM megafunction in the design, the **blackboxes** directory does not contain a module description for the ALTDPRAM megafunction because it is defined in the **altdpram.v** file of the formal verification library. When a module does not have an RTL description, or the description exists only in the formal verification library and you do not want to compare the module using formal verification, a file containing only the top-level module description with port declaration is written out to the **blackboxes** directory and read into the Encounter Conformal software. To learn more about black boxes, refer to “[Black Boxes in the Encounter Conformal Flow](#)” on page 18–10.

# Understanding the Formal Verification Scripts for Encounter Conformal

The Quartus II software generates scripts to use with the Encounter Conformal Logic Equivalence Check (LEC) software. This section elaborates on the details of the Encounter Conformal commands used within the scripts to help you compare the revised netlist with the golden netlist. In most cases, you do not need to add any more Encounter Conformal constraints to verify your netlists. Also, a sample script generated by the Quartus II software is provided at the end of the chapter.

## The Encounter Conformal Commands within the Quartus II Software-Generated Scripts

The value for the variable QUARTUS is the path to the Quartus II software installation directory:

```
setenv QUARTUS <Quartus Installation Directory>
```

The Quartus II software assigns the current working directory of the project to the PROJECT variable. Use this variable to change the project directory to the directory where the design files are installed when moving from a UNIX to a Windows environment, or vice versa:

```
setenv PROJECT <Quartus Project Directory>
```

The following command reads both the golden and the revised netlists, along with the appropriate library models:

```
read design <design files>
```



You must update the project location when the files are moved from the Windows environment to the UNIX environment.

The post place-and-route netlist from the Quartus II software might contain net and instance names that are slightly different from those of the golden netlist. By using the following command, the Quartus II software defines temporary substitute string patterns enabling the Encounter Conformal software to automatically map key points when the names are not the same:

```
add renaming rule <rule>
```

The Encounter Conformal LEC software employs three name-based methods to map key points to compare the revised netlist with the golden netlist. Scripts set the correct method to get the best results.

```
set mapping method <mapping_rule>
```

The Quartus II software performs several optimizations, including optimizing the registers whose input is driven by a constant. Under these circumstances, for the formal verification software to compare the netlists properly, the command `set flatten model` is used with the option `seq_constant`.

```
set flatten model <flattening_rule>
```

When you use the command `report black box`, verify that the following modules are listed as black boxes, along with any of the modules black boxed by the user, in both the golden and revised netlists:

- LPMs and megafunctions without the formal verification models
- Encrypted IP functions
- Entities not implemented in Verilog HDL or VHDL

Use the following command to set the same implementation on multipliers for both the golden and revised netlists:

```
set multiplier implementation <implementation_name>
```

If there are any combinational loops or instances of `LPM_LATCH`, the Quartus II software cuts the loop at the same point using the following command on both the golden and revised netlists:

```
add cut point
```

The Encounter Conformal software does not always automatically map all the keypoints, or can incorrectly map some keypoints. To help the Encounter Conformal software successfully complete the mapping process, the Quartus II software records optimizations performed on the netlist as a series of `add mapped points` in the Encounter Conformal `<file_name>.cmc` script.

```
add mapped points <key_points>
```

There are situations where the inverter in front of the register gets moved after the register. In this situation, the following command is used:

```
add mapped points <key_points> -invert
```

The following command reads in the mapped point information from the specified file:

```
read mapped points <file_name>.cmc
```

**Figure 18–7. Instance Equivalence**

During the process of optimization, the Quartus II software might merge two registers into one (Figure 18–7). The Quartus II software informs the formal verification tool that the U1 and U2 registers are equivalent to each other using the following command:

```
add instance equivalence <instance_pathname ..> [-Golden]
```

If the register duplication takes place, the following command is used:

```
add instance equivalence <instance_pathname ..>
[-revised]
```

The following command is used when the inverter is moved beyond the register along with either register duplication or merging:

```
add instance equivalences <instance_pathname>
[-invert <instance_pathname>]
```

At times, the register output is driven to a constant, either logic 0 or logic 1. The Quartus II software sets the value of the register to a constraint using the add instance constraint command. For more information about this command, refer to “[Stuck-at Registers](#)” on page 18–7.

```
add instance constraint <constraint_value>
```

## Comparing Designs Using Encounter Conformal

This section addresses using the Encounter Conformal software to compare designs; that is, how to prove logical equivalence between two versions of the design.

### *Running the Encounter Conformal Software from the GUI*

To run the Encounter Conformal software from the GUI, follow these steps:

1. Open the Encounter Conformal software.
2. On the File menu, click **Do Dofile**.
3. Select the file *<path to project directory>/fv/conformal/<proj rev>.ctc*.

The Encounter Conformal software GUI displays the comparison results ([Figure 18–8](#)). The Golden window displays the original RTL description or the post synthesis .vqm netlist file from Synplify Pro, and the Revised window displays the information of the post-fit netlist generated by the Quartus II software. The message section at the bottom of the window reports the verification results and the number of unmapped and non-equivalent points found in the design.

**Figure 18–8. Encounter Conformal Software GUI Display of Functional Comparisons**



To investigate the verification results, click the **Mapping Manager** icon in the toolbar, or on the Tools menu, click **Mapping Manager**. The Encounter Conformal software reports the mapped, unmapped, and compared points in the Mapped Points, Unmapped Points, and Compared Points windows, respectively.



For more information about how to diagnose non-equivalent points, refer to the Encounter Conformal software user documentation.

## *Running the Encounter Conformal Software From a System Command Prompt*

To run the Encounter Conformal Software without using the GUI, type the command shown in Example 18–6 at a system command prompt.

### **Example 18–6. Conformal LEC Command to Run Formal Verification**

```
lec -dofile /<path to project directory>/fv/conformal/<proj rev>.ctc -nogui
```

To get a downloadable design example showing the formal verification flow with Quartus II software, go to [www.altera.com/support/examples/quartus/exm-formal-verification.html](http://www.altera.com/support/examples/quartus/exm-formal-verification.html).



To learn more about the latest debugging tips and solutions for formal verification flow between Cadence Conformal LEC tool and Quartus II software, go to [www.altera.com](http://www.altera.com) and perform an advanced search with keywords “formal verification.”

## **Known Issues and Limitations**

The following known issues and limitations can occur when using the formal verification flow described in this chapter:

- When a port on a black box entity drives two or more signals within the black box, the Quartus II software pushes the connections outside of the black box, and creates that many ports on the black box. This problem is only associated with Stratix II and HardCopy II designs.

The additional ports on the black box are named `_unassoc_inputs_[]` and `_unassoc_outputs_[]` (Figure 18–9). This issue is generally associated with reset and enable signals. Figure 18–9 shows an example in which the reset pin is split into two ports outside of the black box and the `_unassoc_inputs_[]` is driven by the `clkctrl` block. In such situations, the `.vo` netlist file generated by the Quartus II software has signals driving these black box ports, but golden RTL does not contain any signals to drive the `_unassoc_inputs_[]`, resulting in a formal verification mismatch of the black box. The black box module definition generated by the Quartus II software in the directory `<Quartus_project>\fv\conformal\*._blackboxes` contains these additional `_unassoc_inputs_[]` and `_unassoc_outputs_[]` ports. This black box module is read on

both the golden and revised sides of the design, which results in unconnected ports on the golden side and formal verification mismatches.

Figure 18–9 shows the creation of `_unassoc_inputs_[]` and `_unassoc_outputs_[]` for the reset signal.

**Figure 18–9. Creation of `_unassoc_inputs_[]` and `_unassoc_outputs_[]`**



Another common occurrence of this issue is in HardCopy II designs. Whenever a port drives large fan-out within the black box, the Quartus II software inserts a buffer on the net and moves the logic outside of the black box (Figure 18–10).

To fix the problem of `unassoc_input_[]` ports causing blackbox mismatches, use Cadence Conformal commands to change the type of the blackbox `unassoc_input_[]` keypoint to a primary output keypoint, and then marking the appropriate pin equivalences. Similarly, to fix the problem of register mismatches due to `unassoc_output_[]` pins from blackboxes, use Conformal commands to change the type of the blackbox `unassoc_output_[]` keypoint to a primary input, and then marking equivalent pins as such. The commands to perform these actions are written in the `<proj rev>.cep` file.

Figure 18–10 shows the creation of `_unassoc_inputs_[]` for a signal with large fan-out.

**Figure 18–10. Creation of `_unassoc_inputs_[]` for a Signal with Large Fan-out**



- In designs with combinational feedback loops, the Encounter Conformal software can insert extra cut points in the revised netlist, causing unmapped points and ultimately verification mismatches.
- For Cyclone II designs, Conformal LEC might report non-equivalent flipflops and extra cut points for the revised (post-fit) design when your HDL source code instantiates the `lpm_ff` primitive with an asynchronous load signal `aload` (with or without any other asynchronous control signals) and when the asynchronous clear signal `ac1r` and asynchronous set signal `aset` are used together. To avoid this problem, ensure that there is a wrapper module or entity around the `lpm_ff` instantiation, and black box the module or entity that instantiates the `lpm_ff` primitive.
- For Stratix III designs, the Cadence Conformal LEC software creates cut points for the combinational loops on the golden side and might fail equivalence checking due to improper mapping. The combinational loops are due to logic around the registers emulating multiple set, resets, or both. These cut points are also reported during the mapping step in Quartus II software with Warning messages. You can manually add Cadence Conformal commands to add cut points, which result in proper mapping and formal verification.
- To perform formal verification, certain synthesis optimization options, such as register retiming, optimization through black box hierarchy boundaries, and disabling the ROM and shift register inference, are turned off, which can have an impact on the area resource and performance.
- RAM and ROM instantiations, inferences, or both are not verified using formal verification.

- Incremental Compilation for the purpose of formal verification does not support user-created design partitions.
- Formal verification does not support clear box netlist due to unconnected ports on its WYSIWYG instances.
- Formal verification does not support VHDL megafunction variations due to undriven ports on the megafunctions.
- When a black box contains bidirectional ports, the Quartus II software fails to reconstruct the hierarchy. For this reason, the black box is represented by a flat netlist, resulting in formal verification mismatches.
- ROMs in the design have to be black boxed before compilation using Quartus II integrated synthesis, because the Quartus II software might perform some optimizations on the ROM, resulting in Formal Verification mismatches.
- Conformal might report mismatches or abort comparison of some key points when a DSP megafunction is implemented in LEs by the Quartus II software due to implicit optimizations within the DSP and the complexity of the multiplier logic in terms of LEs.
- Unused logic optimized within and around a black box by the Quartus II software can result in a black-box interface different from the interface in the synthesized .vqm netlist file.

## Black Box Models

The black box models are interface definitions of entities, such as primitives, atoms, LPMs, and megafunctions. These models have a parameterized interface, and do not contain any definition of behavior. They are specifically designed and tested to work with the Encounter Conformal software, which uses these models along with your design to generate black boxes for instances of the entity with varying sets of parameters in the design. [Table 18–5](#) describes the supported black box models. Besides these black box models, you can set a black box property on a specific module or entity as explained earlier in this chapter.

**Table 18–5. Supported Black Box Models (Part 1 of 3)**

| Entity Type   | Entity Names                                                                                                                                                     |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Megafunctions | ALT3PRAM, ALTACCUMULATE, ALTFP_MULT, ALTSQRT, ALTLVDS_RX, ALTLVDS_TX, ALTSHIFT_TAPS, SLD_VIRTUAL_JTAG SLD_VIRTUAL_JTAG_BASIC DCFIFO, SCFIFO, ALTSYNCRAM, ALTSQRT |
| LPMs          | lpm_add_sub, lpm_divide                                                                                                                                          |

**Table 18–5. Supported Black Box Models (Part 2 of 3)**

| Entity Type | Entity Names                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Atoms (1)   | <p>Cyclone:</p> <p>cyclone_crcblock, cyclone_jtag, cyclone_pll, cyclone_ram_block,<br/>cyclone_asmiblock, cyclone_dll</p>                                                                                                                                                                                                                                                                                                                                                                                                        |
|             | <p>Stratix:</p> <p>stratix_crcblock, stratix_jtag, stratix_lvds_receiver,<br/>stratix_lvds_transmitter, stratix_pll, stratix_rublock,<br/>stratix_ram_block, stratix_dll</p>                                                                                                                                                                                                                                                                                                                                                     |
|             | <p>Stratix II:</p> <p>stratixii_crcblock, stratixii_jtag, stratixii_lvds_receiver,<br/>stratixii_lvds_transmitter, stratixii_pll, stratixii_rublock,<br/>stratixii_ram_block, stratixii_asm_block, stratixii_dll,<br/>stratixii_termination, stratixii_asmiblock</p>                                                                                                                                                                                                                                                             |
|             | <p>Stratix GX:</p> <p>stratixgx_crcblock, stratixgx_jtag, stratixgx_lvds_receiver,<br/>stratixgx_lvds_transmitter, stratixgx_pll, stratixgx_rublock,<br/>stratixgx_ram_block, stratixgx_dll</p>                                                                                                                                                                                                                                                                                                                                  |
|             | <p>Stratix II GX:</p> <p>stratixiigx_hssi_receiver, stratixiigx_hssi_transmitter,<br/>stratixiigx_hssi_central_management_unit,<br/>stratixiigx_hssi_cmu_pll, stratixiigx_hssi_cmu_clock_divider,<br/>stratixiigx_hssi_refclk_divider,<br/>stratixiigx_hssi_calibration_block, stratixiigx_crcblock,<br/>stratixiigx_ram_block, stratixiigx_lvds_transmitter,<br/>stratixiigx_lvds_receiver, stratixiigx_pll, stratixiigx_dll,<br/>stratixiigx_jtag, stratixiigx_asmiblock, stratixiigx_termination,<br/>stratixiigx_rublock</p> |
|             | <p>Cyclone II:</p> <p>cycloneii_asmiblock, cycloneii_clk_delay_ctrl, cycloneii_clkctrl,<br/>cycloneii_jtag, cycloneii_pll, cycloneii_ram_block</p>                                                                                                                                                                                                                                                                                                                                                                               |
|             | <p>Aria GX:</p> <p>arriagx_asmiblock, arriagx_crcblock, arriagx_dll,<br/>arriagx_hssi_calibration_block,<br/>arriagx_hssi_central_management_unit,<br/>arriagx_hssi_cmu_clock_divider, arriagx_hssi_cmu_pll,<br/>arriagx_hssi_receiver, arriagx_hssi_refclk_divider,<br/>arriagx_hssi_transmitter, arriagx_jtag, arriagx_lvds_receiver,<br/>arriagx_lvds_transmitter, arriagx_pll, arriagx_ram_block,<br/>arriagx_rublock, arriagx_termination</p>                                                                               |
|             | <p>HardCopy II:</p> <p>hardcopyii_crcblock, hardcopyii_dll, hardcopyii_jtag,<br/>hardcopyii_lvds_receiver, hardcopyii_lvds_transmitter,<br/>hardcopyii_pll, hardcopyii_ram_block, hardcopyii_termination</p>                                                                                                                                                                                                                                                                                                                     |

**Table 18–5. Supported Black Box Models (Part 3 of 3)**

| Entity Type | Entity Names                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Atoms (1)   | <p>Stratix III:<br/> stratixiii_asmiblock, stratixiii_crcblock, stratixiii_jtag,<br/> stratixiii_lvds_receiver, stratixiii_lvds_transmitter,<br/> stratixiii_mlab_cell,<br/> stratixiii_pll, stratixiii_ram_block, stratixiii_rublock,<br/> stratixiii_termination, stratixiii_tsdblock</p> <p>Cyclone III:<br/> cycloneiii_apfcontroller, cycloneiii_clkctrl,<br/> cycloneiii_crcblock, cycloneiii_ddio_oe, cycloneiii_ddio_out,<br/> cycloneiii_ff, cycloneiii_io_ibuf, cycloneiii_io_obuf,<br/> cycloneiii_io_pad, cycloneiii_jtag, cycloneiii_lcell_comb,<br/> cycloneiii_mac_mult, cycloneiii_mac_out, cycloneiii_oscillator,<br/> cycloneiii_pll, cycloneiii_pseudo_diff_out, cycloneiii_ram_block,<br/> cycloneiii_rublock, cycloneiii_termination</p> |

**Note to Table 18–5:**

- (1) The entity names are given for the specific device family listed.

## Conformal Dofile/Script Example

The following example script (18-7), generated by the Quartus II software, lists some of the setup commands used in Conformal LEC software:

### Example 18-7. Conformal LEC Script

```

// Copyright (C) 1991-2007 Altera Corporation
// Your use of Altera Corporation's design tools, logic functions
// and other software and tools, and its AMPP partner logi
// functions, and any output files from any of the foregoing
// (including device programming or simulation files), and any
// associated documentation or information are expressly subject
// to the terms and conditions of the Altera Program License
// Subscription Agreement, Altera MegaCore Function License
// Agreement, or other applicable license agreement, including,
// without limitation, that your use is for the sole purpose of
// programming logic devices manufactured by Altera and sold by
// Altera or its authorized distributors. Please refer to the
// applicable agreement for further details.

// Script generated by Quartus II

reset
set system mode setup
set log file mfs_3prm_1a.fv.log -replace
set naming rule "%s" -register -golden
set naming rule "%s" -register -revised
// Naming rules for Verilog
set naming rule "%L.%s" "%L[%d].%s" "%s" -instance
set naming rule "%L.%s" "%L[%d].%s" "%s" -variable
// Naming rules for VHDL
// set naming rule "%L:%s" "%L:%d:%s" "%s" -instance
// set naming rule "%L:%s" "%L:%d:%s" "%s" -variable
// set undefined cell black_box -both
// These are the directives that are not supported by the QIS RTL to gates FV flow
set directive off verplex ambit
set directive off assertion_library black_box clock_hold compile_off compile_on
set directive off dc_script_begin dc_script_end divider enum infer_latch
set directive off mem_rowselect multi_port multiplier operand state_vector template
add notranslate module alt3pram -golden
add notranslate module alt3pram -revised
setenv QUARTUS /data/quark/build/ajaishan/quartus
setenv PROJECT
/net/quark/build/ajaishan/quartus_regtest/eda/fv/conformal/synplify/stratix/mfs_3prm_1a_v1
/_mfs_3prm_1a/qu_allopt
read design \
    $QUARTUS/eda/fv_lib/vhdl/dummy.vhd \
    -map lpm $QUARTUS/eda/fv_lib/vhdl/lpm \
    -map altera_mf $QUARTUS/eda/fv_lib/vhdl/mfs \
    -map stratix $QUARTUS/eda/fv_lib/vhdl/stratix \
    -vhdl -noelaborate -golden
read design \
    -file $PROJECT/fv/conformal/mfs_3prm_1a.clg \
    $PROJECT/p3rm_block.v \
    $PROJECT/mfs_3prm_1a.v \
    -verilog2k -merge none -golden
read design \
    $QUARTUS/eda/fv_lib/vhdl/dummy.vhd \

```

```

-map lpm $QUARTUS/eda/fv_lib/vhdl/lpms \
-map altera_mf $QUARTUS/eda/fv_lib/vhdl/mfs \
-map stratix $QUARTUS/eda/fv_lib/vhdl/stratix \
-vhdl -noelaborate -revised
read design \
  -file $PROJECT/fv/conformal/mfs_3prm_1a.clr \
  $PROJECT/fv/conformal/mfs_3prm_1a.vo \
  -verilog2k -merge none -revised
// add ignored inputs _unassoc_inputs_* -all -revised
add renaming rule r1 "~I\/" "\/" -revised
add renaming rule r2 "_I\/" "\/" -revised
set multiplier implementation rca -golden
set multiplier implementation rca -revised
set mapping method -name first
set mapping method -nounreach
set mapping method -noreport_unreach
set mapping method -nobbox_name_match
set flatten model -seq_constant
set flatten model -nodff_to_dlat_zero
set flatten model -nodff_to_dlat_feedback
set flatten model -nooutput_z
set root module mfs_3prm_1a -golden
set root module mfs_3prm_1a -revised
report messages
report black box
report design data
// report floating signals
dofile $PROJECT/fv/conformal/mfs_3prm_1a.cec
// dofile $PROJECT/fv/conformal/mfs_3prm_1a.cep
// Instance-constraints commands for constant-value registers removed
// during compilation
set system mode lec -nomap
read mapped points $PROJECT/fv/conformal/mfs_3prm_1a.cmc
// Trivial mappings with same name registers
// read mapped points $PROJECT/fv/conformal/mfs_3prm_1a_trivial.cmc
// dofile $PROJECT/fv/conformal/mfs_3prm_1a.cmp
map key points
remodel -seq_constant -repeat
add compare points -all
compare
usage
// exit -f

```

## Conclusion

Formal verification software enables verification of the design during all stages from RTL to placement and routing. Verifying designs takes more time as designs increase in size. Formal verification is a technique that helps reduce the time needed for your design verification cycle.

## Referenced Documents

This chapter references the following documents:

- *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook*
- *Netlist Optimizations and Physical Synthesis* chapter in volume 2 of the *Quartus II Handbook*

## Document Revision History

Table 18–6 shows the revision history for this chapter.

| <b>Table 18–6. Document Revision History</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                              |
|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|
| <b>Date and Version</b>                      | <b>Changes Made</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <b>Summary of Changes</b>                    |
| May 2008<br>v8.0.0                           | <ul style="list-style-type: none"> <li>Added support for Cyclone III devices.</li> <li>Updated “Black Boxes in the Encounter Conformal Flow” on page 18–10.</li> <li>Updated Table 18–1 and Table 18–5.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Updated for Quartus II software version 8.0. |
| October 2007<br>v7.2.0                       | <ul style="list-style-type: none"> <li>Updated Introduction section on page 17–1.</li> <li>Updated Known Issues and Limitations section on page 17–24.</li> <li>Updated Table 17–1, 17–5.</li> <li>Updated Figure 17–10.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Updated for Quartus II software version 7.2. |
| May 2007<br>v7.1.0                           | <ul style="list-style-type: none"> <li>Updated Formal Verification Design Flow section on page 17–2.</li> <li>Updated Generating the Post-Fit Netlist Output File and Encounter Conformal Setup Files section on page 17–10.</li> <li>Updated Understanding the Formal Verification Scripts for Encounter Conformal section title on page 17–18.</li> <li>Updated Known Issues and Limitations on page 17–24.</li> <li>Renamed Tcl Sample Script to Conformal Dofile/Script Example and updated section on page 17–29.</li> <li>Added Referenced Documents on page 17–31.</li> <li>Removed Debugging Tips section.</li> <li>Updated Figure 17–3, 17–5.</li> <li>Updated Table 17–1, 17–4, 17–5.</li> </ul> | Updated for Quartus II software version 7.1. |
| March 2007<br>v7.0.0                         | Updated Quartus II software 7.0 revision and date only.<br>No other changes made to chapter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | —                                            |
| November 2006<br>v6.1.0                      | Changed date only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Updated for Quartus II software version 6.1  |
| May 2006<br>v6.0.0                           | Minor updates for the Quartus II software version 6.0.0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | —                                            |
| October 2005<br>v5.1.0                       | <ul style="list-style-type: none"> <li>Updated for the Quartus II software version 5.1.</li> <li>Chapter 15 was previously Chapter 13 in version 5.0.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | —                                            |
| May 2005<br>v5.0.0                           | New functionality for Quartus II software 5.0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | —                                            |
| January 2005<br>v1.0                         | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | —                                            |

The Quartus® II software offers a complete software solution for system designers who design with Altera® FPGA and CPLD devices. The Quartus II Programmer is part of the Quartus II software package that allows you to program Altera CPLD and configuration devices, and configure Altera FPGA devices. This section describes how you can use the Quartus II Programmer to program or configure your device after you successfully compile your design.

This section includes the following chapter:

- [Chapter 19, Quartus II Programmer](#)

 For information about the revision history for chapters in this section, refer to each individual chapter for that chapter's revision history.



## Introduction

The Quartus® II software offers a complete software solution for system designers who design with Altera® FPGA and CPLD devices. The Quartus II Programmer is part of the Quartus II software package that allows you to program Altera CPLD and configuration devices, and configure Altera FPGA devices. After your design successfully compiles, you can use the Quartus II Programmer to program or configure your device.

This chapter contains the following sections:

- “Programming Flow”
- “Programming and Configuration Modes” on page 19–4
- “Programmer Overview” on page 19–6
- “Hardware Setup” on page 19–12
- “Device Programming and Configuration” on page 19–14
- “Optional Programming Files” on page 19–18
- “Flash Loaders” on page 19–21
- “Other Programming Tools” on page 19–22
- “Scripting Support” on page 19–22

## Programming Flow

The programming flow begins with design compilation, in which the Quartus II Assembler generates the programming or configuration file, then proceeds with the programming or configuration file conversion for different configuration devices, or optional programming and configuration file creation. The flow ends with the configuration or programming of the FPGA, CPLD, or configuration devices with the programming or configuration file using the Quartus II Programmer.

Figure 19–1 shows the programming file generation flow. This flow covers the types of configuration and programming files that are used by the Quartus II Programmer. Refer to “[Optional Programming Files](#)” on [page 19–18](#) for information on other optional programming files.

**Figure 19–1. Programming File Generation Flow**

Table 19–1 shows the programming and configuration file formats supported by Altera FPGAs, CPLDs, configuration devices, enhanced configuration devices, and serial configuration devices.

**Table 19–1. Programming and Configuration File Format**

| File Format                   | FPGA | CPLD | Configuration Device and Enhanced Configuration Device | Serial Configuration Device |
|-------------------------------|------|------|--------------------------------------------------------|-----------------------------|
| SRAM Object File (.sof)       | ✓    | —    | —                                                      | —                           |
| Programmer Object File (.pof) | —    | ✓    | ✓                                                      | ✓                           |
| Jam File (.jam)               | ✓    | ✓    | ✓                                                      | —                           |
| Jam Byte-Code File (.jbc)     | ✓    | ✓    | ✓                                                      | —                           |

Figure 19–2 shows the programming flow using the Quartus II Programmer. Refer to “[Generating Optional Programming Files](#)” on [page 19–20](#) for detailed information about converting or creating different programming files. Refer to “[Device Programming and Configuration](#)” on [page 19–14](#) for information about programming or configuring the device.

**Figure 19–2. Programming Flow**



# Programming and Configuration Modes

The Quartus II Programmer supports the following four programming or configuration modes: JTAG, passive serial, active serial, and in-socket programming.

## JTAG Mode

You can use the Joint Test Action Group (JTAG) mode to configure FPGA devices and program CPLDs, configuration devices, or enhanced configuration devices. The JTAG mode allows multiple FPGAs, CPLDs, and configuration devices connected in a JTAG chain to be configured or programmed at the same time. JTAG programming or configuration uses four JTAG pins: TCK, TDI, TMS, and TDO. The JTAG interface also allows you to perform boundary-scan test using third-party boundary scan tools.

**.pof** files are used for programming CPLDs, and configuration or enhanced configuration devices, while **.sof** files are used for configuring FPGA devices. **.jam** and **.jbc** files can be used for both programming and configuration. Serial configuration devices do not support JTAG programming.



For more information about JTAG configuration or programming mode and JTAG pin connection, refer to the *Configuration Handbook*, or the device handbook or data sheet for the respective FPGA, CPLD, or configuration devices.

## Passive Serial Mode

You can use the passive serial (PS) mode to configure Altera FPGAs. PS configuration uses the DCLK, CONF\_DONE, nCONFIG, nSTATUS, and DATA0 configuration pins. Unlike the JTAG scheme, the PS configuration scheme can be used to configure the FPGA with a configuration device or enhanced configuration device, not necessarily through a download cable. If you are using the configuration device or enhanced configuration device to configure the FPGA through PS mode, you can route the configuration signals out to a header so that you can also configure the FPGA through the download cable with the Quartus II Programmer. Configuration through PS mode with a download cable is useful in the design stage. This configuration method allows you to configure your FPGA device directly from the Quartus II Programmer as you make changes to your design for debugging and testing.

PS mode supports configuration of an FPGA chain. **.sof** files are used for configuration through PS. Every FPGA device in the chain requires a **.sof** file, so the number of **.sof** files used depends on the number of FPGA devices in the chain.



For more information about PS configuration mode and PS pin connection, refer to the *Configuration Handbook* or the chapter on configuration in the appropriate FPGA device handbook.

## Active Serial Mode

You can use the active serial (AS) mode to program serial configuration devices. After programming completes, the serial configuration device then configures the FPGA. AS programming uses the DATA, DCLK, nCS, and ASDI pins. If the download cable is connected to the nCONFIG and nCE pins of the FPGA, the download cable disables the FPGA's access to the AS interface by holding the nCE pin high and the nCONFIG pin low. Upon completion of the programming, the nCE and nCONFIG pins are released and the FPGA configuration begins.



For more information about programming the serial configuration device, configuring the FPGA with the serial configuration device through AS mode, or the AS pin connection, refer to the *Serial Configuration Data Sheet* in the *Configuration Handbook* or the chapter on configuration in the appropriate FPGA device handbook.

## In-Socket Programming Mode

The in-socket programming mode is used for programming a single device. This programming mode supports programming the MAX<sup>®</sup> 7000 and MAX 3000 CPLD families, configuration devices, enhanced configuration devices, and serial configuration devices. Instead of using a download cable, in-socket programming mode uses the Altera Programming Unit (APU) hardware together with the programming adapter for the corresponding device to program the device. The programming unit with the programming adapter has a socket for the device and the hardware powers the device for programming. In-socket programming is normally used in the production environment to pre-program devices before they are mounted on the printed circuit boards on the assembly line.



Refer to [www.altera.com](http://www.altera.com) or the Quartus II Help for a list of programming adapters available for Altera devices.

Table 19–2 shows the programming and configuration modes supported by Altera devices.

| <b>Table 19–2. Programming and Configuration Modes</b> |             |             |                                                               |                                    |
|--------------------------------------------------------|-------------|-------------|---------------------------------------------------------------|------------------------------------|
| <b>Mode</b>                                            | <b>FPGA</b> | <b>CPLD</b> | <b>Configuration Device and Enhanced Configuration Device</b> | <b>Serial Configuration Device</b> |
| JTAG                                                   | ✓           | ✓           | ✓                                                             | —                                  |
| PS                                                     | ✓           | —           | —                                                             | —                                  |
| AS                                                     | —           | —           | —                                                             | ✓                                  |
| In-Socket Programming                                  | —           | ✓ (1)       | ✓                                                             | ✓                                  |

*Note to Table 19–2:*

(1) MAX II CPLDs do not support in-socket programming mode.

## Programmer Overview

The Quartus II Programmer graphical user interface (GUI) is a window in which you can add your programming and configuration files, specify the programming options and hardware, and then proceed with the programming or configuration of the device.

To open the **Programmer** window, on the Tools menu, click **Programmer**. Figure 19–3 shows the programmer GUI. The status of each operation, whether programming is successful or not, is reported in the Quartus II message window. Figure 19–4 shows a typical programming message after the programmer has successfully programmed a device.

Figure 19–3. The Programmer Window



Figure 19–4. Status Report in the Message Window

| Type | Message                                                        |
|------|----------------------------------------------------------------|
| i    | Info: Successfully performed operation(s)                      |
| i    | Info: Ended Programmer operation at Mon Feb 26 09:39:27 2007   |
| i    | Info: Started Programmer operation at Mon Feb 26 09:39:51 2007 |
| i    | Info: Device 1 contains JTAG ID code 0x020A30DD                |
| i    | Info: Device 1 silicon ID is ALTERA04-1                        |
| i    | Info: Examining devices                                        |
| i    | Info: Successfully performed operation(s)                      |
| i    | Info: Ended Programmer operation at Mon Feb 26 09:39:53 2007   |

Table 19–3 describes the items available in the programmer window.

| <b>Table 19–3. Programmer Window Items (Part 1 of 3)</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Items</b>                                             | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>Hardware Setup</b>                                    | Opens the <b>Hardware Setup</b> dialog box in the programmer and enables you to perform the following: <ul style="list-style-type: none"> <li>• add and remove hardware items from the <b>Hardware</b> list.</li> <li>• add and remove JTAG servers from the <b>JTAG Servers</b> list.</li> <li>• configure your local JTAG server.</li> <li>• specify a programming hardware or download cable for device programming and configuration.</li> </ul> |
| <b>Mode</b>                                              | Specifies the programming or configuration mode (either JTAG, In-Socket Programming, Passive Serial, or Active Serial Programming).                                                                                                                                                                                                                                                                                                                  |
| <b>Progress</b>                                          | Shows the progress of a specific operation.                                                                                                                                                                                                                                                                                                                                                                                                          |
| <b>Action Buttons</b>                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <b>Start</b>                                             | Starts the operations of the specified programming options.                                                                                                                                                                                                                                                                                                                                                                                          |
| <b>Stop</b>                                              | Stops all operations in progress.                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <b>Auto Detect</b>                                       | Scans the JTAG chain to check for devices in the chain and the chain connection.                                                                                                                                                                                                                                                                                                                                                                     |
| <b>Delete</b>                                            | Removes the selected programming or configuration files from the programmer.                                                                                                                                                                                                                                                                                                                                                                         |
| <b>Add File</b>                                          | Adds programming or configuration files to the programmer.                                                                                                                                                                                                                                                                                                                                                                                           |
| <b>Change File</b>                                       | Replaces the selected programming or configuration file with another file.                                                                                                                                                                                                                                                                                                                                                                           |
| <b>Save File</b>                                         | Allows you to save the data read out from CPLD or configuration devices using the “examine” process into a <b>.pof</b> file.                                                                                                                                                                                                                                                                                                                         |
| <b>Add Device</b>                                        | Adds a device into the JTAG device chain in the programmer. If no programming or configuration file is specified, the programmer will bypass this device during programming or configuration. You can also add your user-defined device into the chain.                                                                                                                                                                                              |
| <b>Up</b>                                                | Moves the selection up to another programming or configuration file or device in the programmer window.                                                                                                                                                                                                                                                                                                                                              |
| <b>Down</b>                                              | Moves the selection down to another programming or configuration file or device in the programmer window.                                                                                                                                                                                                                                                                                                                                            |
| <b>File or Device Chain Information</b>                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <b>File</b>                                              | Displays the programming or configuration file name.                                                                                                                                                                                                                                                                                                                                                                                                 |
| <b>Device</b>                                            | The <b>Device</b> column shows: <ul style="list-style-type: none"> <li>• the target device of the file, if you add a programming or configuration file into the programmer.</li> <li>• the devices in the JTAG chain detected by the programmer, if you click <b>Auto Detect</b> in JTAG mode.</li> <li>• the device added to the programmer, if you manually add a device into the programmer.</li> </ul>                                           |

**Table 19–3. Programmer Window Items (Part 2 of 3)**

| Items                                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Checksum</b>                                             | <p>The <b>Checksum</b> column shows:</p> <ul style="list-style-type: none"> <li>the checksum of the file, if you add a programming or configuration file into the programmer.</li> <li>the checksum for the data read out, if you examine a device.</li> </ul> <p>The checksum is calculated by the Quartus II software. The programmer does not display the checksum for the <b>.jam</b> or <b>.jbc</b> files generated for a multi-device JTAG chain.</p>                                                                                                   |
| <b>Usercode</b>                                             | <p>The <b>Usercode</b> column shows:</p> <ul style="list-style-type: none"> <li>the usercode of the file, if you add a programming or configuration file into the programmer.</li> <li>the usercode read out from the device, if you examine a device.</li> </ul> <p>You can specify the usercode before design compilation, or use the Auto usercode feature that uses the checksum as the usercode. The programmer does not show the usercode information in PS configuration mode or for the Jam or JBC files generated for a multi-device JTAG chain.</p> |
| <b>Programming Options</b>                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <b>Enable real-time ISP to allow background programming</b> | <p>Can only be turned on if you are targeting a MAX II device, and is turned off for all other device families. When this option is turned on, you can do the real-time in-system programming (ISP) for the MAX II device. The existing design in the MAX II device functions normally during and after the real-time ISP is completed. The new design starts to function after a power cycle to the device occurs.</p>                                                                                                                                       |
| <b>Program or Configure</b>                                 | <p>Can be used for programming CPLDs, configuration devices, or configuring FPGA devices.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <b>Verify</b>                                               | <p>Verifies the content of the CPLD and all configuration devices against the respective programming files. This option is not available for FPGAs.</p> <p>Verification fails if the data in the file is different from the data in the device. Stand-alone verification for the CPLD with the programming file used for the programming will fail if the security bit is set when the device is programmed initially.</p>                                                                                                                                    |
| <b>Blank-Check</b>                                          | <p>Checks whether the CPLD or configuration device is blank or not.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>Examine</b>                                              | <p>Reads back the contents of the CPLD or configuration device. You can then save the examined data as a <b>.pof</b> file. Examining a CPLD with the security bit set does not produce a usable <b>.pof</b> file. This option is not available for MAX 7000S devices.</p>                                                                                                                                                                                                                                                                                     |
| <b>Security Bits</b>                                        | <p>Protects the design in the CPLD from being examined. If the security bit is set when the CPLD is programmed, you cannot read the correct data out using the examine process. Security bits cannot be set for the configuration devices or FPGAs.</p>                                                                                                                                                                                                                                                                                                       |
| <b>Erase</b>                                                | <p>Erases the contents of the CPLD and all configuration devices. You can also erase the user flash memory (UFM) of the MAX II CPLD. This option is not available for MAX 7000S devices.</p>                                                                                                                                                                                                                                                                                                                                                                  |

| <b>Table 19–3. Programmer Window Items (Part 3 of 3)</b> |                                                                                                                                                                                                                                                                                                         |
|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Items                                                    | Description                                                                                                                                                                                                                                                                                             |
| <b>ISP CLAMP</b>                                         | Allows the MAX II or MAX 7000B CPLD's I/O pins to be clamped to certain states during normal programming. ISP CLAMP can only be turned on if certain pins of the device have the ISP Clamp State assignment enabled, or you have added an I/O Pin State (.ips) file in the programmer.                  |
| <b>IPS File</b>                                          | Shows the IPS file used for ISP Clamp of the MAX II or MAX 7000B CPLDs. The <b>IPS File</b> column only appears if your programmer window has a MAX II or MAX 7000B .pof file. To add in the .ips file, click once on the row of the programming file and on the Edit menu, click <b>Add IPS File</b> . |

Table 19–4 shows the programming and configuration options supported by Altera devices.

| <b>Table 19–4. Programming and Configuration Options</b> |      |      |                                                        |                             |
|----------------------------------------------------------|------|------|--------------------------------------------------------|-----------------------------|
| Option                                                   | FPGA | CPLD | Configuration Device and Enhanced Configuration Device | Serial Configuration Device |
| Program or Configure                                     | ✓    | ✓    | ✓                                                      | ✓                           |
| Verify                                                   | —    | ✓    | ✓                                                      | ✓                           |
| Blank-Check                                              | —    | ✓    | ✓                                                      | ✓                           |
| Examine                                                  | —    | ✓    | ✓                                                      | ✓                           |
| Security Bit                                             | —    | ✓    | —                                                      | —                           |
| Erase                                                    | —    | ✓    | ✓                                                      | ✓                           |
| ISP Clamp                                                | —    | ✓(1) | —                                                      | —                           |
| IPS File (2)                                             | —    | ✓    | —                                                      | —                           |
| Real-time ISP                                            | —    | ✓(3) | —                                                      | —                           |

*Notes to Table 19–4:*

(1) Only MAX II and MAX 7000B CPLDs support the ISP Clamp feature.

(2) IPS file is used for ISP Clamp.

(3) Only MAX II CPLDs support the real-time ISP feature.

## Tools Menu

More programmer options are available from the Tools menu. On the Tools menu, click **Options** and then click **Programmer**. For descriptions of these options, refer to [Table 19–5](#).

**Table 19–5. Programmer Options**

| Option                                                                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Show checksum without usercode</b>                                            | Determines whether the checksum values displayed in the programmer are calculated with or without JTAG usercodes. This option allows you to have multiple versions of a programming or configuration file with different user codes, but share the same checksum.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| <b>Initiate configuration after programming</b>                                  | Specifies that configuration devices configure attached FPGA devices automatically after the programmer completes programming the configuration devices.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>Display message when programming finishes</b>                                 | Displays a message when programming or other operation such as examining or blank-checking is complete.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>Enable real-time ISP to allow background programming (for MAX II devices)</b> | Can only be turned on if you are targeting a MAX II device. This option is turned off for all other device families. When this option is turned on, you can do the real-time in-system programming (ISP) for the MAX II device. The existing design in the MAX II device functions normally during and after the real-time ISP is completed. The new design starts to function after a power cycle to the device occurs. This option is also available in the programmer window.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <b>Halt on-chip configuration controller</b>                                     | <p>Halts the on-chip auto-configuration controller of the FPGA device for AS configuration, or the configuration device for PS or Fast Passive Parallel (FPP) configuration to allow JTAG configuration through a download cable. If you want to configure your FPGA through JTAG while the FPGA MSEL pins are set to AS mode, you should halt the on-chip configuration controller if any of the following occurs:</p> <ul style="list-style-type: none"> <li>● the active serial configuration device connected to your FPGA is blank</li> <li>● the active serial configuration device is not present</li> <li>● an error occurs during AS configuration prior to JTAG configuration</li> </ul> <p>If the MSEL pins are set to PS or FPP mode, halt the configuration controller of the configuration device if an error occurs during PS or FPP configuration prior to JTAG configuration. The FPGA pulls the nSTATUS pin (which is connected to the OE pin of the configuration device) low to disable the configuration device.</p> |
| <b>Automatically check the Program/Configure checkbox when adding SOF</b>        | Automatically enables the program or configuration operation when adding an .sof file to the file list in the programmer window.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

## Hardware Setup

The Quartus II Programmer provides the flexibility to choose the download cable or programming hardware. Before you can program or configure your device, you must have the correct hardware setup.

### Hardware Settings

Click **Hardware Setup** to bring up the **Hardware Setup** dialog box. On the **Hardware Settings** tab (Figure 19–5), you can select a download cable or programming hardware available from the **Currently selected hardware** list. If the download cable or programming hardware you require is not displayed, click **Add Hardware** and specify the download cable or programming hardware. Make sure that you have installed the download cable driver before adding the hardware.



You do not need to manually add the USB-Blaster™ download cable to the list. After installing the driver, simply connect the download cable to the PC before opening the **Hardware Setup** dialog box. The USB-Blaster appears automatically in the list when the dialog box is opened.

**Figure 19–5. Hardware Settings**



More information about programming hardware driver installation is available in the Design Software section under **Support** on the Altera website ([www.altera.com/support](http://www.altera.com/support)).

## JTAG Settings

The JTAG server allows programs such as the Quartus II Programmer to access the JTAG hardware. This application software is installed together with the Quartus II software. You can also access the JTAG download cable or programming hardware connected to a remote computer through the JTAG server of that computer. With the JTAG server, you can control the programming or configuration of devices from a single computer through other computers at remote locations. The JTAG server uses the TCP/IP communications protocol.

Click **Hardware Setup** to bring up the **Hardware Setup** dialog box. On the **JTAG Settings** tab (Figure 19–6), you can add or remove JTAG servers from the list. By default, you have only the local JTAG server (which is on your computer) in the list. By adding a remote JTAG server, you can access the JTAG hardware in that remote computer from your computer. You need the password of the remote JTAG server to add the server to your list. Click **Add Server**, then enter the IP address of that computer in the **Server name** field and the password in the **Server password** field.

**Figure 19–6. JTAG Settings**



You can also allow remote clients to access the JTAG server on your computer and program or configure devices connected to your computer through the JTAG interface of your computer. Click **Configure Local JTAG Server** to enable the server and then enter the password that the remote clients require to access your JTAG server.

# Device Programming and Configuration

The Quartus II Programmer supports single- or multi-device programming and configuration. This section describes the steps required to program or configure Altera devices, as well as how to bypass Altera and non-Altera devices in a JTAG chain.

## Single Device Programming and Configuration

To program or configure a single device with the Quartus II Programmer, perform the following steps:

1. On the Tools menu, click **Programmer** to open the **Programmer** window.
2. Click **Hardware Setup** and select the programming hardware or download cable. If you are using JTAG mode, you can specify the correct JTAG settings for programming or configuration involving remote JTAG servers. Click **Close**.
3. From the **Mode** list, select the programming or configuration mode.
4. Click **Add File** to add the **.pof** or **.sof** file to the programmer (you can omit this step if the file is already displayed). To change the file, select it and click **Change File**. To remove the file from the programmer, select it and click **Delete**.



If you are using JTAG, AS, or in-socket programming mode, after the file has been added to the programmer, select the programming or configuration option by turning on the corresponding check box in the programmer.

5. Click **Start**.

## Multi-Device Programming and Configuration

JTAG and PS modes allow you to program or configure a device chain. A JTAG chain can consist of a combination of FPGA, CPLD, and configuration devices that support JTAG mode. A PS chain consists of FPGAs that support PS mode. The steps for programming or configuring a device chain is similar to the steps for programming or configuring a single device. One exception is that in a device chain you must specify all the programming or configuration files for the devices you want to program or configure. JTAG mode allows you to bypass some of the devices in the JTAG chain while programming or configuring the rest of the devices. PS mode does not allow you to bypass devices in the FPGA chain.

### *Bypassing an Altera Device*

If you have the programming or configuration file for the Altera device you want to bypass, in the programmer, turn off all the options in the row for that device before you program or configure other devices. If you do not have the programming or configuration file for that device, click **Add Device** to specify the device.

### *Bypassing a Non-Altera Device*

The JTAG chain of the device you want to program or configure may contain non-Altera devices. To program or configure your Altera device in the JTAG chain, you must bypass those non-Altera devices. The non-Altera devices are not in the list of devices that you can select when you click **Add Device** in the programmer.

To bypass the devices, you must manually define these devices. Click **Add Device** to open the **Select Device** dialog box. Click **New** to define a device. In the **New Device** dialog box (Figure 19–7), enter the name of the device and the JTAG instruction register length of the device. You can find the JTAG instruction register length in the device's data sheet. You can also specify the JTAG ID code for the device by clicking **Add JTAG ID**. This is optional and you can turn on **Allow none** to set the ID code to all 0s. If you do not specify the JTAG ID code, the default value is all 0s.

**Figure 19–7. New Device Dialog Box**



After defining the device, the device appears in the device list (Figure 19–8). Click **Export** to save the information in a Quartus User-Defined Device (.qud) file. This file saves the information for the user-defined devices that appear under **Device name** in the dialog box and can be used by other Quartus II projects as well. To obtain information on the user-defined devices from the .qud file, click **Import** and the devices are listed under **Device name**.

**Figure 19–8. Select Devices**



Figure 19–9 shows the programmer window for a JTAG chain.

**Figure 19–9. Multi-Device JTAG Chain**



### Chain Description File

All the information in the Quartus II Programmer, including the programming or configuration mode, programming or configuration files used, device chain information, and the programming options specified can be saved in a chain description file (.cdf). You do not have to specify the information each time you program the device chain. Simply open the CDF in the Quartus II software and information appears in the Quartus II Programmer GUI.

### Design Security Key Programming

The Quartus II Programmer supports the generation of encryption key programming files and encrypted configuration files for Altera FPGAs that support the design security feature. You can also use the Quartus II Programmer to program the encryption key into the FPGA.



Refer to [AN 341: Using the Design Security Feature in Stratix II and Stratix II GX Devices](#) for more information about using the design security feature with the Quartus II software.

## Optional Programming Files

The Quartus II software is able to generate optional programming or configuration files in various formats to be used with programming tools other than the Quartus II Programmer. In addition, you can convert the FPGA configuration files to programming files for configuration devices.

### Types of Programming and Configuration Files

The Quartus II software generates programming files of various formats for use with different programming tools. [Table 19–6](#) shows the programming and configuration files generated by the Quartus II software.

**Table 19–6. Types of Programming and Configuration Files (Part 1 of 2)**

| File Format | Generated by the Quartus II Software | Supported by the Quartus II Programmer | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------|--------------------------------------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| .sof        | ✓                                    | ✓                                      | This configuration data file is used for configuring FPGA devices. The Quartus II Assembler generates this file when you compile your FPGA design.                                                                                                                                                                                                                                                                                                                                                                                                          |
| .pof        | ✓                                    | ✓                                      | This programming data file is used for programming CPLDs and configuration devices. The Quartus II Assembler generates the CPLD POF file when you compile your CPLD design. The configuration device POF file is converted from the FPGA SOF file.                                                                                                                                                                                                                                                                                                          |
| .jam        | ✓                                    | ✓                                      | This ASCII-format file is used for configuring or programming one or more FPGAs, CPLDs, and configuration devices in a JTAG chain. The Jam file includes both programming algorithm and data. Apart from the Quartus II Programmer, you can use Altera's Jam Standard Test and Programming Language (STAPL) player, the <code>quartus_jli</code> executable, or other third-party programming tools together with the Jam file. The Jam file is also suitable for embedded processor-type programming environments.                                         |
| .jbc        | ✓                                    | ✓                                      | Similar to the Jam file, this binary-format file is used for configuring or programming one or more FPGAs, CPLDs, and configuration devices in a JTAG chain. The JBC file includes both the programming algorithm and data, and the size is smaller than the Jam file. In addition to the Quartus II Programmer, you can use Altera's Jam Byte-Code player, the <code>quartus_jli</code> executable, or other third-party programming tools together with the JBC file. The JBC file is also suitable for embedded processor-type programming environments. |

**Table 19–6. Types of Programming and Configuration Files (Part 2 of 2)**

| File Format                                    | Generated by the Quartus II Software | Supported by the Quartus II Programmer | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------------------------------------|--------------------------------------|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Serial Vector Format File (.svf)               | ✓                                    | —                                      | This ASCII-format file is used for configuring, programming, blank-checking, and verifying one or more FPGAs, CPLDs, and configuration devices in a JTAG chain. The .svf file, which includes programming algorithm and data, is suitable for an automated test equipment (ATE) environment that requires a fixed programming algorithm.                                                                                                                                                                                                                                                                                        |
| In-System Configuration File (.isc)            | ✓                                    | —                                      | This data file is used with the IEEE 1532 BSDL file for programming a single device that supports IEEE 1532 programming.<br>The Quartus II software supports generating the .isc file for MAX 7000AE, MAX 7000B, and MAX 3000A CPLDs.                                                                                                                                                                                                                                                                                                                                                                                           |
| Hexadecimal Intel-Format Output File (.hexout) | ✓                                    | —                                      | The .hexout file is used for programming FPGA configuration data into enhanced configuration devices or other storage devices. For enhanced configuration devices, use the enhanced configuration device .pof file to generate the .hexout file. Use the FPGA .sof file to generate the .hexout file for other storage devices (for example, the flash or EEPROM devices). You can use a microcontroller to read back the data from the storage device and configure the FPGA.<br>To program the enhanced configuration device or other storage devices with the .hexout file, you can use other third-party programming tools. |
| Raw Binary File (.rbf)                         | ✓                                    | —                                      | This binary file contains configuration data for one or more FPGAs. You can use Altera's JRunner software to configure your FPGA device with the .rbf file. The .rbf file is also suitable for embedded processor configuration environments.                                                                                                                                                                                                                                                                                                                                                                                   |
| Tabular Text File (.ttf)                       | ✓                                    | —                                      | This ASCII file contains configuration data for one or more FPGAs. The .ttf file is used for embedded processor-type configuration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Raw Programming Data (.rpd)                    | ✓                                    | —                                      | This binary file is used for programming serial configuration devices. Use the serial configuration device .pof file to generate this file. You can use Altera's SRunner software to program your serial configuration device with the .rpd file.                                                                                                                                                                                                                                                                                                                                                                               |
| JTAG Indirect Configuration File (.jic)        | ✓                                    | ✓                                      | The .jic file is used for programming serial configuration devices through JTAG with the Quartus II Programmer and Altera FPGAs that support AS configuration mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |



Refer to the Quartus II Help or the *Configuration File Formats* chapter of the *Configuration Handbook* for more information about the programming and configuration file formats.



Refer to [AN 425: Using Command-Line Jam STAPL Solution for Device Programming](#) for more information about using the **.jam** and **.jbc** programming files with the Jam STAPL Player, Jam STAPL Byte-Code Player, and the **quartus\_jli** command-line executable.

## Generating Optional Programming Files

When you compile your design, the Quartus II Assembler generates the **.sof** file for an FPGA or a **.pof** file for a CPLD. With the **.sof** or **.pof** file for your design, you can then create other optional programming or configuration files, or convert the **.sof** file to target a particular configuration device.

### Create Programming Files

The Quartus II software allows you to create optional **.jam**, **.jbc**, **.svf**, or **.isc** programming or configuration files. In addition, you can create **.jam**, **.jbc**, and **.svf** files for a JTAG chain that consists of more than one device.

To create the files, open the Quartus II Programmer, set the programming or configuration mode to JTAG, and then add the programming or configuration files or devices to the programmer. On the File menu, click **Create/Update** and then click **Create JAM, SVF, or ISC File**. Select the file format and name the file accordingly.

For SVF files, you can create an **.svf** file for programming or verification only. In addition, you can specify whether or not to do the optional blank-check operation with the **.svf** file.

### Convert Programming Files

To store the FPGA data into configuration devices, you can convert the SOF data to another format and program the configuration device. The Quartus II software supports converting the data into **.pof**, **.hexout**, **.rbf**, **.ttf**, **.rpd**, or **.jic** format.



For more information about converting programming files with the Quartus II software, refer to the *Configuration File Formats* chapter of the *Configuration Handbook*.

## *Generating Optional Programming or Configuration Files During Compilation*

The Quartus II software can generate optional programming or configuration files automatically when you compile your design. To select the format of the optional programming or configuration files to be generated during compilation, on the Assignments menu, click **Settings**. Under **Device**, click **Device and Pin Options**.

You can select the configuration device from the **Configuration** tab for the configuration device **.pof** file generation. For other optional programming and configuration file generation, you can select the file format under the **Programming Files** tab.

# Flash Loaders

Serial configuration devices and the common flash interface (CFI) flash devices do not support JTAG interface and cannot be programmed directly through the normal JTAG programming. Flash loaders allow the programming of the serial configuration device and the CFI flash from the Quartus II Programmer through JTAG.

## Parallel Flash Loader

The parallel flash loader (PFL) performs two functions:

- Allows the programming of the CFI flash through the JTAG interface
- Acts as the configuration controller that reads the configuration data from the CFI flash and configures the FPGA

To program the CFI flash, the PFL uses the MAX II device as a bridge between the JTAG interface of the Quartus II Programmer and the CFI of the CFI flash device. You can program FPGA configuration data and user data into the flash with a flash **.pof** file generated by the Quartus II software. After the flash is programmed with the FPGA configuration data, the PFL is then used to read the configuration data back from the CFI flash to configure the FPGA.



Refer to [AN 386: Using the MAX II Parallel Flash Loader with the Quartus II Software](#) for more information about PFL.

## Serial Flash Loader

The serial flash loader (SFL) allows programming of the serial configuration devices through JTAG. The SFL uses the FPGA device that supports AS configuration mode as a bridge between the active serial memory interface (ASMI) of the serial configuration device and the JTAG

interface of the programmer. The Quartus II Programmer uses the **.jic** file converted from the FPGA **.sof** file to program the serial configuration device through JTAG.



Refer to [AN 370: Using the Serial Flash Loader with the Quartus II Software](#) for more information about SFL.

## Other Programming Tools

This section covers other programming tools that are related to the Quartus II Programmer and can be used for programming or debugging programming problems.

### Quartus II Stand-Alone Programmer

If you do not have the full version of the Quartus II software, Altera offers the free Quartus II Stand-Alone Programmer. This stand-alone programmer has the full function of the normal Quartus II Programmer, and enables you to create or convert programming files from the **.sof** or **.pof** file of your design. You can download the Quartus II Stand-Alone Programmer from the **Download Center** page found through the **Support** page on the Altera website at [www.altera.com](http://www.altera.com).

### jtagconfig Debugging Tool

The **jtagconfig** command-line utility is included with the Quartus II software. You can use this utility (which is similar to the auto detect operation in the Quartus II Programmer) to check the devices in a JTAG chain and the user-defined devices.

For more information about the **jtagconfig** utility, type one of the following commands at the command prompt:

```
jtagconfig -h ↵
jtagconfig --help ↵
```

## Scripting Support

Apart from the Quartus II Programmer GUI, you can perform programming with the Quartus II command-line programmer (**quartus\_pgm**). This **quartus\_pgm** command-line programmer comes with the Quartus II Programmer. You can run this programmer separately from the Quartus II software. You can also run the procedures for the programmer in a Tcl script. The programmer accepts the **.pof**, **.sof**, and **.jic** programming or configuration files. You can also use the CDF.

For more information about the command-line syntax, type one of the following commands at the command prompt:

```
quartus_pgm -h ↵
quartus_pgm --help ↵
```

For more information about a specific programmer option or topic, type the following command at the command prompt:

```
quartus_pgm --help=<option|topic> ↵
```

The following is an example of a command that programs a device:

```
quartus_pgm -c byteblasterII -m jtag -o bpv;design.pof ↵
```

where:

- c byteblasterII specifies the ByteBlaster II download cable
- m jtag specifies the JTAG programming mode
- o bpv represents the blank-check, program, and verify operations
- design.pof represents the .pof file used for the programming

The programmer automatically executes the erase operation before programming the device.

For detailed information about scripting command options, you can also refer to the Quartus II Command-Line and Tcl API Help browser. To run the Help browser, type the following command at the command prompt:

```
quartus_sh --qhelp ↵
```

The *Quartus II Scripting Reference Manual* includes the same information in PDF format.



For more information about Tcl scripting, refer to the *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*. Refer to the *Quartus II Settings File Manual* for information on all settings and constraints in the Quartus II software. Refer to the *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook* for more information about command-line scripting.

## Conclusion

The Quartus II Programmer offers you a wide variety of options to program and configure your Altera devices. With the Quartus II Programmer, the Quartus II software provides you with a complete solution for your FPGA or CPLD design prototyping, which can even be performed in the production environment.

## Referenced Documents

This chapter references the following documents:

- *AN 341: Using the Design Security Feature in Stratix II and Stratix II GX Devices*
- *AN 370: Using the Serial FlashLoader with the Quartus II Software*
- *AN 386: Using the MAX II Parallel Flash Loader with the Quartus II Software*
- *AN 425: Using Command-Line Jam STAPL Solution for Device Programming*
- *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*
- *Configuration File Formats* chapter of the *Configuration Handbook*
- *Quartus II Scripting Reference Manual*
- *Quartus II Settings File Manual*
- *Serial Configuration Devices (EPCS1, EPCS4, EPCS16, and EPCS64) and EPCS128* Data Sheet of the *Configuration Handbook*
- *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*

## Document Revision History

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

| <b>Table 19–7. Document Revision History</b> |                                                                                                      |                           |
|----------------------------------------------|------------------------------------------------------------------------------------------------------|---------------------------|
| <b>Date and Document Version</b>             | <b>Changes Made</b>                                                                                  | <b>Summary of Changes</b> |
| May 2008<br>v8.0.0                           | Updated date and part number and added hypertext links. Also updated file format naming conventions. | —                         |
| October 2007,<br>v7.2.0                      | Reorganized “Referenced Documents” section.                                                          | —                         |
| May 2007<br>v7.1.0                           | Initial release                                                                                      | —                         |