

# Quartus II Version 6.0 Handbook Volume 1: Design & Synthesis



101 Innovation Drive San Jose, CA 95134 (408) 544-7000 http://www.altera.com

Copyright © 2006 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 in

formation and before placing orders for products or services.

I.S. EN ISO 900

# **Contents**



| Chapter Revision Dates                                                      | xiii        |
|-----------------------------------------------------------------------------|-------------|
| About this Handbook                                                         | xv          |
| How to Contact Altera                                                       | xv          |
| Third-Party Software Product Information                                    | xv          |
| Typographic Conventions                                                     |             |
| Section I. Design Flows                                                     |             |
| Revision History                                                            | Section I–1 |
| Chapter 1. Quartus II Incremental Compilation for Hierarchical & Team-Base  | ed Design   |
| Introduction                                                                |             |
| Quartus II Design Flow                                                      |             |
| Top-Down vs. Bottom-Up Design Flows                                         |             |
| Using Incremental Synthesis Only Instead of Full Incremental Compilation    |             |
| Design Partitions                                                           |             |
| Design Partitions Compared to Physical Regions                              |             |
| Preparing a Design for Incremental Compilation                              |             |
| Compiling a Design Using Incremental Compilation                            |             |
| What Represents a Source Change for Incremental Compilation?                |             |
| Creating Design Partitions                                                  |             |
| Creating Design Partitions in the GUI                                       |             |
| Methodology for Creating Good Partitions                                    |             |
| Guidelines for Creating Good Design Partitions                              |             |
| Partition Statistics Reports                                                |             |
| Resource Balancing                                                          |             |
| Timing Budgeting                                                            |             |
| Setting the Netlist Type for Design Partitions                              |             |
| Fitter Preservation Level                                                   |             |
| Empty Partitions                                                            |             |
| Creating a Design Floorplan With LogicLock Location Assignments             |             |
| Recommendations for Creating Good Floorplan Location Assignments            |             |
| The Importance of Floorplan Location Assignments in Incremental Compilation | 1–32        |
| Taking Advantage of the Early Timing Estimator                              | 1–34        |

Altera Corporation iii

| Criteria for Successful Partition & Floorplan Schemes                         | 1–34 |
|-------------------------------------------------------------------------------|------|
| Exporting & Importing Partitions for Bottom-Up Design Flows                   | 1–35 |
| Preparing the Top-Level Design for a Bottom-Up Incremental Compilation        |      |
| Methodology                                                                   | 1–35 |
| Exporting a Partition to be Used in a Top-Level Project                       | 1–36 |
| Importing a Lower-Level Partition Into the Top-Level Project                  | 1–38 |
| Importing Assignments & Advanced Import Settings                              | 1–39 |
| Generating Bottom-Up Design Partition Scripts for Project Management          |      |
| User Scenarios—Incremental Compilation Application Examples                   | 1–48 |
| Top-Down Incremental Design Flows                                             |      |
| Bottom-Up Design Flows                                                        |      |
| Incremental Compilation Restrictions                                          |      |
| Using Incremental Compilation with Quartus II Archive Files                   | 1–58 |
| OpenCore Plus MegaCore Functions                                              |      |
| Engineering Change Management With the Chip Editor                            |      |
| SignalProbe Feature                                                           |      |
| SignalTap II Logic Analyzer & Logic Analyzer Interface in Bottom-Up           |      |
| Compilation Flows                                                             | 1–60 |
| Restrictions on Megafunction Partitions                                       | 1–60 |
| Nodes Created & Changed During Routing                                        | 1–60 |
| Routing Preservation in Bottom-Up Compilation Flows                           | 1–61 |
| Bottom-Up Design Partition Script Limitations                                 | 1–61 |
| Register Packing & Partition Boundaries                                       | 1–63 |
| I/O Register Packing                                                          |      |
| Scripting Support                                                             | 1–75 |
| Generate Incremental Compilation Tcl Script Command                           | 1–75 |
| Preparing a Design for Incremental Compilation                                | 1–76 |
| Creating Design Partitions                                                    | 1–76 |
| Setting Properties of Design Partitions                                       | 1–77 |
| Recommendations for Creating Good Floorplan Location Assignments—Excluding of |      |
| Filtering Certain Device Elements (Such as RAM or DSP Blocks)                 | 1–78 |
| Generating Bottom-Up Design Partition Scripts                                 | 1–78 |
| Exporting a Partition to be Used in a Top-Level Project                       |      |
| Importing a Lower-Level Partition into the Top-Level Project                  | 1–81 |
| Make Files                                                                    |      |
| User Scenarios—Incremental Compilation Application Examples                   | 1–82 |
| Conclusion                                                                    | 1–84 |
|                                                                               |      |
| Chapter 2. Quartus II Design Flow for MAX+PLUS II Users                       |      |
| Introduction                                                                  | 2–1  |
| Chapter Overview                                                              | 2–1  |
| Typical Design Flow                                                           | 2–2  |
| Device Support                                                                | 2–3  |
| Quartus II GUI Overview                                                       | 2–4  |
| Project Navigator                                                             | 2–4  |
| Nada Findan                                                                   | 2.4  |

iv Altera Corporation

| Tcl Console                                              | 2–4  |
|----------------------------------------------------------|------|
| Messages                                                 |      |
| Status                                                   |      |
| Setting Up MAX+PLUS II Look & Feel in Quartus II         | 2–6  |
| MAX+PLUS II Look & Feel                                  |      |
| Compiler Tool                                            | 2–9  |
| Analysis & Synthesis                                     | 2–10 |
| Partition Merge                                          | 2–10 |
| Fitter                                                   | 2–10 |
| Assembler                                                | 2–11 |
| Timing Analyzer                                          | 2–11 |
| EDA Netlist Writer                                       | 2–11 |
| Design Assistant                                         | 2–11 |
| MAX+PLUS II Design Conversion                            |      |
| Converting an Existing MAX+PLUS II Design                | 2–12 |
| Converting MAX+PLUS II Graphic Design Files              | 2–13 |
| Importing MAX+PLUS II Assignments                        | 2–14 |
| Quartus II Design Flow                                   |      |
| Creating a New Project                                   | 2–16 |
| Design Entry                                             |      |
| Making Assignments                                       | 2–20 |
| Synthesis                                                |      |
| Functional Simulation                                    |      |
| Place & Route                                            |      |
| Timing Analysis                                          |      |
| Timing Closure Floorplan                                 | 2–29 |
| Timing Simulation                                        |      |
| Power Estimation                                         |      |
| Programming                                              |      |
| Conclusion                                               |      |
| Quick Menu Reference                                     |      |
| Quartus II Command Reference for MAX+PLUS II Users       | 2–36 |
|                                                          |      |
| Chapter 3. Quartus II Support of HardCopy Series Devices |      |
| Introduction                                             | 3–1  |
| HardCopy II Device Support                               | 3–1  |
| HardCopy II Design Benefits                              | 3–1  |
| Quartus II Features for HardCopy II Planning             |      |
| HardCopy II Development Flow                             | 3–3  |
| Designing the Stratix II FPGA First                      | 3–4  |
| Designing the HardCopy II Device First                   | 3–6  |
| HardCopy II Device Resource Guide                        |      |
| HardCopy II Companion Device Selection                   | 3–10 |
| Migration Compatibility Filtering                        | 3–11 |

| HardCopy II Recommended Settings in the Quartus II Software                | 3–13 |
|----------------------------------------------------------------------------|------|
| Limit DSP & RAM to HardCopy II Device Resources                            | 3–13 |
| Enable Design Assistant to Run During Compile                              | 3–14 |
| Timing Settings                                                            |      |
| Quartus II Software Version 6.0 Features Supported for HardCopy II Designs |      |
| Quartus II Features Not Presently Supported for HardCopy II Designs        |      |
| Chip Editor for HardCopy II Devices                                        | 3–20 |
| Formal Verification of Stratix II & HardCopy II Revisions                  |      |
| HardCopy II Utilities Menu                                                 |      |
| Companion Revisions                                                        |      |
| Compiling the HardCopy II Companion Revision                               |      |
| Comparing HardCopy II & Stratix II Companion Revisions                     | 3–25 |
| Generate HardCopy II Handoff Report                                        | 3–26 |
| Archive HardCopy II Handoff Files                                          | 3–26 |
| HardCopy II Advisor                                                        |      |
| HardCopy II Floorplan View                                                 | 3–29 |
| Conclusion                                                                 |      |
| HardCopy Stratix Device Support                                            |      |
| Features                                                                   | 3–33 |
| HARDCOPY_FPGA_PROTOTYPE, HardCopy Stratix & Stratix Devices                | 3–34 |
| HardCopy Design Flow                                                       | 3–36 |
| The Design Flow Steps of the One Step Process                              | 3–37 |
| How to Design HardCopy Stratix Devices                                     | 3–38 |
| Tcl Support for HardCopy Migration                                         |      |
| Design Optimization & Performance Estimation                               | 3–42 |
| Design Optimization                                                        | 3–42 |
| Performance Estimation                                                     |      |
| Buffer Insertion                                                           | 3–45 |
| Placement Constraints                                                      |      |
| Location Constraints                                                       | 3–46 |
| LAB Assignments                                                            |      |
| LogicLock Assignments                                                      | 3–47 |
| Checking Designs for HardCopy Design Guidelines                            | 3–48 |
| Altera-Recommended HDL Coding Guidelines                                   | 3–48 |
| Design Assistant                                                           |      |
| Reports & Summary                                                          |      |
| Generating the HardCopy Design Database                                    | 3–50 |
| Static Timing Analysis                                                     | 3–52 |
| Early Power Estimation                                                     | 3–52 |
| HardCopy Stratix Early Power Estimation                                    |      |
| HardCopy APEX Early Power Estimation                                       |      |
| Tcl Support for HardCopy Stratix                                           | 3–53 |
| Targeting Designs to HardCopy APEX Devices                                 | 3–54 |
| Conclusion                                                                 |      |
| Related Documents                                                          | 3-55 |

vi Altera Corporation

| Chapter 4. Engineering Change Management                                                                              |              |
|-----------------------------------------------------------------------------------------------------------------------|--------------|
| Introduction                                                                                                          | 4–1          |
| Impact of Last Minute Design Changes                                                                                  | 4–1          |
| Performance                                                                                                           | 4–1          |
| Compilation Time                                                                                                      |              |
| Verification                                                                                                          | 4–2          |
| Documentation                                                                                                         |              |
| ECO Support                                                                                                           |              |
| ECO Support at the HDL Level                                                                                          |              |
| ECO Support at the Netlist Level                                                                                      |              |
| Conclusion                                                                                                            | 4–6          |
| Section II. Design Guidelines                                                                                         |              |
| Revision History                                                                                                      | Section II–2 |
| Chapter 5. Design Recommendations for Altera Devices                                                                  |              |
| Introduction                                                                                                          |              |
| Synchronous FPGA Design Practices                                                                                     |              |
| Fundamentals of Synchronous Design                                                                                    |              |
| Hazards of Asynchronous Design                                                                                        |              |
| Design Guidelines                                                                                                     |              |
| Combinational Logic Structures                                                                                        |              |
| Clocking Schemes                                                                                                      |              |
| Hierarchical Design Partitioning                                                                                      |              |
| Targeting Clock & Register-Control Architectural Features                                                             |              |
| Clock Network Resources                                                                                               |              |
| Register Control Signals                                                                                              |              |
| Conclusion                                                                                                            |              |
| Conclusion                                                                                                            |              |
| Chapter 6. Recommended HDL Coding Styles                                                                              |              |
| Introduction                                                                                                          |              |
| Using Altera Megafunctions                                                                                            |              |
| Instantiating Altera Megafunctions in HDL Code                                                                        |              |
| Instantiating Megafunctions Using the MegaWizard Plug-In Manager                                                      |              |
| Instantiating Megafunctions Using the Port & Parameter Definition                                                     |              |
| Inferring Altera Megafunctions from HDL Code                                                                          |              |
| lpm_mult—Inferring Multipliers from HDL Codealtmult_accum & altmult_add—Inferring Multiply-Accumulators & Multiply-Ad |              |
| from HDL Code                                                                                                         |              |
| altsyncram & lpm_ram_dp—Inferring RAM Functions from HDL Code                                                         |              |
| lpm_rom—Inferring ROM from HDL Code                                                                                   |              |
| altshift_taps—Inferring Shift Registers from HDL Code                                                                 |              |
| 1 0                                                                                                                   |              |

Altera Corporation vii

| Device-Specific Coding Guidelines                                      | 6–29          |
|------------------------------------------------------------------------|---------------|
| Register Power-Up Values in Altera Devices                             | 6–29          |
| Secondary Register Control Signals Such as Clear & Clock Enable        | 6–32          |
| Tri-State Signals                                                      | 6–36          |
| Adder Trees                                                            | 6–37          |
| Coding Guidelines for Other Logic Structures                           | 6–40          |
| Latches                                                                | 6–40          |
| State Machines                                                         | 6–45          |
| Multiplexers                                                           | 6–52          |
| Cyclic Redundancy Check Functions                                      | 6–61          |
| Conclusion                                                             | 6–63          |
| Section III. Synthesis                                                 |               |
| Revision History                                                       | Section III-2 |
| icviolott History                                                      | occuon in 2   |
| Chapter 7. Quartus II Integrated Synthesis                             |               |
| Introduction                                                           |               |
| Design Flow                                                            |               |
| Language Support                                                       |               |
| Verilog HDL Support                                                    |               |
| VHDL Support                                                           |               |
| AHDL Support                                                           |               |
| Schematic Design Entry Support                                         |               |
| Incremental Synthesis                                                  |               |
| Partitions for Incremental Synthesis                                   |               |
| Partitions for Preserving Hierarchical Boundaries                      |               |
| Preparing a Design for Incremental Synthesis                           |               |
| Synthesizing a Design Using Incremental Synthesis                      |               |
| Forcing Complete Resynthesis                                           |               |
| Considerations & Restrictions When Using Incremental Synthesis         |               |
| Quartus II Synthesis Options                                           |               |
| Setting Synthesis Options                                              |               |
| Specifying Verilog & VHDL Versions for Each Design File                |               |
| Optimization Technique                                                 |               |
| Speed Optimization Technique for Clock Domains                         |               |
| PowerPlay Power Optimization                                           |               |
| State Machine Processing                                               |               |
| Manually Specifying State Assignments Using the syn_encoding Attribute |               |
| Manually Specifying Enumerated Types Using the enum_encoding Attribute |               |
| Preserve Hierarchical Boundary                                         |               |
| Restructure Multiplexers                                               |               |
| Power-Up Level                                                         |               |
| Power-Up Don't Care                                                    |               |
| Remove Duplicate Logic                                                 |               |
| Remove Duplicate Registers                                             |               |
| Remove Redundant Logic Cells                                           | /-35          |

viii Altera Corporation

| Preserve Registers                                               | 7–36 |
|------------------------------------------------------------------|------|
| Noprune Synthesis Attribute/Preserve Fanout Free Node            |      |
| Keep Combinational Node/Implement as Output of Logic Cell        |      |
| Maximum Fan-Out                                                  |      |
| Megafunction Inference Control                                   |      |
| RAM Style & ROM Style—for Inferred Memory                        |      |
| RAM Initialization File—for Inferred Memory                      |      |
| Multiplier Style—for Inferred Multipliers                        |      |
| Full Case                                                        |      |
| Parallel Case                                                    |      |
| Translate Off & On                                               |      |
| Ignore Translate Off                                             |      |
| Read Comments as HDL                                             |      |
| Setting Other Quartus II Options in Your HDL Source Code         |      |
| Use I/O Flip-Flops                                               |      |
| Altera Attribute                                                 |      |
| chip_pin                                                         |      |
| Analyzing Synthesis Results                                      | 7–59 |
| Messages                                                         |      |
| Analysis & Synthesis Section of Compilation Report               |      |
| Project Navigator                                                |      |
| VHDL & Verilog HDL Messages                                      |      |
| HDL Message Types                                                |      |
| Controlling the Display of HDL Messages                          |      |
| Node-Naming Conventions in Quartus II Integrated Synthesis       |      |
| Hierarchical Node-Naming Conventions                             |      |
| Node-Naming Conventions for Registers (DFF or D Flip-Flop Atoms) | 7–66 |
| Register Changes During Synthesis                                | 7–67 |
| Node-Naming Conventions for Combinational Logic Cells            | 7–69 |
| Scripting Support                                                | 7–70 |
| Quartus II Synthesis Options                                     | 7–71 |
| Assigning a Pin                                                  | 7–72 |
| Preparing a Design for Incremental Synthesis                     |      |
| Conclusion                                                       | 7–74 |
|                                                                  |      |
| Chapter 8. Synplicity Synplify & Synplify Pro Support            |      |
| Introduction                                                     |      |
| Design Flow                                                      |      |
| Output Netlist File Name & Result Format                         |      |
| Synplify Optimization Strategies                                 |      |
| Implementations in Synplify Pro                                  |      |
| Timing-Driven Synthesis Settings                                 |      |
| FSM Compiler                                                     |      |
| Optimization Attributes & Options                                |      |
| Altera-Specific Attributes                                       | 8–14 |

Altera Corporation ix

| Exporting Designs to the Quartus II Software Using NativeLink Integration         | 8–16 |
|-----------------------------------------------------------------------------------|------|
| Running the Quartus II Software from within the Synplify Software                 | 8-16 |
| Using the Quartus II Software to Launch the Synplify Software                     | 8–17 |
| Running the Quartus II Software Manually Using the Synplify-Generated Tcl Script  | 8–18 |
| Passing Constraints to the Quartus II Software                                    |      |
| Guidelines for Altera Megafunctions & Architecture-Specific Features              | 8–29 |
| Instantiating Altera Megafunctions Using the MegaWizard Plug-In Manager           | 8–30 |
| Inferring Altera Megafunctions from HDL Code                                      | 8–35 |
| Incremental Compilation & Block-Based Design                                      | 8-41 |
| Hierarchy & Design Considerations with Multiple VQM Files                         | 8–43 |
| Creating a Design with Separate Netlist Files                                     | 8-43 |
| Creating a Design with Multiple VQM Files Using Synplify Pro MultiPoint Synthesis |      |
| Generating a Design with Multiple VQM Files Using Black Boxes                     | 8–51 |
| Conclusion                                                                        |      |
|                                                                                   |      |
| Chapter 9. Mentor Graphics Precision RTL Synthesis Support                        |      |
| Introduction                                                                      | 9–1  |
| Design Flow                                                                       | 9–2  |
| Creating a Project & Compiling the Design                                         |      |
| Creating a Project                                                                |      |
| Compiling the Design                                                              |      |
| Setting Constraints                                                               |      |
| Setting Timing Constraints                                                        |      |
| Setting Mapping Constraints                                                       | 9–7  |
| Assigning Pin Numbers & I/O Settings                                              | 9–7  |
| Assigning I/O Registers                                                           |      |
| Disabling I/O Pad Insertion                                                       |      |
| Controlling Fan-Out on Data Nets                                                  | 9–10 |
| Synthesizing the Design & Evaluating the Results                                  |      |
| Obtaining Accurate Logic Utilization & Timing Analysis Reports                    |      |
| Exporting Designs to the Quartus II Software Using NativeLink Integration         | 9–12 |
| Running the Quartus II Software from within the Precision RTL Software            |      |
| Running the Quartus II Software Manually Using the Precision RTL                  |      |
| Synthesis-Generated Tcl Script                                                    | 9–14 |
| Using Quartus II Software to Launch the Precision RTL Synthesis Software          |      |
| Passing Constraints to the Quartus II Software                                    |      |
| Megafunctions & Architecture-Specific Features                                    |      |
| Instantiating Altera Megafunctions Using the MegaWizard Plug-In Manager           |      |
| Inferring Altera Megafunctions from HDL Code                                      |      |
| Incremental Compilation & Block-Based Design                                      |      |
| Hierarchy & Design Considerations                                                 |      |
| Creating a Design with Separate Netlist Files                                     |      |
| Creating Quartus II Projects for Multiple EDIF Files                              | 9–35 |
| Conclusion                                                                        |      |
|                                                                                   |      |

x Altera Corporation

| Chapter 10. Mentor Graphics LeonardoSpectrum Support                    |       |
|-------------------------------------------------------------------------|-------|
| Introduction                                                            | 10–1  |
| Design Flow                                                             |       |
| Optimization Strategies                                                 |       |
| Timing-Driven Synthesis                                                 |       |
| Other Constraints                                                       |       |
| Timing Analysis with the Leonardo-Spectrum Software                     | 10–8  |
| Exporting Designs Using NativeLink Integration                          | 10–9  |
| Generating Netlist Files                                                |       |
| Including Design Files for Black-Boxed Modules                          | 10–9  |
| Passing Constraints with Scripts                                        |       |
| Integration with the Quartus II Software                                |       |
| Guidelines for Altera Megafunctions & LPM Functions                     | 10–10 |
| Inferring Multipliers & DSP Functions                                   | 10–12 |
| Controlling DSP Block Inference                                         |       |
| Block-Based Design with the Quartus II Software                         | 10–19 |
| Hierarchy & Design Considerations                                       |       |
| Creating a Design with Multiple EDIF Files                              |       |
| Generating Multiple EDIF Files Using Black Boxes                        |       |
| Incremental Synthesis Flow                                              | 10–31 |
| Conclusion                                                              | 10–34 |
| Chapter 11. Synopsys Design Compiler FPGA Support  Introduction         |       |
| Design Flow Using the DC FPGA Software & the Quartus II Software        | 11–2  |
| Setup of the DC FPGA Software Environment for Altera Device Families    |       |
| Megafunctions & Architecture-Specific Features                          | 11–5  |
| Instantiating Altera Megafunctions Using the MegaWizard Plug-In Manager |       |
| Clear Box Methodology                                                   |       |
| Black Box Methodology                                                   |       |
| Inferring Altera Megafunctions from HDL Code                            |       |
| Reading Design Files into the DC FPGA Software                          |       |
| Selecting a Target Device                                               | 11–15 |
| Timing & Synthesis Constraints                                          |       |
| Compilation & Synthesis                                                 |       |
| Reporting Design Information                                            |       |
| Saving Synthesis Results                                                |       |
| Exporting Designs to the Quartus II Software                            |       |
| write_fpga Command                                                      |       |
| write & write_par_constraint Commands                                   |       |
| Using Tcl Scripts with Quartus II Software                              |       |
| Place & Route with the Quartus II Software                              |       |
| Formality Software Support                                              |       |
| CONCINSION                                                              | 11-26 |

Altera Corporation xi

## Chapter 12. Analyzing Designs with Quartus II Netlist Viewers

| Introduction                                                     | 12–1  |
|------------------------------------------------------------------|-------|
| When to Use Viewers: Analyzing Design Problems                   |       |
| Quartus II Design Flow with the Netlist Viewers                  | 12–3  |
| RTL Viewer Overview                                              |       |
| State Machine Viewer Overview                                    |       |
| Technology Map Viewer Overview                                   |       |
| Introduction to the User Interface                               | 12–7  |
| Schematic View                                                   | 12–7  |
| Hierarchy List                                                   |       |
| State Machine Viewer                                             | 12-17 |
| Navigating the Schematic View                                    | 12-20 |
| Traversing & Viewing the Design Hierarchy                        | 12-20 |
| Viewing Contents of Atom Primitives in the Technology Map Viewer |       |
| Zooming & Magnification                                          |       |
| Partitioning the Schematic into Pages                            |       |
| Go to Net Driver                                                 |       |
| Filtering in the Schematic View                                  | 12-27 |
| Filter Sources Command                                           | 12-28 |
| Filter Destinations Command                                      | 12-29 |
| Filter Sources & Destinations Command                            | 12-29 |
| Filter between Selected Nodes Command                            |       |
| Filter Selected Nodes & Nets Command                             | 12-30 |
| Filter Bus Index Command                                         | 12-31 |
| Filter Command Processing                                        |       |
| Filtering Across Hierarchies                                     | 12-32 |
| Expanding a Filtered Netlist                                     | 12-33 |
| Reducing a Filtered Netlist                                      |       |
| Probing to Source Design File & Other Quartus II Windows         |       |
| Probing to the Viewers from Other Quartus II Windows             | 12-36 |
| Viewing a Timing Path                                            |       |
| Other Features in the Schematic Viewer                           | 12-38 |
| Tooltips                                                         | 12-38 |
| Rollover                                                         |       |
| The Properties Dialog Box                                        | 12-41 |
| Displaying Net Names                                             | 12-42 |
| Displaying Node Names                                            |       |
| Full Screen View                                                 | 12-42 |
| Find Command                                                     |       |
| Exporting & Copying a Schematic Image                            |       |
| Printing                                                         |       |
| Debugging HDL Code with the State Machine Viewer                 |       |
| Simulation of State Machine Gives Unexpected Results             | 12–45 |
| Conclusion                                                       | 12-48 |



# **Chapter Revision Dates**

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

Chapter 1. Quartus II Incremental Compilation for Hierarchical & Team-Based Design

Revised: *May* 2006 Part number: *QII51015-6.0.0* 

Chapter 2. Quartus II Design Flow for MAX+PLUS II Users

Revised: May 2006 Part number: QII51002-6.0.0

Chapter 3. Quartus II Support of HardCopy Series Devices

Revised: *May* 2006 Part number: *QII51004-6.0.0* 

Chapter 4. Engineering Change Management

Revised: May 2006 Part number: QII51005-6.0.0

Chapter 5. Design Recommendations for Altera Devices

Revised: May 2006 Part number: QII51006-6.0.0

Chapter 6. Recommended HDL Coding Styles

Revised: May 2006 Part number: QII51007-6.0.0

Chapter 7. Quartus II Integrated Synthesis

Revised: May 2006 Part number: QII51008-6.0.0

Chapter 8. Synplicity Synplify & Synplify Pro Support

Revised: May 2006 Part number: QII51009-6.0.0

Chapter 9. Mentor Graphics Precision RTL Synthesis Support

Revised: *May* 2006 Part number: *QII51011-6.0.0* 

Altera Corporation xiii

Chapter 10. Mentor Graphics LeonardoSpectrum Support

Revised: May 2006 Part number: QII51010-6.0.0

Chapter 11. Synopsys Design Compiler FPGA Support

Revised: May 2006 Part number: QII51014-6.0.0

Chapter 12. Analyzing Designs with Quartus II Netlist Viewers

Revised: May 2006 Part number: QII51013-6.0.0

xiv Altera Corporation



## About this Handbook

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

### How to Contact Altera

For the most up-to-date information about Altera products, go to the Altera world-wide web site at www.altera.com. For technical support on this product, go to www.altera.com/mysupport. For additional information about Altera products, consult the sources shown below.

| Information Type               | USA & Canada                                                   | All Other Locations                                         |
|--------------------------------|----------------------------------------------------------------|-------------------------------------------------------------|
| Technical support              | www.altera.com/mysupport/                                      | altera.com/mysupport/                                       |
|                                | (800) 800-EPLD (3753)<br>(7:00 a.m. to 5:00 p.m. Pacific Time) | (408) 544-7000 (1)<br>(7:00 a.m. to 5:00 p.m. Pacific Time) |
| Product literature             | www.altera.com                                                 | www.altera.com                                              |
| Altera literature services     | literature@altera.com (1)                                      | literature@altera.com (1)                                   |
| Non-technical customer service | (800) 767-3753                                                 | (408) 544-7000<br>(7:30 a.m. to 5:30 p.m. Pacific Time)     |
| FTP site                       | ftp.altera.com                                                 | ftp.altera.com                                              |

#### 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 6.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 PROVDED 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.

Altera Corporation xv

# Typographic Conventions

This document uses the typographic conventions shown below.

| Visual Cue                                  | Meaning                                                                                                                                                                                                                                                                                                                 |  |
|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bold Type with Initial<br>Capital Letters   | 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.                                                                                                                                                              |  |
| bold type                                   | External timing parameters, directory names, project names, disk drive names, filenames, filename extensions, and software utility names are shown in bold type.  Examples: f <sub>MAX</sub> , \qdesigns directory, d: drive, chiptrip.gdf file.                                                                        |  |
| Italic Type with Initial<br>Capital Letters | Document titles are shown in italic type with initial capital letters. Example: AN 75: High-Speed Board Design.                                                                                                                                                                                                         |  |
| Italic type                                 | Internal timing parameters and variables are shown in italic type. Examples: $t_{PJA}$ , $n+1$ .                                                                                                                                                                                                                        |  |
|                                             | Variable names are enclosed in angle brackets (< >) and shown in italic type. Example: <file name="">, <pre><pre><pre><pre><pre><pre>file</pre>.</pre></pre></pre></pre></pre></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: data1, tdi, input. Active-low signals are denoted by suffix n, e.g., resetn.                                                                                                                                                                       |  |
|                                             | Anything that must be typed exactly as it appears is shown in Courier type. For example: c:\qdesigns\tutorial\chiptrip.gdf. Also, sections of an actual file, such as a Report File, references to parts of files (e.g., the AHDL keyword SUBDESIGN), as well as logic function names (e.g., TRI) are shown in Courier. |  |
| 1., 2., 3., and<br>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.                                                                                                                                                                                        |  |
| • •                                         | 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                                     | The caution indicates required information that needs special consideration and understanding and should be read prior to starting or continuing with the procedure or process.                                                                                                                                         |  |
| <b>A</b>                                    | The warning indicates information that should be read prior to starting or continuing the procedure or processes.                                                                                                                                                                                                       |  |
| 4                                           | The angled arrow indicates you should press the Enter key.                                                                                                                                                                                                                                                              |  |
| •••                                         | The feet direct you to more information on a particular topic.                                                                                                                                                                                                                                                          |  |

xvi Altera Corporation



# **Section I. Design Flows**

The Altera® Quartus® II, version 6.0 design software provides a complete multi-platform design environment that easily adapts to your specific design needs. The Quartus II software also allows you to use the Quartus II graphical user interface, EDA tool interface, or command-line interface for each phase of the design flow. This section explains the Quartus II, version 6.0 software options that are available for each of these flows.

This section includes the following chapters:

- Chapter 1, Quartus II Incremental Compilation for Hierarchical & Team-Based Design
- Chapter 2, Quartus II Design Flow for MAX+PLUS II Users
- Chapter 3, Quartus II Support of HardCopy Series Devices
- Chapter 4, Engineering Change Management

### **Revision History**

The chapter, *Hierarchical Block-Based & Team-Based Design Flows*, was removed from this handbook. The table below shows the revision history for Chapters 1 to 4.

Altera Corporation Section I–1

| Chapter(s) | Date / Version       | Changes Made (Part 1 of 2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | May 2006 v6.0.0      | Name changed to <i>Quartus II Incremental Compilation for Hierarchical &amp; Team-Based Design</i> .  Updated for the Quartus II software version 6.0.0  Added new device support information.  Added top-down and bottom-up design flow information.  Added incremental compilation design compiling information.  Added recommendations for creating good floorplan location assignments.  Added register packing & partition boundary information.  Added engineering management with the Chip Editor.  Added information on how to check and save to reapply SignalProbe™. |
|            | December 2005 v5.1.1 | Minor typographic update.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|            | October 2005 v5.1.0  | Updated for the Quartus II software version 5.1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|            | August 2005 v5.0.1   | Added documentation on cross-partition register packing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|            | May 2005 v5.0.0      | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2          | May 2006 v6.0.0      | Minor updates for the Quartus II software version 6.0.0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|            | December 2005 v5.1.1 | Minor typographic and formatting updates.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|            | October 2005 v5.1.0  | Updated for the Quartus II software version 5.1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|            | May 2005 v5.0.0      | Chapter 2 was formerly Chapter 1 in version 4.2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|            | Dec. 2004 v2.1       | Updated for Quartus II software version 4.2.  Chapter 1 was formerly Chapter 2.  General formatting, editing updates, and figure updates.  FLEX® 600 device support added.  Assignment Editor, Timing Assignments, and Synthesis updated.  APEX II support for balanced optimization technique removed, MAX II support added.  Minor updates to Place & Route.  Tcl commands no longer supported for the Quartus II Simulator Tool.  Excel-based power calculator replaced by PowerPlay Early Power Estimation spreadsheet.  Added support for erase capability for CPLDs.     |
|            | June 2004 v2.0       | <ul><li>Updates to tables, figures.</li><li>New functionality for Quartus II software 4.1.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|            | Feb. 2004 v1.0       | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

Section I–2 Altera Corporation

| Chapter(s) | Date / Version      | Changes Made (Part 2 of 2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 3          | May 2006 v6.0.0     | Minor updates for the Quartus II software version 6.0.0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|            | October 2005 v5.1.0 | Updated for the Quartus II software version 5.1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|            | May 2005 v5.0.0     | <ul> <li>Chapter 3 was formerly Chapter 2.</li> <li>Updated for consistency with the Quartus II Support for HardCopy II         Devices and Quartus II Support for HardCopy Stratix Devices chapters         in the HardCopy Series Handbook.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|            | Jan. 2005 v2.1      | Added HardCopy II Device Material.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|            | Dec. 2004 v2.1      | <ul> <li>Chapter 2 was formerly Chapter 3.</li> <li>Updates to tables, figures.</li> <li>New functionality for Quartus II software 4.2</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|            | June 2004 v2.0      | <ul><li>Updates to tables, figures.</li><li>New functionality for Quartus II software 4.1.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|            | Feb. 2004 v1.0      | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| 4          | May 2006 v6.0.0     | Minor updates for the Quartus II software version 6.0.0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|            | October 2005 v5.1.0 | Updated for the Quartus II software version 5.1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|            | May 2005 v5.0.0     | Chapter 4 was formerly Chapter 3 in version 4.2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|            | Dec. 2004 v2.1      | <ul> <li>Updated for Quartus II software version 4.2:</li> <li>Chapter 4 was formerly Chapter 3.</li> <li>General formatting and editing updates.</li> <li>Device family support descriptions updated.</li> <li>Updated HardCopy structured support for performance improvements.</li> <li>Quartus II Archive File automatically receives buffer insertion.</li> <li>Power Calculator now Power Estimator for affected devices.</li> <li>Updates to tables, figures.</li> <li>The description of How to Design HardCopy Stratix Devices was updated.</li> <li>The description of HardCopy Timing Optimization Wizard was updated.</li> <li>HardCopy Floorplans &amp; Timing Modules was renamed to Design Optimization.</li> <li>The description of Performance Estimation was updated.</li> <li>Added new section on Buffer Insertion.</li> <li>Location Constraints was updated.</li> <li>Targeting Designs to HardCopy APEX 20KC and HardCopy APEX 20KE Devices was removed.</li> <li>A new section Altera Recommended HDL Coding Guidelines was added.</li> <li>Table 2–5 was added. It lists the HardCopy Stratix design files collected by the hardCopy Files Wizard.</li> <li>The description of the HardCopy APEX Power Estimator was updated.</li> <li>A new section on Targeting Designs to HardCopy APEX Devices was added.</li> </ul> |  |
|            | June 2004 v2.0      | <ul> <li>Updates to tables, figures.</li> <li>New functionality for Quartus II software 4.1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|            | Feb. 2004 v1.0      | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |

Altera Corporation Section I–3

Section I–4 Altera Corporation



# 1. Quartus II Incremental Compilation for Hierarchical & Team-Based Design

QII51015-6.0.0

#### Introduction

For today's high-density, high-performance FPGA designs, the ability to iterate rapidly during the design and debugging stages is critical. The Quartus® II software delivers advanced technology to create designs for high-density FPGAs. Altera® has introduced the FPGA industry's first true incremental design and compilation flow, providing the following benefits:

- Preserves the results and performance for unchanged logic in your design as you make changes elsewhere.
- Reduces design iteration time by an average of about 60%, allowing you to perform more design iterations per day and achieve timing closure more efficiently.
- Provides ease of use through the GUI.
- Includes Tcl scripting, command-line, and makefile support.
- Facilitates modular and team-based design flows using top-down or bottom-up methodologies.
- Supports full incremental compilation for Stratix<sup>®</sup>, Stratix II, Cyclone<sup>™</sup>, and Cyclone II devices, and incremental synthesis for the MAX<sup>®</sup> II device family. Supports full incremental compilation for native HardCopy<sup>®</sup> II device development, however, you cannot migrate a Stratix II design with full incremental compilation enabled to a HardCopy II device.



Quartus II incremental compilation is an optional compilation flow. This chapter provides an overview of the Quartus II design flow with and without incremental compilation. However, for an overview of the Quartus II design flow and features, refer to the *Introduction to Quartus II Manual*.

To take advantage of incremental compilation, organize your design into logical partitions and physical regions for synthesis and fitting (or place and route). Incremental compilation preserves the compilation results and performance of unchanged partitions in your design, dramatically reducing design iteration time by focusing new compilations only on changed design partitions. New compilation results are then merged with the previous compilation results from unchanged design partitions. Additionally, you can target optimization techniques, such as physical synthesis, to specific design partitions while leaving other partitions untouched.

In conventional FPGA design, a hierarchical design is flattened into a single netlist before logic synthesis and fitting, and the entire design is recompiled every time the design changes. The Quartus II incremental compilation feature provides the ability to partition a design along any of its hierarchical boundaries. The Quartus II software separately synthesizes and fits each individual hierarchical design partition then merges the partitions into a complete netlist for subsequent stages of the compilation flow. When recompiling the design, you can choose to use source code, post-synthesis results, or post-fitting results for each partition. If you want to preserve the fitter results, you can choose to keep just the fitter netlist, keep the placement results, or keep both the placement and routing results.

Incremental compilation supports top-down design methodologies, in which one designer manages the project for the entire design, as well as bottom-up design methodologies in which each design block can be developed independently. Bottom-up methodologies include team-based design flows in which design partitions are created by team members in another location or by third-party intellectual property (IP) providers. For bottom-up flows, you can generate scripts from the top-level design that pass constraints to lower-level design blocks compiled in separate Quartus II projects.

The goal of this chapter is to provide the following information:

- Provide an overview of the Quartus II design flow with and without incremental compilation
- Describe how to use the Quartus II incremental compilation feature
- Provide you the level of understanding required to make good design decisions to achieve timing closure while speeding up design iterations
- Present several applications of incremental compilation in the form of user scenarios, along with the rationale behind them and the steps required to carry out the tasks

This chapter includes the following sections:

- Quartus II Design Flow
- Design Partitions
- Preparing a Design for Incremental Compilation
- Compiling a Design Using Incremental Compilation
- Creating Design Partitions
- Guidelines for Creating Good Design Partitions
- Setting the Netlist Type for Design Partitions
- Creating a Design Floorplan With LogicLock Location Assignments
- Criteria for Successful Partition and Floorplan Schemes
- Exporting & Importing Partitions for Bottom-Up Design Flows
- User Scenarios—Incremental Compilation Application Examples
- Incremental Compilation Restrictions
- Scripting Support
- Conclusion

# Quartus II Design Flow

Quartus II incremental compilation enhances the standard Quartus II design flow by allowing you to reuse satisfactory results from previous compilations and save compilation time. This section outlines the standard compilation flow and the incremental flow, highlights the differences, and explains some of the reasons you might want to use the incremental flow.

The standard Quartus II compilation flow consists of the following essential modules:

- Analysis & Synthesis—performs logic synthesis to minimize the design logic and performs technology mapping to implement the design logic using device resources such as logic elements. This stage also generates the project database that integrates the design files (including netlists from third-party synthesis tools). When you are using EDIF or VQM netlists created by third-party synthesis tools, the Analysis & Synthesis stage performs logic synthesis and technology mapping only for black boxes and Altera megafunctions.
- Fitter—places and routes the logic of a design into a device.
- Assembler—converts the Fitter's device, logic, and pin assignments into programming files for the device.
- **Timing Analyzer**—analyzes and validates the timing performance of all the logic in a design.

Quartus II Project & Design Files Block \_ Verilog **EDIF** VQM **VHDL** AHDL Design HDL Netlist Netlist (.vhd) (.tdf) File (.v) (.edf) (.vqm) (.bdf) Settings & Analysis & Synthesis (1) Assignments Post-Synthesis Netlist Settings & Fitter Assignments Place-and-Route Post-Fit Netlist Assembler Timing Analyzer No Make Design & Assignment Requirements Modifications Satisfied? Yes Program/Configure Device

Figure 1–1 shows a block diagram of the Quartus II standard design flow.

Figure 1-1. Quartus II Standard Design Flow

#### Note to Figure 1–1:

(1) When you are using EDIF or VQM netlists created by third-party EDA synthesis tools, the Analysis & Synthesis stage of the compilation is performed to create the design database, but logic synthesis and technology mapping are performed only for black boxes and Altera megafunctions.

In the standard Quartus II compilation flow, you can use smart compilation to allow the compiler to determine which compiler modules are required based on the changes made to the design since the last smart compilation, and then skip any modules that are not required. For example, when smart compilation is selected, the compiler skips the Analysis & Synthesis module if the design source files were unchanged. Smart compilation skips only entire compiler stages. It cannot make

incremental changes within a given stage of the compilation flow. On the Assignments menu, click **Settings**. In the Category list, select **Compilation Process Settings** and click **Use Smart Compilation**.

In the standard compilation flow, all of the source code is processed with the Analysis & Synthesis module, and all the logic is placed by the Fitter module whenever the design is recompiled after any change in any part of the design. One reason for this behavior is to obtain optimal quality of results. By processing the entire design, the compiler can perform global optimizations to improve area and performance.

However, there are situations in which a more incremental compilation flow is desirable. When the design partitions are well chosen and placed in the device floorplan, you can speed up your design compilation time while maintaining or even improving the quality of results. "Creating Design Partitions" on page 1–17 provides tips for choosing design partitions.

You may want to use incremental compilation later in the design cycle when you are not interested in improving the majority of the design any further, and want to make changes to or optimize one specific block. In this case, you may want to preserve the performance of modules that are unmodified and to reduce compilation time on subsequent iterations. There are also situations in which incremental compilation is useful both for reducing compilation time and for achieving timing closure. For example, you may want to specify which partitions should be preserved in subsequent incremental compilations, and then recompile the other partitions with advanced optimizations turned on.

You might also have part of your design that is not yet complete, for which you can create an empty partition while compiling the completed partitions, and then save results for the complete partitions while you work on the new part of the design. Alternately, different designers or IP providers may be working on different blocks of the design using a team-based methodology, and you want to combine them in a bottom-up compilation flow.

For more detailed user scenarios, refer to "User Scenarios—Incremental Compilation Application Examples" on page 1–48.

Figure 1–2 shows a block diagram of the Quartus II design flow using incremental compilation.



Figure 1–2. Quartus II Design Flow Using Incremental Compilation

#### Note to Figure 1-2:

(1) When you are using EDIF or VQM netlists created by third-party EDA synthesis tools, the Analysis & Synthesis stage of the compilation is performed to create the design database, but logic synthesis and technology mapping are performed only for black boxes and Altera megafunctions.

In this flow, you partition the design, then perform logic synthesis and technology mapping for each partition individually with Analysis & Synthesis.

Analysis & Synthesis reads the project assignments to determine the partition boundaries. The example in Figure 1–2 shows a top-level partition and two lower-level partitions. If any part of the design changes, Analysis & Synthesis processes the changed partitions and keeps the existing netlist for the unchanged partitions. After completion of Analysis & Synthesis, there is one post-synthesis netlist for each partition.

The partition merge step creates a single, complete netlist that can be comprised of post-synthesis and/or post-fitting netlists, or netlists imported from lower-level projects, depending on the netlist type you specify for each partition. For more information, refer to "Setting the Netlist Type for Design Partitions" on page 1–26.

The Fitter then processes the merged netlist, preserving the placement or placement and routing of unchanged partitions, refitting only those partitions that have changed. The Fitter generates the complete netlist for use in further stages of the compilation flow, including timing analysis and programming file generation. It also generates individual netlists for each partition so that the partition merge step can use the post-fit netlist to preserve the placement and routing of a partition if you specify to do so in future compilations.

If the design does not meet its requirements (functionality, timing, or area), you can make changes to the design and recompile. The Quartus II software does not resynthesize or refit unchanged partitions that have a netlist type assignment that specifies the use of a post-synthesis or post-fit netlist, respectively.

#### Top-Down vs. Bottom-Up Design Flows

The Quartus II incremental compilation feature supports both top-down and bottom-up compilation flows. With top-down compilation, one designer or project lead compiles the entire design in the software. Different designers or IP providers can design and verify different parts of the design, and the project lead can add design entities to the project as they are completed. However the project lead compiles and optimizes the top-level project as a whole. Completed parts of the design can have fitting results and performance fixed as other parts of the design are changing.

Bottom-up design flows allow individual designers to complete the optimization of their design in separate projects and then integrate each lower-level project into one top-level project. Incremental compilation

provides export and import features to enable this design methodology. Designers of lower-level blocks can export the optimized netlist for their design, along with a set of assignments such as LogicLock regions. Then the project lead imports each design block as a design partition in a top-level project. In this case, the project lead must provide guidance to designers of lower-level blocks to ensure that each partition uses the appropriate device resources.

It is important to realize that with the full incremental compilation flow, users who traditionally relied on a bottom-up approach for the sole reason of performance preservation can now employ a top-down approach to achieve the same goal. This ability is important for two reasons. First, a top-down flow is generally simpler to perform than its bottom-up counterpart. For example, the need to export and import lower-level designs is eliminated. Second, a top-down approach provides the design software with information about the entire design so it can perform global optimizations. In a bottom-up design methodology, you must perform resource balancing and time-budgeting because the software does not have any information about the other partitions in the top-level design when it compiles individual lower-level partitions. For more information about the export and import operations, and how to use design partition scripts to help with design planning, refer to "Exporting & Importing Partitions for Bottom-Up Design Flows" on page 1–35.

# Using Incremental Synthesis Only Instead of Full Incremental Compilation

You can turn on incremental compilation for only the synthesis stage of compilation to perform incremental synthesis, with no incremental place-and-route. In this mode, the Fitter uses a flattened netlist without partition boundaries and therefore performs cross-boundary optimizations that help timing performance. The difference between this flow and the one shown in Figure 1–2 is that the partition merge stage does not accept post-fit netlists produced by the Fitter, and the Fitter does not compile partitions separately.

**Incremental synthesis only** is the default compilation option when using incremental compilation. This is because, although the potential benefit offered by **Full incremental compilation** can be higher than that offered by incremental synthesis alone, many additional design considerations and a deeper understanding of the compilation process are required to use the full incremental compilation flow successfully.

Table 1–1 lists the different characteristics between the two compilation options.

| Table 1–1. Characteristics of Using Incremental Synthesis Only, Compared to Full Incremental Compilation |                                                                                                                                                       |                                                                                                                                                                                                                                              |  |  |  |
|----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Characteristic                                                                                           | Incremental Synthesis Only                                                                                                                            | Full Incremental Compilation                                                                                                                                                                                                                 |  |  |  |
| Compilation<br>Time Savings                                                                              | Roughly 15-40% of total time; savings limited to Quartus II integrated synthesis.                                                                     | Roughly 50-70% of total time; savings in both Quartus II integrated synthesis and the Fitter.                                                                                                                                                |  |  |  |
| Performance<br>Preservation                                                                              | None since placement cannot be preserved.                                                                                                             | Excellent when critical paths are contained within a partition, because you can preserve post-fitting information for unchanged partitions.                                                                                                  |  |  |  |
| Node Name<br>Preservation                                                                                | Preserves post-synthesis node names for unchanged partitions.                                                                                         | Preserves post-fitting node names for unchanged partitions.                                                                                                                                                                                  |  |  |  |
| Area Changes                                                                                             | Area might increase due to lack of cross-boundary optimizations. If design is partitioned appropriately, small or no change in area.                  | Area increases by 5% on average in addition to any synthesis area change, since placement and register packing are restricted.                                                                                                               |  |  |  |
| f <sub>MAX</sub> Changes                                                                                 | $f_{MAX}$ might be reduced due to lack of cross-boundary optimizations. If the design is partitioned appropriately, no negative impact on $f_{MAX}$ . | If the design is partitioned and the floorplan location assignments are created appropriately, no negative impact on $f_{MAX}$ . You may get a slight performance increase by employing a good partition and floorplan scheme.               |  |  |  |
| Ease of Use                                                                                              | Simply create partitions.                                                                                                                             | Specify which partitions you want to preserve, and create floorplan location assignments in most cases.                                                                                                                                      |  |  |  |
| Floorplan<br>Creation                                                                                    | Not required.                                                                                                                                         | Required in most cases for best quality of results.                                                                                                                                                                                          |  |  |  |
| When Design is<br>Resynthesized                                                                          | Change in source code or synthesis assignments.                                                                                                       | Change in source code (unless you specify to use a post-fit netlist strictly), or when you specify to use the source file.                                                                                                                   |  |  |  |
| When Design is<br>Refit                                                                                  | Always                                                                                                                                                | Change in source code (unless you specify to use a post-fit netlist strictly), when you specify to use the source or post-synthesis netlist, or when you specify to use a post-fit netlist with a fitter preservation level of Netlist Only. |  |  |  |
| When to Use in<br>the Design Flow                                                                        | Can use with equal value throughout the design process.                                                                                               | Useful mostly when performing placement and routing, especially during iterative timing closure and for late design changes, or when part of the design is incomplete.                                                                       |  |  |  |
| User Base                                                                                                | Quartus II integrated synthesis users only; limited application for third-party synthesis tool users.                                                 | Potentially all Quartus II software users; typically more experienced users who may have previously used LogicLock <sup>TM</sup> assignments.                                                                                                |  |  |  |



For usage details specific to the **Incremental synthesis only** option, refer to the *Incremental Synthesis* section in the *Quartus II Integrated Synthesis* chapter in volume 1 of the *Quartus II Handbook*.

# Design Partitions

It is common design practice to create modular or hierarchical designs in which you develop each design entity separately and then instantiate them in a higher-level entity, forming a complete design. The software does not consider each design entity automatically to be a design partition for incremental compilation; rather, you must designate one or more design hierarchies below the top-level project to be a design partition. Creating partitions prevents the compiler from performing optimizations across partition boundaries, as discussed in "Creating Design Partitions" on page 1–17 and illustrated in Figure 1–8. However, this allows for separate synthesis and placement for each partition, making incremental compilation possible.

Partitions must have the same boundaries as hierarchical blocks in the design because partitions cannot be a portion of the logic within a hierarchical entity. When you declare a partition, every hierarchical entity within that partition becomes part of the same partition. You can create new partitions for hierarchical entities within an existing partition, in which case the entities within the new partition are no longer included with the higher-level partition, as described in the following example.

In Figure 1–3, hierarchical entities **B** and **F** form partitions in the complete design, which is made up of entities **A**, **B**, **C**, **D**, **E**, and **F**. The shaded boxes in Representation A indicate design partitions in a "tree" representation of the hierarchy. In Representation B, the lower-level entities are represented inside the higher-level entities, and the partitions are illustrated with different colored shading. The top-level partition, called Top, automatically contains the top-level entity in the design, and contains any logic not defined as part of another partition. The design file for the top-level may be just a wrapper for the hierarchical entities below it, or it may contain its own logic. In this example, the partition for top-level entity **A** also includes the logic in one of its lower-level entities, **C**. Because entity **F** is contained in its own partition, it is not treated as part of the top-level partition. Another separate partition, **B**, contains the logic in entities **B**, **D**, and **E**.

Figure 1–3. Partitions in a Hierarchical Design

#### Representation A



#### Representation B



#### **Design Partitions Compared to Physical Regions**

Design partitions for incremental compilation are logical partitions, different from physical regions in the device floorplan. Physical regions specify locations in the device floorplan using LogicLock assignments in the Quartus II software. Physical regions have a size and location on the device floorplan, and you can assign multiple design instances and nodes to a physical region to place them close to each other. A logical design partition does not refer to a physical section of the device and does not directly control the placement of instances. A logical design partition sets up a virtual boundary between design hierarchies so each is compiled separately, preventing logical optimizations from occurring between them.

Altera recommends that you assign each design partition to a physical region using the LogicLock feature to improve quality of results when performing a full incremental compilation. Create floorplan location assignments for design partitions using LogicLock regions as discussed in "Creating a Design Floorplan With LogicLock Location Assignments" on page 1–29. Physical location assignments are not required for logical design partitions if you are using the **Incremental Synthesis Only** option.

# Preparing a Design for Incremental Compilation

To set up your design for incremental compilation, use the following general steps. Detailed descriptions for some of these steps are included in later sections of this chapter. The flow chart in Figure 1–5 illustrates these steps in the complete incremental design flow.

- Elaborate the design. On the Processing menu, point to Start and click Start Analysis & Elaboration, or run any compilation flow that includes this step. This allows the Quartus II software to identify your design's hierarchy.
- On the Assignments menu, click Settings. On the Compilation Process page of the Settings dialog box, select Incremental compilation and turn on Full incremental compilation, as shown in Figure 1–4.
- 3. Create partitions in your design by applying the Set as Design Partition or PARTITION\_HIERARCHY assignment to the appropriate instances. Refer to the section "Creating Design Partitions" on page 1–17 for more details on design partitions and how to make good assignments.



When you specify your first partition, a dialog box is shown that asks whether you wish to enable incremental compilation if you have not already done so. Selecting Full incremental compilation in this dialog box also turns on incremental compilation as in Step 2. You can also turn on incremental compilation in the Design Partitions Window on the Assignments menu.

Selecting **Off** on the Incremental Compilation page of the **Settings** dialog box turns off all forms of incremental synthesis and incremental compilation, but does not remove any partition assignments. Partition assignments have no effect on the design if incremental compilation is turned off.

- 4. Make location assignments for each partition in the design with the LogicLock feature to create a design floorplan. Each partition should be assigned to a physical region on the device. Refer to the section "Creating a Design Floorplan With LogicLock Location Assignments" on page 1–29 for details on making these assignments.
- 5. On the Processing menu, click Start Compilation to compile the design. The first compilation after making the partition and LogicLock assignments is a complete compilation that prepares the design for subsequent incremental compilations.

To use incremental synthesis only, follow Step 1 through Step 3, but, in Step 2 select **Incremental synthesis only** instead of **Full incremental compilation** on the **Incremental Compilation** page in the **Settings** dialog box in Figure 1–4.



Figure 1–4. Full Incremental Compilation Enabled in the Settings Dialog Box



For details specific to using only the incremental synthesis option, refer to the *Incremental Synthesis* section in the *Quartus II Integrated Synthesis* chapter in volume 1 of the *Quartus II Handbook*.

# Compiling a Design Using Incremental Compilation

After compiling the design once and then making changes, you can take advantage of incremental compilation to recompile the changed parts of the design while preserving the results for the unchanged partitions, saving time on subsequent compilations. To do this, perform the following general steps:

- 1. To preserve previous compilation results for a partition, set the Netlist Type assignment for that partition to Post-Fit. To save just the synthesis results, set the Netlist Type assignment for that partition to Post-Synthesis. If you have imported a partition from another Quartus II project, choose Imported. For details on setting this partition property and specifying the fitter preservation level for post-fit netlists, refer to "Setting the Netlist Type for Design Partitions" on page 1–26.
- 2. Compile the design. When you start a compilation for a partitioned design with incremental compilation turned on, the Quartus II software automatically uses the incremental compilation flow, preserving the results as specified in Step 1.



If you preserve the compilation results using the Post-Fit netlist, you do not have to back-annotate logic location assignments. You should not use the incremental compilation and the back-annotation features in the same Quartus II project.

The flow chart in Figure 1–5 illustrates these steps in the complete incremental design flow.



Figure 1–5. Summary of Design Flow Using Incremental Compilation

#### What Represents a Source Change for Incremental Compilation?

The Quartus II software uses an internal checksum to determine whether the contents of a source file have changed. Source files are the design files used to create the design, and consist of VHDL files, Verilog HDL files, AHDL files, Block Design Files (.bdf), EDIF netlists, and VQM netlists. Changes in other files such as vector waveform files for simulation do not trigger recompilation.

The project database folder (\db) includes all the netlist information for previous compilations. To avoid unnecessary recompilations, the database files must not be altered or deleted.

Synthesis and Fitter assignments, including optimization settings, timing assignments, or Fitter location assignments such as pin assignments or LogicLock assignments, do not trigger automatic recompilation in the incremental compilation flow. To recompile a partition with new assignments, change the **Netlist Type** assignment for that partition to **Source File** to recompile with all new settings, or to **Post-Synthesis** to recompile using existing synthesis results but new fitter settings, or to **Post-Fit** with the **Fitter preservation Level** set to **Placement** to re-run routing using existing placement results except for any new routing settings including delay chain settings. For information about the **Netlist Type** and **Fitter Preservation Level** assignments, refer to "Setting the Netlist Type for Design Partitions" on page 1–26.

#### Determining Which Partitions Will be Recompiled

When design files in a partition have dependencies on other files, changing one file may trigger an automatic recompilation of another file. The **Partition Dependent Files** table in the Analysis & Synthesis report lists the design files that contribute to each design partition, so you can use this table to determine which files are recompiled when a specific partition is recompiled.

For example, if a design has files **a.v** that contains entity **a**, **b.v** that contains entity **b**, and **c.v**, that contains entity **c**, then the **Partition Dependent Files** table for the partition containing entity **a** lists file **a.v**, the table for the partition containing entity **b** lists file **b.v**, and the table for the partition containing entity **c** lists file **c.v**. Any dependencies are transitive, so if file **a** depends on **b**, and **b** depends on **c**, then the entities in file **a** depend on files **b** and **c** so entities **b** an **c** are listed in the report table.

If a design contains common files, such as a file includes.v that is referenced in each entity by the command include includes.v, then all partitions are dependent on this file, and a change to includes.v causes the entire design to be recompiled. The VHDL statement use work.all also typically results in unnecessary recompilations.

To avoid this type of problem, ensure that files common to all entities such as a common include file contain only the set of information that is truly common to all entities. Remove use work.all statements in your VHDL file or replace them by including only the specific packages needed for each entity.

#### Forcing Use of the Post-Fitting Netlist When a Source File has Changed

Forcing the use of the post-fitting netlist when the contents of a source file has changed is recommended only for advanced users who thoroughly understand when a partition must be recompiled. To force the Fitter to use a previously generated post-fit netlist when there are changes to the source files, you can use the **Post-Fit (Strict)** Netlist Type assignment. For information about the **Post-Fit (Strict)** Netlist Type, refer to "Setting the Netlist Type for Design Partitions" on page 1–26.



Misuse of the **Post-Fit (Strict)** Netlist Type can result in the generation of a functionally incorrect netlist when source design files change. Use caution in applying this assignment.

## Creating Design Partitions

You can make partition assignments to HDL or schematic design instances, or to VQM or EDIF netlist instances (from third-party synthesis tools). To take advantage of incremental compilation when source files change, the top-level design entity of each partition should have a unique design file. If you define two different entities of separate partitions but they are in the same design file, you cannot maintain incremental compilation because the software would have to recompile both partitions if you changed either entity in the design file.

When you are using a third-party synthesis tool, create a separate netlist file for each partition to allow each partition to be treated incrementally. To create separate netlists for each partition, you may have to create a top-level HDL wrapper file that instantiates the lower-level netlist files and then create separate projects in your synthesis tool for each of the lower-level partitions. In this case, the lower-level blocks should be treated as a black box in the top-level design. Some synthesis tools allow you to create separate netlist files for different design blocks within a single project.



For information on using incremental compilation with third-party synthesis tools, refer to the appropriate chapter in the *Synthesis* section in volume 1 of the *Quartus II Handbook*.

For suggestions on determining which parts of your design should be set as design partitions, refer to "Guidelines for Creating Good Design Partitions" on page 1–20.

#### **Creating Design Partitions in the GUI**

You can create design partitions in the Quartus II GUI with the Design Partitions Window or the Project Navigator.

On the Assignments menu, click **Design Partitions Window** (Figure 1–6) to create your partitions in one of the following ways:

- Create new partitions for one or more instances by dragging and dropping them from the **Hierarchy** tab of the **Project Navigator**, into the Design Partitions window. Using this method, you can create multiple partitions at once.
- Create new partitions by double-clicking the <<new>> cell in the Partition Name column. In the Create New Partitions dialog box, select the design instance and click OK.

To delete partitions in the Design Partitions window, right-click a partition and click **Delete**, or press the **Delete** key.

Design Partitions Partition Name Compilation Hierarchy Path Netlist Type Fitter Preservation Level 🖃 🌆 Design Partitions -- << new>> ⊡**(ि** Top filtref Post-Sunthesis - aps:inst Imported Placement taps:inst mult:inst6 mult:inst6 Post-Fit Placement and Routing hvalues:inst2 hvalues:inst2 Post-Synthesis Not Applicable > Incremental compilation: Full incremental compilation ▼

Figure 1–6. Design Partitions Window

Alternately, you can use the list of instances under the **Hierarchy** tab in the **Project Navigator**. Right-click on an instance in the **Project Navigator** and click **Set as Design Partition**.



A design partition icon appears next to each instance that is set as a partition (Figure 1–7).

To remove an existing partition assignment, right-click the instance in the **Project Navigator** and click **Set as Design Partition** again. (This process turns off the option.)

Project Navigator

Entity

Cyclone II: EP2C5F256C6

Cyclone II: EP2C5F2

Figure 1–7. Project Navigator Showing Design Partitions

#### Partition Name

When you create a partition, the Quartus II software automatically generates a name based on the instance name and hierarchy path. Change the name by double-clicking on the partition name in the Design Partitions window, or right-click the partition and click **Rename**. Alternately, you can right-click the partition in the Design Partitions window and click **Properties** to open the **Design Partition Properties** dialog box. On the **General** tab, enter the Name. By renaming your

partitions you can avoid referring to them by their hierarchy path, which can sometimes be long, especially important when using command-line commands or assignments. Partition names can be from 1 to 1024 characters in length, and must be unique. The name can only consist of alphanumeric characters, the pipe (  $\mid$  ), the colon ( : ), and the underscore (  $_{-}$  ) characters.

#### **Methodology for Creating Good Partitions**

There is an inherent tradeoff between compilation time and quality of results when you vary the number of partitions in a project. You can reduce this effect by ensuring that you follow a good methodology during the partitioning process. In any incremental compilation flow in which you can compile the source code for each partition during the partition planning phase, Altera recommends the following iterative flow:

- 1. Start with a complete design that is not partitioned and has no location or LogicLock assignments.
- 2. On the Processing menu, point to Start and click **Start Early Timing Estimate** to perform a placement and timing analysis estimate.



You must perform Analysis & Synthesis before performing an Early Timing Estimate. If incremental compilation is already turned on, you must also perform Partition Merge.

To run a full compilation instead of the Early Timing Estimate, on the Processing menu, click **Start Compilation**.

- Record the quality of results from the Compilation Report (f<sub>MAX</sub>, area, etc.).
- 4. Enable incremental compilation as described in "Preparing a Design for Incremental Compilation" on page 1–12.
- 5. Create design partitions as described in "Preparing a Design for Incremental Compilation" on page 1–12 using the guidelines in "Guidelines for Creating Good Design Partitions" on page 1–20.
- 6. Perform another Early Timing Estimate or full compilation.
- 7. Record the quality of results from the Compilation Report. If the quality of results is significantly worse than that obtained in the previous compilation in Step 3, repeat Step 5 through this step (Step 7) to change your partition assignments and use a different partitioning scheme.

8. Even if the quality of results is acceptable, you can repeat Step 5 through Step 7 by further dividing a large partition into several smaller partitions. Doing so improves compilation time in future incremental compilations. You can repeat this step until you achieve a good tradeoff point (that is, all critical paths are localized within partitions and the quality of results is not negatively affected, and the size of each partition is reasonable).

#### Guidelines for Creating Good Design Partitions

When planning your design, keep in mind the size and scope of each partition, and the likelihood that different parts of your design might change as your design develops.

Creating partitions prevents the compiler from performing optimizations across partition boundaries (Figure 1–8), allowing the software to synthesize and place each partition separately.

Figure 1–8. Effects of Partition Boundaries During Optimization



Since cross-boundary optimizations cannot occur when using partitions, the quality of results and performance of the design may decrease as the number of partitions increases. Having more partitions allows for greater reduction in compilation time, however, you should limit the number of partitions to prevent degradation of the quality of results. This effect is more pronounced when using full incremental compilation than when using incremental synthesis only, and can have more effect in a bottom-up methodology than a top-down methodology.

Altera recommends that you also observe the following important hierarchical design considerations when creating partitions:

Register all inputs and outputs of each partition. This helps avoid any delay penalty on signals that cross partition boundaries. At the very least, either the inputs or the outputs should be registered. The Statistics reports described in the "Partition Statistics Reports" section list the ports registered for each partition.



While this can be difficult in practice, greater adherence to this principle results in less timing degradation and area increase when using incremental flows. Registering lessens the need for the cross-partition optimizations that are prevented by partitioning.

- Minimize the number of paths that cross partition boundaries. If there are critical paths crossing between partitions, rework the partition(s) to avoid these inter-partition paths. The Statistics reports described in the "Partition Statistics Reports" section list the number of input and output ports for each partition.
- Ensure that the size of each partition is not too small, (for example, not less than 1,000 logic elements (LEs) or adaptive logic modules (ALMs)). The Statistics reports described in the "Partition Statistics Reports" section list the logic utilization of each partition.
- Minimize the number of unconnected ports at partition boundaries. This helps avoid errors in the Fitter during full incremental compilation where the netlist cannot be split. The Statistics reports described in the "Partition Statistics Reports" section list the number of unconnected input and output ports for each partition.
- Do not use tri-state signals or bidirectional ports on hierarchical boundaries, unless the port is connected directly to a top-level I/O pin on the device. If you use boundary tri-states in a lower-level block, synthesis pushes the tri-states through the hierarchy to the top-level to take advantage of the tri-state drivers on the output pins of the device.
  - In an incremental compilation flow, internal tri-states are supported only when all the destination logic is contained in the same partition, in which case Analysis & Synthesis implements the internal tri-state signals using multiplexing logic. For a bidirectional port that feeds a bidirectional pin at the top-level, all the logic that forms the bidirectional I/O cell must reside in the same partition.
- Note that logic is not synthesized or optimized across partition boundaries, which means any constant value (for example, a signal set to GND) is not propagated across partitions.
- You may have to perform some manual resource balancing across partitions if device resources are overused in the individual partitions. Refer to "Resource Balancing" on page 1–23 for details.
- You may have to perform some timing budgeting if paths that cross partition boundaries require further optimization. Refer to "Timing Budgeting" on page 1–25 for details.



For more guidelines on design hierarchical partitioning, refer to *Hierarchical Design Partitioning* in the *Design Recommendations for Altera Devices* chapter in volume 1 of the *Quartus II Handbook*.

#### **Partition Statistics Reports**

You can view statistics about design partitions in the Partition Merge Partition Statistics compilation report and the **Statistics** tab in the **Design Partitions Properties** dialog box.

The **Partition Statistics** page under the **Partition Merge** folder of the **Compilation Report** lists statistics about each partition. The statistics for each partition (each row in the table) include the number of logic cells it contains, as well as the number of input and output pins it contains and how many are registered or unconnected. This report is useful when optimizing your design partitions in a top-down compilation flow, or when you are compiling the top-level design in a bottom-up compilation flow, ensuring that the partitions meet the guidelines presented previously. Figure 1–9 shows the report window.



Figure 1-9. Partition Merge Partition Statistics Report

You can also view statistics about the resource and port connections for a particular partition on the **Statistics** tab of the **Design Partition Properties** dialog box. On the **Assignments** menu, click **Design Partitions Window**. Right-click on a partition and click **Properties** to open the dialog box (Figure 1–10).



Figure 1–10. Statistics Tab in the Design Partitions Properties Dialog Box

#### **Resource Balancing**

When using incremental compilation, the software synthesizes each partition separately, with no data about the resources used in other partitions. This means that device resources could be overused in the individual partitions during synthesis, and thus the design may not fit in the target device when the partitions are merged.

In a bottom-up design flow in which designers optimize their lower-level designs and export them to a top-level design, the software also places and routes each partition completely separately. In some cases, partitions can use conflicting resources when combined at the top level.

To avoid these effects, you may have to perform manual resource balancing across partitions.

#### RAM & DSP Blocks

In the regular synthesis flow, when DSP blocks or RAM blocks are overused, the Quartus II Compiler can perform resource balancing and convert some of the logic into regular logic cells (for example, LEs or ALMs). Without data about resources used in other partitions, it is possible for the logic in each separate partition to maximize the use of a particular device resource, such that the design does not fit once all the partitions are merged. In this case, you may be able to manually balance the resources by using the Quartus II synthesis options to control inference of megafunctions that use the DSP or RAM blocks. You can also use the MegaWizard® Plug-In Manager to customize your RAM or DSP megafunctions to use regular logic instead of the dedicated hardware blocks.



For more information on resource balancing when using Quartus II synthesis, refer to the *Megafunction Inference Control* section in the *Quartus II Integrated Synthesis* chapter in volume 1 of the *Quartus II Handbook*. For more tips on resource balancing and reducing resource utilization, refer to the appropriate *Resource Utilization Optimization Techniques* section in the *Area & Timing Optimization* chapter in volume 2 of the *Quartus II Handbook*.

Altera recommends using a LogicLock region for each partition to minimize the chance that the logic in more than one partition uses the same logic resource. However, there are situations in which partition placement may still cause conflicts at the top level. For example, you can design a partition one way in a lower level design (such as using an M-RAM memory block) and then instantiate it in two different ways in the top level (such as one using an M-RAM block and another using an M4K block). In this case, you can use a post-fit netlist only with no placement information to allow the software to refit the logic.

#### Global Routing Signals

Global routing signals can cause conflicts when multiple projects are imported into a top-level design. The Quartus II software automatically promotes high fan-out signals to use global routing resources available in the device. It is possible for lower-level partitions to use the same global routing resources, causing conflicts at the top level.

In addition, LAB placement depends on whether the inputs to the LCELLs within the LAB are using a global clock signal. Therefore, problems can occur if a design does not use a global signal in the lower-level design, but does use a global signal in the top-level design.

To avoid these problems, the project lead should determine which partitions will use particular global routing signals, then each designer of a lower-level partition can assign the appropriate global signals manually, and prevent other signals from using global routing resources. Use the Global Signal assignment set to a value of On or Off in the Assignment Editor to place a signal on a global routing line, or to prevent the signal from using a global routing line. If you want to disable the automatic global promotion performed in the Fitter, turn off the Auto Global Clock and Auto Global Register Control Signals. On the Assignments menu, click Settings. On the Fitter Settings page, click More Settings and change the settings to Off.

Alternately, to avoid problems when importing, direct the Fitter to discard the placement and routing of the imported netlist by setting the Fitter preservation level property of the partition to Netlist Only. With this option, the Fitter re-assigns all the global signals for this particular partition when compiling the top-level design.

If you are performing a bottom-up flow using the design partition scripts, then the software can automatically write the commands to pass global constraints and turn off the automatic options. Refer to "Generating Bottom-Up Design Partition Scripts for Project Management" on page 1–42 for details.

#### **Timing Budgeting**

If you optimize lower-level partitions and import them to the top level, any unregistered paths that cross between partitions are not optimized as an entire path. One way to reduce this effect is to ensure input and output ports of the partitions are registered whenever possible.

To ensure that the Compiler correctly optimizes the input and output logic in each partition, you may be required to perform some manual timing budgeting. For each unregistered timing path that crosses between partitions, make timing assignments on the corresponding I/O path in each partition to constrain both ends of the path to the budgeted timing delay. Timing budgets may be required for these I/O ports because when the Compiler optimizes each partition, it has no information about the placement of the logic that connects to that port. If the logic in one partition is placed far away from logic in another partition, the routing delay between the logic could lead to problems meeting the timing requirements. Assigning a timing budget for each part of the connection ensures that the Compiler optimizes the paths appropriately.

When performing manual timing budgeting, you can also use **Virtual Pin** assignments. By assigning location and timing constraints to the **Virtual Pins**, you can further improve the quality of the timing budget.

If you are performing a bottom-up flow using the design partition scripts, then the software can write virtual pin assignments and I/O timing budget constraints automatically. Refer to "Generating Bottom-Up Design Partition Scripts for Project Management" on page 1–42 for details.

#### Setting the Netlist Type for Design Partitions

The **Netlist Type** is a property of each design partition that allows you to specify the type of netlist or source file that the compiler should use as the input for each partition, as described in Table 1–2. This property determines which netlist is used by the Partition Merge stage in the next compilation. To view and modify the **Netlist Type**, on the Assignments menu, click **Design Partition Window**. Double-click the **Netlist Type** for an entry. Alternatively, right-click on an entry, click **Design Partition Properties**, then modify the **Netlist Type** on the **Compilation** tab.

| Table 1–2. Netlist Type Settings (Part 1 of 2) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Partition<br>Netlist Type                      | Quartus II Behavior for Partition During Compilation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| Source File                                    | Always compiles the partition using the associated design source file(s). You can use this netlist type to recompile a partition from the source code using new synthesis or fitter settings. If the partition has an associated imported netlist, compiling it with netlist type set to Source File removes the imported netlist.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| Post-Synthesis                                 | Preserves post-synthesis results for the partition and uses the post-synthesis netlist as long as the following conditions are true:  • A post-synthesis netlist is available from a previous synthesis  • No change has been made to the associated source files since the previous synthesis  Compiles the partition from the source files if there are source changes or if a post-synthesis netlist is not available. Changes to the assignments do not cause recompilation.  You can use this netlist type to preserve the synthesis results unless source files change, but refit the partition using any new fitter settings. If a partition has an associated imported netlist, this setting is not available.                                                                                                                                                                                                              |  |
| Post-Fit                                       | Preserves post-fit results for the partition and uses the post-fit netlist as long as the following conditions are true:  • A post-fit netlist is available from a previous fitting  • No change has been made to the associated source files since the previous fitting  Compiles the partition from the source files if there are source changes or if a post-fit netlist is not available. Changes to assignments do not cause recompilation. The Fitter Preservation  Level specifies what type of information is preserved from the post-fit netlist. You can use this netlist type to preserve the fitter results unless source files change. You can also use this netlist type to apply global optimizations, such as Physical Synthesis optimizations, to certain partitions while preserving the fitting results for other partitions.  If a partition has an associated imported netlist, this setting is not available. |  |
| Post-Fit (Strict)                              | Always preserves post-fit results for the partition. Uses the post-fit netlist even if changes have been made to the associated source files since the previous fitting. The <b>Fitter Preservation Level</b> specifies what type of information is preserved from the post-fit netlist. If a partition has an associated imported netlist, this setting is not available.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |

| Table 1–2. Netlist Type Settings (Part 2 of 2) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Partition<br>Netlist Type                      | Quartus II Behavior for Partition During Compilation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| Imported                                       | Compiles the design partition using a netlist imported from a Quartus II Exported Partition File (.qxp). The Fitter Preservation Level specifies what type of information is preserved from the imported netlist. The software does not modify or overwrite the original imported netlist during compilation. To preserve changes made to the imported netlist (such as movement of an imported LogicLock region), use the "Post-Fit (Import-based)" setting following a successful compilation with the imported netlist. For additional details, refer to "Exporting & Importing Partitions for Bottom-Up Design Flows" on page 1–35.  If a partition does not have an associated imported netlist, this setting is not available.                                                                                  |  |
| Post-Fit<br>(Import-based)                     | Preserves post-fit results for the partition and uses the post-fit netlist as long as the following conditions are true:  • A post-fit netlist is available from a previous fitting  • No change has been made to the associated imported netlist since the previous fitting Compiles the partition from the imported netlist if the imported netlist changes (which means it has been reimported) or if a post-fit netlist is not available. Changes to assignments do not cause recompilation. The <b>Fitter Preservation Level</b> specifies what type of information is preserved from the post-fit netlist. You can use this netlist type to preserve changes to the placement and routing of the imported netlist.  If a partition does not have an associated imported netlist, this setting is not available. |  |
| Empty                                          | Uses an empty placeholder netlist for the partition and uses virtual pins at the partition boundaries. You can use this netlist type to skip the compilation of a lower-level partition. For more details on the Empty setting, refer to "Empty Partitions" on page 1–28.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |

#### **Fitter Preservation Level**

The Fitter Preservation Level property specifies which information the compiler will use from a post-fit or imported netlist. The property is only available if the **Netlist Type** is set to **Post-Fit**, **Post-Fit** (**Strict**), **Imported**, or **Post-Fit** (**Import-based**).

On the Assignments menu, click **Design Partitions Window**. You can view and modify the **Fitter Preservation Level** by double-clicking an entry. You can also right-click and click **Properties**, then edit the **Fitter Preservation Level** on the **Compilation** tab.

Table 1–3 describes the Fitter preservation level settings.

| Table 1–3. Fitter Preservation Level Settings |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Fitter Preservation<br>Level                  | Quartus II Behavior for Partition During Compilation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| Placement                                     | Preserves the netlist atoms and their placement in the design partition. Re-routes the design partition. This setting saves significant compilation time because the Fitter does not need to re-fit the nodes in the partition. Note that the Fitter may need to modify the placement for timing or legality reasons. This setting might not be available if netlist type is set to <b>Imported</b> and the imported netlist does not contain placement data.                                                                                                                                               |  |
| Placement and<br>Routing                      | Preserves the netlist atoms and their placement and routing in the design partition. This setting minimizes compilation time. Note that the Fitter may need to modify the placement and routing for timing or legality reasons. This setting may not be available if netlist type is set to <b>Imported</b> and the imported netlist does not contain routing data.                                                                                                                                                                                                                                         |  |
| Netlist Only                                  | Preserves the netlist atoms of the design partition, but replaces and re-routes the design partition. Unlike a Post-Synthesis netlist, a Post-Fit netlist with the atoms preserved contains any fitter optimizations, for example, registers duplicated by Physical Synthesis during a previous Fitting. You can use this setting to preserve Fitter optimizations but allow the software to perform placement and routing again. You can also use this setting to reapply certain fitter optimizations (that is, physical synthesis) that would otherwise be impossible when the placement is locked down. |  |

#### **Empty Partitions**

To set the **Netlist Type** to **Empty**, on the Assignments menu, click **Design Partitions Window**, or double-click an entry, or right-click an entry and click **Design Partition Properties** and select **Empty**. This setting specifies that the Quartus II Compiler should use an empty placeholder netlist for the partition.

You can use the **Empty** setting to skip the compilation of a lower-level partition that is incomplete or missing from the top-level design. You can also use it if you want to compile only some partitions in the design, such as during optimization or if the compilation time is large for one partition and you want to exclude it.

When a partition **Netlist Type** is defined as **Empty**, virtual pins are created at the boundary of the partition. This means that the software temporarily maps I/O pins in the lower-level design entity to internal cells and not to pins during compilation.

Any sub-partitions below an empty partition are also considered empty, regardless of their settings.

You can use a design flow in which some partitions are set to **Empty** in a variation of a bottom-up design flow, where you develop pieces of the design separately and then combine them at the top-level at a later time. When you implement part of the design without information about the rest of the project, it is impossible for the Compiler to perform global placement optimizations. One way to reduce this effect is to ensure input and output ports of the partitions are registered whenever possible, as recommended in "Guidelines for Creating Good Design Partitions" on page 1–20.

When you set a design partition to **Empty**, a design file is required in Analysis & Synthesis to specify, at minimum, the port interface information so that it can connect the partition correctly to other logic and partitions in the design. If the design file is missing, you must create a wrapper file (called a black box or hollow-body file) that defines the design block and specifies the input, output, and/or bidirectional ports.

# Creating a Design Floorplan With LogicLock Location Assignments

Once you have partitioned the design, create floorplan location assignments for the design as discussed in this section when using the full incremental compilation flow to improve quality of results.

The simplest way to create a floorplan for a partitioned design is to create one LogicLock region per partition (including the top-level partition). Initially, leave each region with the default settings of Auto size and Floating location to allow the Quartus II software to determine the optimal size and location for the regions. Then, after compilation, back-annotate the Fitter-determined size and location properties. Check the quality of results obtained for your floorplan location assignments and make changes to the regions as needed.



For more information on why creating a design floorplan is important, refer to "The Importance of Floorplan Location Assignments in Incremental Compilation" on page 1–32.

To create a LogicLock region for each design partition, use the following general methodology:

 On the Assignments menu, click Design Partitions Window and ensure that all partitions have their Netlist Type set to Source or Post-Synthesis. If the Netlist Type is set to Post-Fit, floorplan location assignments are not used when recompiling the design.

- Create a LogicLock region for a partition using one of the following methods:
  - On the Assignments menu, click LogicLock Regions Window.
     Drag an individual partition from the Design Partitions
     Window and drop it in the <<new>> row of the LogicLock
     Regions Window.
  - Under Compilation Hierarchy in the Project Navigator, right-click an instance that is denoted as a partition and click Create New LogicLock Region.
- Repeat Step 2 for each partition, including the top-level entity, which is automatically considered a partition.
- 4. On the Processing menu, point to Start and click **Start Early Timing Estimate** to place auto-sized, floating-location LogicLock regions.



You must perform Analysis & Synthesis and Partition Merge before performing an Early Timing Estimate.

To run a full compilation instead of the Early Timing Estimate, on the Processing menu, click **Start Compilation**.

- On the Assignments menu, click LogicLock Regions Window, and click on each LogicLock region while holding the Ctrl key to select all regions (including the top-level region).
- Right-click on the last selected LogicLock region, and click Properties.
- On the Location tab, click Back-annotate Origin and Lock to back-annotate the Fitter-determined size and location properties, then click OK.



It is important that you use the Fitter-chosen locations only as a starting point to make the regions of a fixed size and location. Regions with fixed size and location yield better  $f_{\text{MAX}}$  than auto-sized regions on average.

Do not back-annotate the contents of the region, just save the location and size using the **Back-annotate Origin and Lock** command. Placement is preserved through the use of the post-fit netlist instead of back-annotated content assignments.

8. If required, modify the size and location via the **LogicLock Regions Window** or the **Timing Closure Floorplan**.

- On the Processing menu, point to Start and click Start Early Timing Estimate to estimate the timing performance of your design with these LogicLock regions.
- 10. Repeat steps 8 and 9 until you are satisfied with the quality of results for your design floorplan. On the Processing menu, click **Start Compilation** to run a full compilation.

#### Recommendations for Creating Good Floorplan Location Assignments

If your design contains hierarchical partitions (that is, parent-child relationships between partitions), you can create hierarchical LogicLock regions to ensure that the logic in the child partition is physically placed inside the LogicLock region for the parent partition. This can be useful when the parent partition does not contain registers at the boundary with the lower-level child partition. To create a hierarchical relationship between regions in the <code>LogicLock Regions Window</code>, drag and drop the child region to the parent region.

If resource utilization is low, you may enlarge the Fitter-chosen region. Doing so usually improves the final results because it gives the Fitter more freedom to place additional logic added to the partition during future incremental compilations.

If the quality of results has worsened after creating floorplan location assignments, try to improve the floorplan by enlarging the area of each region using the following guidelines:

- Ideally, the entire device should be covered by LogicLock regions. You may move the region origins to satisfy this requirement, but Altera recommends preserving the Fitter-determined relative placement of the regions.
- Regions should not overlap in the device floorplan.
- Give more area to regions that are densely populated.



For more information on making and editing LogicLock regions, consult the *LogicLock Design Methodology* chapter in volume 2 of the *Quartus II Handbook*.

Excluding or Filtering Certain Device Elements (Such as RAM or DSP Blocks)

If your design contains memory or digital signal processing (DSP) elements, you may want to exclude these elements from the LogicLock region. You can use a LogicLock resource filter to prevent elements of certain types from being assigned to a region. Note that the filter does not

prevent them from being placed inside the region boundaries unless the region's "Reserved" property is set to on. Defining a resource filter instructs the Fitter that certain blocks are not required to be inside a region. Resource filters are useful in cases where it is difficult to place rectangular regions for design blocks that contain memory and DSP elements, because of their placement in columns throughout the device floorplan. Filtering these elements can help to resolve no-fit errors that are caused by regions spanning too many resources, especially for designs that are memory and/or DSP-intensive. If desired, you can also create separate regions for the memory or DSP blocks, which can be shaped to accommodate the columns in the device to control the placement of those design elements.

To view any resource filters, right-click in the LogicLock Regions window and click **Properties**. In the **LogicLock Region Properties** dialog box, View the **Excluded Resources** column in the **Members** box. To set up a resource filter, highlight the appropriate region member and click **Edit Excluded Resources**, then turn on the design element types to be excluded from the region. You can choose to exclude combinational logic or registers from logic cells, or any of the sizes of TriMatrix™ memory blocks, or DSP blocks.



For more information on excluding nodes from LogicLock regions, consult the *LogicLock Design Methodology* chapter in volume 2 of the *Ouartus II Handbook*.

#### The Importance of Floorplan Location Assignments in Incremental Compilation

Floorplan location planning is very important for a design that uses full incremental compilation, because it helps to avoid the situation that arises when the Fitter is directed to place or replace a portion of the design in an area of the device where most resources have already been claimed. In this case, the placement of the post-fit netlists of other modules forces the Fitter to place the new portion of the design in the empty parts of the device. There are two immediate disadvantages to this situation. First, the Fitter must work harder because of the higher number of physical constraints, and therefore compilation time probably increases. Second, the quality of results often decreases, sometimes dramatically, because the placement of the target module is now scattered throughout the device.

Figures 1–11 and 1–12 illustrate the problems associated with refitting designs that do not have floorplan location assignments. Figure 1–11 shows the initial placement of a four-partition design (**P1–P4**) without floorplan location assignments. The second part of the figure shows the

situation if a change occurs to **P3**. After removing the logic for the changed partition, the Fitter must replace and reroute the new logic for **P3** using the white space shown in the figure.

Figure 1–11. Representation of Device Floorplan without Location Assignments



Performing this placement is very difficult. The Fitter may not be able to find any legal placement for the logic in partition **P3**, even if it was able to do so in the initial compilation. If the Fitter does find a legal placement, the results are probably sub-optimal.

Figure 1–12 shows the initial placement of a four-partition design with floorplan location assignments made by the user, and the situation after partition **P3** is removed in this case.

Figure 1–12. Representation of Device Floorplan with Location Assignments



This placement presents a much more reasonable task to the Fitter and yields better results than the previous case that does not have floorplan location assignments.

#### Taking Advantage of the Early Timing Estimator

The general methodology steps described above take advantage of the Early Timing Estimator to enable quick compilations of the design while creating assignments. The Early Timing Estimator feature provides a timing estimate for a design as much as 45 times faster than running a full compilation, yet estimates are, on average, within 11 percent of final design timing. You can use the Timing Closure Floorplan editor to view the "placement estimate" created by this feature, identify critical paths, and if necessary, add or modify floorplan constraints. You can then rerun the Early Timing Estimator to quickly assess the impact of any floorplan location assignments or logic changes, enabling rapid iterations on design variants to help you find the best solution.



For information on timing analysis and early timing estimation, refer to the *Classic Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

#### Criteria for Successful Partition & Floorplan Schemes

The end results of design partitioning and floorplan creation differ from design to design. However, it is important to evaluate your results to ensure that your scheme is successful. Compare the results before creating your floorplan location assignments to the results after doing so, and consider using another scheme if any of the following guidelines are not met:

- No degradation in  $f_{MAX}$  should be observed after the design is partitioned and floorplan location assignments are created. In many cases, a slight increase in  $f_{MAX}$  is possible.
- The area increase should be no more than 5 percent after the design is partitioned and floorplan location assignments are created.
- The time spent in the routing stage should not significantly increase.

The amount of compilation time spent in the routing stage is reported in the Messages window with an Info message indicating the elapsed time for Fitter routing operations. If you notice a dramatic increase in routing time, the floorplan location assignments may be creating substantial routing congestion. In this case, decrease the number of LogicLock regions. Doing so typically reduces the compilation time in subsequent incremental compilations, and may also improve design performance.

To help you modify your LogicLock regions, you can identify areas of congested routing in your design using the Timing Closure Floorplan. On the Assignments menu, click **Timing Closure Floorplan** and turn on **Show Routing Congestion**. This feature is available only when you click **Field View** on the View menu.



For details on using the Timing Closure Floorplan, refer to the *Timing Closure Floorplan* chapter in volume 2 of the *Quartus II Handbook*.

# Exporting & Importing Partitions for Bottom-Up Design Flows

The bottom-up flow refers to the design methodology in which a project is first divided into smaller sub-designs that are implemented as separate projects, potentially by different designers. The compilation results of these lower-level projects are then exported and given to the designer (or the project lead) who is responsible for importing them into the top-level project to obtain a fully functional design.

There are at least two benefits associated with a bottom-up design flow:

- It facilitates team-based development.
- It permits the reuse of compilation results from another project, with the ultimate goals of performance preservation and compilation time reduction.

A bottom-up design flow also has some potential drawbacks that require careful planning:

- It may be difficult to achieve timing closure for the full design, because you compile the lower-level sub-modules independently without any information about each other. This problem may be avoided by careful timing budgeting and special design rules such as always registering the ports at the module boundaries.
- For the same reason, resource budgeting and allocation may be needed to avoid resource conflicts and overuse. Floorplan creation is typically very important in a bottom-up flow.

In a bottom-up design flow, the top-level project lead can do much of the design planning, and then pass constraints on to the designers of lower-level blocks. The bottom-up design partition scripts generated by the Quartus II software can make it easier to plan a bottom-up design, and limit the difficulties that can arise when integrating separate designs.

### Preparing the Top-Level Design for a Bottom-Up Incremental Compilation Methodology

To set up your design for bottom-up incremental compilation, use the following general steps:

 Create a top-level project that will be compiled by the project lead and will eventually incorporate the entire design. The top-level design file must include the top-level entity that instantiates all the lower-level subdesign that you plan to compile in separate Quartus II projects and import as separate design partitions.

- 2. In your top-level project, include a wrapper design file for each subdesign partition that defines at least the port interface of the subdesign. Analysis & Elaboration requires this wrapper file (also known as a "stub" or "black box" file) to connect all the separate design partitions at the top level. The wrapper file does not have to contain any logic definition, just the module or entity and architecture, and the port list for the design block.
- 3. Create all global assignments, including the device assignment, pin location assignments, and timing assignments, so that the final design meets its requirements. Lower-level project designers can add their own constraints for their partitions as needed, and later export them to top-level, but the basic constraints can be passed down from the top-level to avoid any conflicts and ensure that lower-level projects use the correct assignments.
- 4. Set up the top-level design with design partitions, turn on incremental compilation, and create a design floorplan using LogicLock assignments. Follow the steps in "Preparing a Design for Incremental Compilation" on page 1–12.
- 5. Ensure that you allocate device resources appropriately, as described in "Resource Balancing" on page 1–23.
- 6. Optionally, you can use the Quartus II software to generate bottom-up design partition scripts that help with design planning and project management at the top level of the project. Refer to "Generating Bottom-Up Design Partition Scripts for Project Management" on page 1–42 for details.

#### **Exporting a Partition to be Used in a Top-Level Project**

Each lower-level subdesign is compiled as a separate Quartus II project. In each project, use the following guidelines to improve the exporting and importing process:

- Ensure that the LogicLock region uses only the resources allocated by the top-level project lead.
- Ensure that you know which clocks should be allocated to global routing resources so that there are no resource conflicts in the top-level design.
  - Set the Global Signal assignment to On for the high fan-out signals that should be routed on global routing lines.
  - To avoid other signals being placed on global routing lines, on the Assignments menu, click Settings and turn off Auto Global Clock and Auto Global Register Controls under More Settings on the Fitter page of the Settings dialog box.

- Alternately, you can set the Global Signal assignment to Off for signals that should not be placed on global routing lines.
   Placement for LABs depends on whether the inputs to the logic cells within the LAB use a global clock, so you may encounter problems if signals do not use global lines in the lower level design but use global routing in the top level.
- Use the Virtual Pin assignment to indicate pins of a subdesign that do not drive pins in the top-level design. This is critical when a subdesign has more output ports than the number of pins available in the target device. Using virtual pins also helps optimize crosspartition paths for a complete design by enabling you to provide more information about the subdesign ports, such as location and timing assignments.
- Because subdesigns are compiled independently without any information about each other, you should provide more information about the timing paths that may be affected by other partitions in the top-level design. You can apply location assignments for each pin to indicate where the port connection will be located after it is incorporated in the top-level design. You can also apply timing assignments to the I/O ports of the subdesign to perform timing budgeting as described in "Timing Budgeting" on page 1–25.

When your subdesign partition has been compiled using these guidelines, and is ready to be incorporated into the top-level design, export a subdesign as a partition using the following steps:

- 1. In the subdesign project, on the Project menu, click Export Project as Design Partition. The Export Project as Design Partition dialog box opens (Figure 1–13).
- In the Export file box, type the name of the Quartus II Exported Partition file (.qxp). By default, the directory path and file name are the same as the current project.
- 3. Under **Netlist to export**, select either **Post-fit netlist** or **Post-synthesis netlist**. The default is **Post-Fit netlist**.
- 4. To automatically create a new version of the Quartus II Exported Partition file after each subsequent compilation, turn on **Always perform exportation following compilation**.
- Click OK. The Quartus II software creates the Quartus II Exported Partition file in the specified directory.

Export Project as Design Partition

You can export the current compilation result and import it into the design partition of another project

Export file:

taps: qxp ...

Netlist to export

Post-fit netlist

Post-synthesis netlist

Always perform exportation following compilation

OK Cancel

Figure 1–13. Export Project as Design Partition Dialog Box

#### Importing a Lower-Level Partition Into the Top-Level Project

The import process involves importing the design netlist from the Quartus II Exported Partition file and adding the netlist to the database for the top-level project. Importing also filters the assignments from the subdesign and creates the appropriate assignments in the top-level project.

To import a subdesign partition into a top-level design:

- In the top-level project, on the Project menu, click Import Design Partition. Alternately, right-click on the partition that you want to import in the Design Partitions window and click Import Design Partition, this opens the Import Design Partition dialog box.
- In the Partition(s) box, click browse to select the desired partition.
   To browse for a partition, highlight the partition name in the Select Partition(s) dialog box and use the appropriate buttons to select or deselect the desired partition(s).



Note that you can select multiple partitions if your top-level design has multiple instances of the subdesign partition and you want to use the same imported netlist.

3. Under **Import file**, type the name of the Quartus II Exported Partition file or browse for the file that you want to import into the selected partition. Note that this file is required only during importation, but is not used during subsequent compilations.



If you have already imported the Quartus II Exported Partition file for this partition at least once, you can use the same location as the previous import instead of specifying the file name again. To do so, turn on Reimport using the latest import files at previous locations. This option is especially useful when you want to import the new Quartus II Exported Partition files for several partitions that you have already imported at least once. You can select all the partitions to be imported in the Partition(s) box and then use the Reimport using latest import files at previous locations option to import all partitions using their previous locations, without specifying individual file names.

- To view the contents of the selected Quartus II Exported Partition file, click Load Properties. The properties displayed include the Netlist Type, Entity name, Device and statistics about the partition size and ports.
- 5. Click Advanced Import Settings and make selections, as appropriate, to control how assignments and regions are integrated from a subdesign into a top-level design partition. During importation, some regions may be resized or slightly moved. Click OK to apply the settings.



For more information about the advanced settings, refer to "Importing Assignments & Advanced Import Settings" on page 1–39.

6. In the **Import Design Partition** dialog box, click **OK** to start importation. The specified Quartus II Exported Partition file is imported into the database for the current top-level project.

#### **Importing Assignments & Advanced Import Settings**

When you import a subdesign partition into a top-level design, the software sets certain assignments by default and also imports relevant assignments from the subdesign into the top-level design.

Design Partition Properties After Importing

When you import a subdesign partition, the import process sets the partition's Netlist Type to **Imported**.

If you compile the design and want to make and preserve changes to the place-and-route results, use the **Post-Fit (Import-based)** Netlist Type on the subsequent compilation. To discard an imported netlist and recompile

from source code, simply compile the partition with netlist type set to **Source File** and be sure to include the relevant source code with the top-level project.

The import process sets the partition's Fitter Preservation Level to the setting with the highest degree of preservation supported by the imported netlist. For example, if a post-fit netlist is imported with placement information, the level is set to **Placement**, but you can change it to the **Netlist Only** value.

Refer to "Setting the Netlist Type for Design Partitions" on page 1–26 for details about the Netlist Type and Fitter Preservation Level setting.

#### Importing Design Partition Assignments Within the Subdesign

Design partitions defined within the subdesign project are currently not imported to the top-level.

#### Importing LogicLock Assignments

LogicLock regions are set to a fixed size when imported. If you instantiate multiple instances of a subdesign in the top-level design, the imported LogicLock regions will be set to a Floating location. Otherwise, they are set to a Fixed location. You can change the location of LogicLock regions after they are imported, or change them to a Floating location to allow the software to place each region but keep the relative locations of nodes within the region wherever possible. If you want to preserve changes made to a partition after compilation, use the Netlist Type **Post-Fit** (**Import-Based**).

The LogicLock Member State assignment is set to Locked to signify that it is a preserved region.

LogicLock back-annotation and node location data is not imported because the Quartus II Exported Partition file contains all the relevant placement information. Altera strongly recommends that you do not add to or delete members from an imported LogicLock region.

#### Importing Other Instance Assignments

All instance assignments are imported, with the exception of design partition assignment, and LogicLock assignments, as described previously.

#### Importing Global Assignments

Global assignments are not imported. The project lead should make global assignments, such as clock settings in the top-level design.

#### Advanced Import Settings

The **Advanced Import Settings** dialog box, shown in Figure 1–15, allows you to specify the options in this section that control how assignments and regions are integrated and how to resolve assignment conflicts when importing a subdesign partition into a top-level design. The following sub-sections describe each of these options.

Figure 1-14. Advanced Import Settings Dialog Box



#### Allow Creation of New Assignments

Allows the import command to add new assignments from the imported project to the top-level project.

When this option is turned off, it imports updates to existing assignments, but no new assignments are allowed.

#### Promote Assignments to all Instances of the Imported Entity

Converts and promotes entity-level assignments from the subdesign into instance-level assignments in the top-level design.

#### Assignment Conflict Resolution: LogicLock Regions

Choose one of the following options to determine how to handle conflicting LogicLock assignments (that is, subdesign assignments that do not match the top-level assignments):

- Always replace regions in the current project (default)—Deletes existing regions and replaces them with the new subdesign region. Note that any changes made to the LogicLock region after the assignments were imported are also deleted.
- Always update regions in the current projects—Overwrites existing region assignments to reflect any new subdesign assignments, with the exception of the LogicLock Origin in case the project lead has made floorplan location assignments in the top-level design.
- Skip conflicting regions—Ignores and does not import subdesign assignments that conflict with any assignments that exist in the top-level design.

#### Assignment Conflict Resolution: Other Assignments

Choose one of the following options to determine how to handle conflicts with other types of assignments (that is, the subdesign assignments do not match the top-level assignments):

- Always replace assignments in the current project (default)— Overwrites or updates existing instance assignments with the new subdesign assignments.
- Skip conflicting assignments—Ignores and does not import subdesign assignments that conflict with any assignments that exist in the top-level design.

### Generating Bottom-Up Design Partition Scripts for Project Management

The bottom-up design partition scripts automate the process of transferring top-level project information to lower-level modules. The software provides a project manager interface for managing resource and timing budgets in the top-level design. This makes it easier for designers of lower-level modules to implement the instructions from the project lead, and avoid conflicts between projects when importing and incorporating the projects into the top-level design. This helps reduce the need to further optimize the designs after integration, and improves overall designer productivity and team collaboration.



Generating bottom-up design partition scripts is optional in any bottom-up design methodology.

In a typical bottom-up design flow, the project lead must perform some or all of the following tasks to ensure successful integration of the sub-projects:

- Manually determine which assignments should be propagated from the top-level to the bottom-levels. This requires detailed knowledge of which Quartus II assignments are needed to set up low-level projects.
- Manually communicate the top-level assignments to the low-level projects. This requires detailed knowledge of Tcl or other scripting languages to efficiently communicate project constraints.
- Manually determine appropriate timing and location assignments that will help overcome the limitations of bottom-up design. This requires examination of the logic in the lower levels to determine appropriate timing constraints.
- Perform final timing closure and resource conflict avoidance at the top level. Because the low-level projects have no information about each other, meeting constraints at the lower levels does not guarantee they will be met when integrated at the top-level. It then becomes the project lead's responsibility to resolve the issues, even though information about the low-level implementation may not be available.

Using the Quartus II feature that generates bottom-up design partition scripts from the top level of the design makes these tasks much easier and eliminates the chance of error when communicating between the project lead and lower-level designers. Partition scripts pass on assignments made in the top-level design, and create some new assignments that guide the placement and help the lower-level designers see how their design connects to other partitions.

Generate design partition scripts after a successful compilation of the top-level design. On the Project menu, click **Generate Bottom-Up Design Partition Scripts**. The design can have empty partitions as placeholders for lower-level blocks, and you can perform an Early Timing Estimation instead of a full compilation to reduce compilation times.

The following subsections describe the information that you can choose to be included in the bottom-up design partition Tcl scripts. Use the options in the **Generate Bottom-Up Design Partition Scripts** dialog box to choose which types of assignments you want to pass down and create in the lower-level partition projects.

For information about current limitations in the bottom-up partition scripts, refer to the "Bottom-Up Design Partition Script Limitations" on page 1–61.

#### Project Creation

You can use the **Create lower-level project if one does not exist** option for the partition scripts to create lower level projects if they are required. The Quartus II Project File for each lower-level project has the same name as the entity name of its corresponding design partition.

With this project creation feature, the scripts work by themselves to create a new project, or can be sourced to make assignments in an existing project.

#### Assignments from the Top-Level Design

By default, any assignments made at the top-level (not including default assignments or project information assignments) are passed down to the appropriate low-level projects in the scripts. The software uses the assignment variables and determines the logical partition(s) to which the assignment pertains (this includes global assignments, instance assignments, and entity-level assignments). The software then changes the assignments so that they are syntactically valid in a project with its target partition's logic as the top-level entity.

The scripts process wildcard assignments correctly, provided there is only one wildcard. Assignments with more than one wildcard are ignored and warning messages are issued.

Use the options described in the following section to specify which of the following types of assignments you would like passed down to the lower-level projects:

- **Timing assignments**—When this option is turned on, all global timing assignments for the lower-level projects are included in the script, including  $t_{CO}$ ,  $t_{SU}$ , and  $t_{MAX}$  constraints. It may also optionally include timing constraints on internal partition connections.
- Design partition assignments—When this option is turned on, script assignments related to design partitions in the lower-level projects are included, as well as assignments associated with LogicLock regions.
- Pin location assignments—When this option is turned on, all pin location assignments for lower-level project ports that connect to pins in the top-level design are included in the script, controlling the overuse of I/Os at the top-level during the integration phase and preserving placement.

#### Virtual Pin Assignments

When Create virtual pins at low-level ports connected to other design units is turned on, the Quartus II software searches partition netlists and identifies all ports that have cross-partition dependencies. For each lower-level project pin associated with an internal port in another partition or in the top-level project, the script generates a virtual pin assignment, ensuring more accurate placement, because virtual pins are not directly connected to I/O ports in the top-level project. These pins are removed from a lower-level netlist when it is imported into the top-level design.

#### Virtual Pin Timing & Location Assignments

One of the main issues in bottom-up design methodologies is that each individual design block includes no information about how it is connected to other design blocks. If you turn on the option to write virtual pin assignments, you can also turn on options to constrain these virtual pins to achieve better timing performance once the lower-level partitions are integrated at the top level.

When Place created virtual pins at location of at top-level source/sink is turned on, the script includes location constraints for each virtual pin created. Virtual output pins are assigned to the location of the connection's destination in the top-level project, and virtual input pins are assigned to the location of the connection's source in the top-level project. Note that if the top-level design uses Empty partitions, the final location of the connection is not known but the pin is still assigned to the LogicLock region that contains its source or destination.

As a result, these virtual pins are no longer placed inside the LogicLock region of the lower-level project, but at their location in the top-level design, eliminating resource consumption in the lower-level project and providing more information about lower-level projects and their port dependencies. These location constraints are not imported into the top-level project.

When Add maximum delay to/from created virtual pins is turned on, the script includes a timing constraint for each virtual pin created. The value you enter in the dialog box is the maximum delay allowed to and from all paths between virtual pins to help meet the timing requirements for the complete design. The software uses the OUTPUT\_MAX\_DELAY assignment or INPUT\_MAX\_DELAY assignment to apply the constraint.

This option allows the project lead to specify a general timing budget for all lower-level internal pin connections. The lower-level designer can override these constraints by applying individual node-level assignments on any specific pin as needed.

#### LogicLock Region Assignments

When **Copy LogicLock region assignments from top-level** is turned on, the script includes assignments identifying the LogicLock assignment for the partition.

The script can also pass assignments to create the LogicLock regions for all other partitions. When **Include all LogicLock regions in lower-level projects** is turned on, the script for each partition includes all LogicLock region assignments for the top-level project and each lower-level partition, revealing the floorplan for the complete design in each partition. Regions that do not belong to other partitions contain virtual pins representing the source and destination ports for cross-partition connections. This allows each designer to more easily view the connectivity between their partition and other partitions in the top-level design, and helps ensure that resource conflicts at the top-level are minimized.

When **Remove existing LogicLock regions from lower-level projects** is turned on, the script includes commands to remove LogicLock regions defined in the lower-level project prior to running the script. This ensures that LogicLock regions not part of the top-level project do not become part of the complete design, and avoids any location conflicts by ensuring lower-level designs use the LogicLock regions specified at the top level.

#### Global Signal Promotion Assignments

To help prevent conflicts in global signal usage when importing projects into the top-level design, you can choose to write assignments that control how signals are promoted to global routing resources in the lower-level partitions. These options can help resource balancing of global routing resources.

When **Promote top-level global signals in lower-level projects** is turned on, the Quartus II software searches partition netlists and identifies global resources, including clock signals. For the relevant partitions, the script then includes a global signal promotion assignment, providing information to the lower-level projects about global resource allocation.

When **Disable automatic global promotion in lower-level projects** is turned on, the script includes assignments that turn off all automatic global promotion settings in the lower-level projects. These settings include: the Auto Global Memory Control Signals logic option, output enable logic options, and clock and register control promotions. If you select the **Disable automatic global promotion in lower-level projects** option in conjunction with the **Promote top-level global signals in** 

**lower-level projects** option, you can ensure that only signals promoted to global resources in the top-level are promoted in the lower-level projects.

#### Makefile Generation

Makefiles allow you to use 'make' commands to ensure that a bottom-up project is up-to-date if you have a make utility installed on your computer. The **Generate makefiles to maintain lower-level and top-level projects** option creates a makefile for each design partition in the top-level design, as well as a master makefile that can run the lower-level project makefiles. The Quartus II software places the master makefiles in the top-level directory, and the partition makefiles in their corresponding lower-level project directories.

Makefiles use the directory locations generated using the **Create lower-level project if one does not exist** option. If you created your lower-level projects without using this option, you must modify the variables at the top of the makefile to specify the directory location for each lower-level project.

To run the makefiles, use a command such as make <code>-f</code> <code>master\_makefile.mak</code> from the script output directory. The master makefile first runs each lower-level makefile, which sources its Tcl script and then generates a Quartus II Exported Partition file to export the project as a design partition. Next, the top-level makefile is run which specifies these newly generated Quartus II Exported Partition files as the import files for their respective partitions in the top-level project. The top-level makefile then imports the lower-level results and performs a full compilation, producing a final design.

To exclude a certain partition from being compiled, edit the EXCLUDE\_FLAGS section of **master\_makefile.mak** according to the instructions in the file, and specify the appropriate options. You can also exclude some partitions from being built, exported, or imported using make commands. To exclude a partition, run the makefile using a command such as the one for the GNU make utility shown in the following example:

gnumake -f master\_makefile.mak exclude\_<partition directory>=1 +

This command instructs that the partition whose output files are in <partition directory> are not built. Multiple directories can be excluded by adding multiple exclude\_cpartition directory> commands.
Command-line options override any options in the makefile.

Another feature of makefiles is the ability to have the master makefile invoke the low-level makefiles in parallel on systems with multiple processors. This option can help designers working with multiple CPUs greatly improve their compilation time. For the GNU make utility, add the -j < N > flag to the make command. The value < N > is the number of processors that can be used to run the build.

# User Scenarios— Incremental Compilation Application Examples

To better illustrate the applications and behavior of the full incremental compilation flow, the following section presents several possible user scenarios. All scenarios assume you have set up the project to use the full incremental compilation flow, using the steps described in "Preparing a Design for Incremental Compilation" on page 1–12. These scenarios are divided into two sections:

- Top-Down Incremental Design Flows
- Bottom-Up Design Flows

#### **Top-Down Incremental Design Flows**

There are four top-down incremental design flow examples:

- Scenario 1—Changing a Source File for One of Multiple Partitions in a Top-Down Compilation Flow
- Scenario 2—Optimizing the Placement for One of Multiple Partitions in a Top-Down Compilation Flow
- Scenario 3—Preserving One Critical Partition in a Multiple-Partition Design in a Top-Down Compilation Flow
- Scenario 4—Placing All but One Critical Partition in a Multiple-Partition Design in a Top-Down Compilation Flow

Scenario 1—Changing a Source File for One of Multiple Partitions in a Top-Down Compilation Flow

Background: You have just performed a lengthy, complete compilation of a design that consists of multiple partitions. An error is found in the HDL source file for one partition and it is being fixed. Because the design is currently meeting timing requirements and the fix is not expected to affect timing performance, it makes sense to compile only the affected partition and preserve the rest of the design.

Perform the following steps to update the single source file:

- 1. Apply and save the fix to the HDL source file.
- 2. On the Assignments menu, click **Design Partition Window**.

- 3. For the partitions that should be preserved, change the Netlist Type to Post-Fit. You can set the Fitter Preservation Level to either Placement or Placement and Routing. For the partition that contains the fix, you can change the netlist type to Source File. Making the Source File setting is optional because the Quartus II software recompiles partitions if changes are detected in a source file.
- 4. Click **Start Compilation** to incrementally compile the fixed HDL code. This compilation should take much less time than the initial full compilation.
- Run simulation again to ensure that the bug is fixed, and use the Timing Analyzer report to ensure that timing results have not degraded.

Scenario 2—Optimizing the Placement for One of Multiple Partitions in a Top-Down Compilation Flow

Background: You have just performed a lengthy full compilation of a design that consists of multiple partitions. The Timing Analyzer reports that the  $f_{MAX}$  timing requirement is not met. After some analysis, you believe that timing closure can be achieved if placement can be improved for one particular partition. You have at least three optimization techniques in mind: raising the Placement Effort Multiplier, enabling Physical Synthesis, and running the Design Space Explorer. Because these techniques all involve significant compilation time, it makes sense to apply them (or just one of them) to only the partition in question.

Perform the following steps to raise the Placement Effort Multiplier or enable Physical Synthesis:

- 1. On the Assignments menu, click **Design Partition Window**.
- 2. For the partition in question, set the **Netlist Type** to **Post-Synthesis**. This causes the partition to be placed and routed with the new Fitter settings (but not resynthesized) during the next compilation.
- 3. For the remaining partitions (including the top-level entity), set the Netlist Type to Post-Fit. Set the Fitter Preservation Level to Placement to allow for the most flexibility during routing. To reduce compilation time further, use the Placement and Routing setting. These partitions are preserved during the next compilation.
- 4. Apply the desired optimization settings.

5. Click **Start Compilation** to incrementally compile the design with the new settings. During this compilation, the Partition Merge stage automatically merges the post-synthesis netlist of the critical partition with the post-fit netlists of the remaining partitions. This "merged" netlist is fed to the Fitter. The Fitter then refits only one partition. Since the effort is reduced as compared to the initial full compilation, the compilation time is also reduced.

To use Design Space Explorer, perform the following steps:

- 1. Repeat steps 1–3 of the previous set of steps.
- 2. Save the project and run Design Space Explorer.

Scenario 3—Preserving One Critical Partition in a Multiple-Partition Design in a Top-Down Compilation Flow

Background: Prior to any compilation, you have some insight into which partition will be the most critical (in terms of timing) after placement and routing. To help achieve timing closure, you decide to use the following compilation flow.

The critical partition is placed and routed by itself, with all optimizations turned on (manually or through Design Space Explorer). After timing closure is achieved for this partition, its content and placement are preserved and the remaining partitions are fit with normal or reduced optimization levels so that the compilation time can be reduced.



This flow generally works only if the critical path is contained inside the partition in question. This is one reason why both the inputs and outputs of each partition should be registered.

For this scenario, perform the following steps:

- 1. Perform partitioning and floorplan location assignment creation.
- For the partition expected to be critical, on the Assignments menu, click Design Partition Window and set Netlist Type to Source File.
- 3. For the remaining partitions (other than any direct or indirect parents of the critical one), set the **Netlist Type** to **Empty**.
- 4. Click **Start Compilation** to compile with the desired optimizations turned on, or use Design Space Explorer.

- 5. Check the Timing Analyzer report to ensure that the timing requirements are met. If so, proceed to step 6. Otherwise, repeat step 4 and step 5 until the requirements are met.
- In the Design Partition Window, set the Netlist Type to Post-Fit for the critical partition. Set the Fitter Preservation Level to Placement and Routing to preserve the results.
- Change the Netlist Type from Empty to Source File for the remaining partitions.
- 8. Turn off the optimizations set in step 4, and compile the design. Turning off the optimizations at this point does not affect the fitted partition, because its Netlist Type is set to **Post-Fit**.
- 9. Check the Timing Analyzer report to ensure that the timing requirements are met. If not, make design or option changes and repeat step 8 and step 9 until the requirements are met.



This flow is similar to a bottom-up design flow in which a module is implemented separately and is merged into the rest of the design afterwards. Refer to "Empty Partitions" on page 1–28 for more information about potential issues. Ensure that if there are any partitions representing a design file that is missing from the project, you create a placeholder wrapper file that defines the port interface.

Scenario 4—Placing All but One Critical Partition in a Multiple-Partition Design in a Top-Down Compilation Flow

Background: Prior to any compilation, you have some insight into which partition will be the most critical (in terms of timing) after placement and routing. To help achieve timing closure, you decide to use the following compilation flow.

Only the non-critical partitions are placed and routed initially, using floorplan location assignments. These non-critical partitions are then preserved when the critical partition is introduced into the Fitter, with various optimizations turned on (manually or through Design Space Explorer).

For this scenario, perform the following steps:

- 1. Perform partitioning and floorplan creation.
- 2. For the partition expected to be critical, on the Assignments menu, click **Design Partition Window** and set the **Netlist Type** to **Empty**.

- 3. For the remaining partitions, set the **Netlist Type** to **Source File**.
- 4. Click **Start Compilation** to compile the non-critical partitions.
- 5. Check the Timing Analyzer report to ensure that the timing requirements are met. If so, proceed to step 6. Otherwise, make design or option changes and repeat steps 4 and 5 until the requirements are met.
- In the Design Partition Window, set the Netlist Type to Post-Fit for the processed partitions. Set the Fitter Preservation Level to Placement to allow for the most flexibility during routing.
- Change the Netlist Type from Empty to Source File for the partition expected to be critical.
- 8. Click **Start Compilation** to compile the design with optimizations turned on, or use Design Space Explorer.
- 9. Check the Timing Analyzer report to ensure that the timing requirements are met. If not, make design or option changes and repeat steps 8 and 9 until the requirements are met.
- This flow is similar to a bottom-up design flow, in which a module is implemented separately and is merged into the rest of the design afterwards. Refer to "Empty Partitions" on page 1–28 for more information about potential issues. Ensure if there are any partitions representing a design file that is missing from the project, that you create a placeholder wrapper file that defines the port interface.

#### **Bottom-Up Design Flows**

There are two bottom-up design flow examples:

- Scenario 5—Team-Based Bottom-Up Design Flow
- Scenario 6—Design Iteration in a Bottom-Up Design Flow

Scenario 5—Team-Based Bottom-Up Design Flow

This scenario describes how to use incremental compilation in a bottom-up design flow.

Background: A project consists of several lower-level subdesigns that are implemented separately by different designers. The top-level project instantiates each of these subdesigns exactly once. The subdesign designers want to optimize their designs independently and pass on the results to the project lead.

As the project lead in this scenario, perform the following steps to prepare the design for a successful bottom-up design methodology.

- 1. Create a new Quartus II project that will ultimately contain the full implementation of the entire design.
- 2. To prepare for the bottom-up methodology, create a "skeleton" of the design that defines the hierarchy for the subdesigns that will be implemented by separate designers. The top-level design implements the top-level entity in the design and instantiates wrapper files that represent each subdesign by defining only the port interfaces but not the implementation.
- Make project-wide settings. Select the device, make global assignments for clocks and device I/O ports, and make any global signal constraints to specify which signals can use global routing resources.
- 4. In the Settings dialog box, expand Compilation Process Settings and select Incremental Compilation. Turn on Full incremental compilation, and click OK.
- Make design partition assignments for each subdesign and set the Netlist Type for each design partition that will be imported to Empty in the Design Partitions window.
- 6. Create LogicLock regions for each of the lower-level partitions to create a design floorplan. This floorplan should consider the connectivity between partitions and estimates of the size of each partition based on any initial implementation numbers and knowledge of the design specifications.
- 7. On the Project menu, click **Generate Bottom-Up Design Partition Scripts**, or launch the script generator from Tcl or the command prompt.
- 8. Make any changes to the default script options as desired. Altera recommends that you pass all the default constraints, including LogicLock region, for all partitions and virtual pin location assignments. Altera further recommends that you add a maximum delay timing constraint for the virtual I/O connections in each

partition to help timing closure during integration at the top level. If lower-level projects have not already been created by the other designers, use the partition script to set up the projects so that you can easily take advantage of makefiles.

Provide each lower-level designer with the Tcl file to create their project with the appropriate constraints. If you using makefiles, provide the makefile for each partition.

As the designer of a lower-level subdesign in this scenario, perform the appropriate set of steps to successfully export your design, whether your design team is using makefiles, or exporting and importing the design manually.

If you are using makefiles, perform the following steps:

- Use the make command and the makefile provided by the project lead to create a Quartus II project with all design constraints, and compile the project.
- The information about which source file should be associated with which partition is not available to the software automatically, so you must specify this information in the makefile. You must specify the dependencies before the software will rebuild the project after the initial call to the makefile.
- 3. When you have achieved the desired compilation results and the design is ready to be imported into the top-level design, the project lead can use the master\_makefile to export this lower-level partition and create a Quartus II Exported Partition file, and then import it into the top-level design.

If you are not using makefiles, perform the following steps:

- 1. Create a new Quartus II project for the subdesign.
- 2. Make LogicLock region assignments and global assignments (including clock settings) as specified by the project lead.
- 3. Make Virtual Pin assignments for ports which represent connections to core logic instead of external device pins in the top-level module.

- 4. Make floorplan location assignments to the Virtual Pins so that they are placed in their corresponding regions as determined by the top-level module. This provides the Fitter with more information about the timing constraints between modules. Alternately, you can apply timing I/O constraints to the paths that connect to virtual pins.
- Turn on Full incremental compilation and proceed to compile and optimize the design as needed.
- When you have achieved the design compilation results, on the Project menu, click Export Project as Design Partition.
- Under Netlist to export, select the netlist type Post-fit netlist to
  preserve the placement and performance of the subdesign. You can
  export Post-Synthesis netlist instead if placement or performance
  preservation is not required.
- 8. Provide the Quartus II Exported Partition file to the project lead.

Finally, as the project lead in this scenario, perform the appropriate set of steps to import the files sent in by the designers of each lower-level subdesign partition.

If you are using makefiles, perform the following steps:

- Use the master\_makefile to export each lower-level partition and create Quartus II Exported Partition files, and then import them into the top-level design.
- The software does not have information about which source file should be associated with which partition, so you must specify this information in the makefile. The software cannot rebuild the project if source files change unless you specify the dependencies.

If you are not using makefiles, perform the following steps:

 After you obtain the Quartus II Exported Partition file for each subdesign from the other designers on the team, on the Project menu, click Import Design Partition and specify the partition in the top-level project that is represented by the subdesign Quartus II Exported Partition file.  Repeat the import process described in step 1 for each partition in the design. After you have imported each partition once, you select all the design partitions and use the **Reimport using latest import files at previous locations** option to import all of the files from their previous locations at one time.

#### **Resolving Assignment Conflicts During Import**

When importing the subdesigns, the project lead may become aware of some assignment conflicts. This can occur, for example, if the subdesign designers changed their LogicLock regions to account for additional logic or placement constraints, or if the designers applied I/O port timing constraints that differ from constraints added to the top-level project by the project lead. To address these conflicts, the project lead may want to do one or both of the following:

- Allow new assignments to be imported
- Allow existing assignments to be replaced or updated

When LogicLock region assignment conflicts occur, the project lead may want to do one of the following:

- Allow the imported region to replace the existing region
- Allow the imported region to update the existing region
- Skip assignment import for regions with conflicts

The project lead can address all of these situations using the **Advanced Import Settings** as described in "Importing Assignments & Advanced Import Settings" on page 1–39.

If the placement of different subdesigns conflict, the project lead can also set the partition's Fitter **Preservation Level to Netlist Only**, which allows the software to re-perform placement and routing with the imported netlist.

#### Importing a Partition to be Instantiated Multiple Times

In this variation of the scenario, one of the subdesigns is instantiated more than once in the top-level design. The designer of the subdesign may want to compile and optimize the entity once under a lower-level project, and then import the results as multiple partitions in the top-level project.

In this case, placement conflict resolution as described in "Resolving Assignment Conflicts During Import" on page 1–56 is mandatory because the top-level partitions share the same imported post-fit netlist. If you import multiple instances of a subdesign in the top-level design, the imported LogicLock regions are automatically set to Floating status.

If you choose to resolve conflicts manually, you can use the import options and manual LogicLock assignments to specify the placement of each instance in the top-level design.

#### Scenario 6—Design Iteration in a Bottom-Up Design Flow

Background: A project consists of several lower-level subdesigns that have been exported from separate Quartus II projects and imported into the top-level design in a bottom-up compilation flow. In this scenario, integration at the top-level has failed because the timing requirements are not met. The timing requirements are met in each individual lower-level project, but critical inter-partition paths in the top-level are causing timing requirements to fail.

After trying various optimizations at the top-level, the project lead determines that they cannot meet the timing requirements given the current lower-level partition placements that were imported. The project lead decides to pass additional constraints to the lower-level projects to improve the placement.

For this scenario, perform the following steps:

- In the top-level design, on the Project menu, click Generate Bottom-Up Design Partition Scripts, or launch the script generator from Tcl or the command line.
- Because lower-level projects have already been created for each partition, turn off Create lower-level project if one does not exist.
- 3. Make any additional changes to the default script options as desired. Altera recommends that you pass all the default constraints, including LogicLock regions, for all partitions and virtual pin location assignments. Altera also recommends that you add a maximum delay timing constraint for the virtual I/O connections in each partition.
- 4. The Quartus II software generates Tcl scripts for all partitions, but in this scenario, you would focus on the partitions that make up the cross-partition critical paths. Following are the important assignments in the script:
  - Virtual pin assignments for module pins not connected to device I/O ports in the top-level design.
  - Location constraints for the virtual pins that reflect the initial top-level placement of the pin's source or destination. These help make the lower-level placement "aware" of its

- surroundings in the top-level, leading to a greater chance of timing closure during integration at the top-level.
- INPUT\_MAX\_DELAY and OUTPUT\_MAX\_DELAY timing constraints on the paths to and from the I/O pins of the partition. These constrain the pins to optimize the timing paths to and from the pins.
- The project lead provides the scripts to the low-level designers who source the file.
  - To source the Tcl script from the Quartus II GUI, on the Tools menu, click Utility Windows and open the Tcl console. Navigate to the script's directory, and type the following command:

```
source <filename> ←
```

 To source the Tcl script at the command line, type the following command:

```
quartus cdb -t <filename>.tcl ←
```

- The lower-level designers recompile their designs with the new assignments.
- 7. The lower-level designers re-export their results.
- 8. The top-level designer re-imports the results.
- 9. You can now analyze the design to determine if the timing requirements have been achieved. Since the lower-level partitions were compiled with more information about connectivity at the top-level, it is more likely that the inter-partition paths have improved placement which helps to meet the timing requirements.

# Incremental Compilation Restrictions

This section documents the restrictions and limitations that you may encounter when using incremental compilation, including interactions with other Quartus II features. Some restrictions apply to both top-down and bottom-up design flows, while some additional restrictions apply only to bottom-up design flows.

#### **Using Incremental Compilation with Quartus II Archive Files**

The post-synthesis and post-fitting netlist information for each design partition is stored in the project database. When you archive a project, the database information is not included in the archive unless you include the database files in the Quartus II Archive file (.qar). In addition, when you

import a design partition into a top-level design, the lower-level design netlist is stored in the project database for the top-level design (the top-level project does not use the original source files or the Quartus II Exported Partition file). If you archive the top-level project, the imported design information is not included unless the database files are included in the Quartus II Archive file.

Altera recommends that you select **Compilation and simulation database files** in the **Archive Project** dialog box if any form of incremental compilation is used so that compilation results are preserved.

#### OpenCore Plus MegaCore Functions

The circuitry that provides OpenCore® Plus MegaCore® functions is currently incompatible with incremental compilation.

#### **Engineering Change Management With the Chip Editor**

When you use the Resource Property Editor to make changes due to engineering change orders (ECOs) after performing a full compilation, recompiling the entire design is not necessary. These changes are made directly to the netlist without performing a new placement and routing. The changes are not made again automatically when you recompile the design.

Because the netlist generated by the Chip Editor is always overwritten by a recompilation, the changes do not appear in the final netlist after recompilation unless they are reapplied. There are change management features to allow you to reapply the changes on subsequent compilations using the Chip Editor, or you can merge the changes back to the source files before the recompilation.

This behavior applies in any compilation, whether or not incremental compilation is turned on.

#### SignalProbe Feature

SignalProbe® pins are added to the design after compilation so you can add them incrementally to your design without performing a new compilation. However, in the Quartus II software version 6.0, these SignalProbe pins are not part of the netlist after a recompilation of the design using full incremental compilation. Reapply the SignalProbe pin assignments on subsequent compilations, then, on the Processing menu, point to Start and click **Start Check & Save All Netlist Changes**.

During the export of a lower-level design in a bottom-up compilation flow, the software removes SignalProbe logic. You can use SignalProbe in lower-level projects to debug your design and then export the design without these debugging ports when it is imported and combined with other logic at the top level.

### SignalTap II Logic Analyzer & Logic Analyzer Interface in Bottom-Up Compilation Flows

The SignalTap® II logic analyzer and External Logic Analyzer Interface are not supported in lower-level projects in a bottom-up incremental compilation flow. These features are supported for the top-level project only after lower-level partitions have been imported, and are fully supported in top-down incremental compilation.



For details about using the SignalTap II logic analyzer in an incremental design flow, refer to the *Design Debugging Using the SignalTap II Embedded Logic Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

#### **Restrictions on Megafunction Partitions**

The Quartus II software does not support partitions for megafunction instantiations. If you use the MegaWizard Plug-In Manager to customize a megafunction variation, the MegaWizard-generated wrapper file instantiates the megafunction. You can create a partition for the MegaWizard-generated megafunction custom variation wrapper file.

The Quartus II software does not support the creation of a partition for inferred megafunctions (that is, where the software infers a megafunction to implement logic in your design). If you have a module or entity for the logic that is inferred, you can create a partition for that hierarchy level in the design.

The Quartus II software does not support creation of a partition for any Quartus II internal hierarchy that is dynamically generated during compilation to implement the contents of a megafunction.

#### **Nodes Created & Changed During Routing**

Node names are preserved through synthesis and fitting when using incremental compilation. Some nodes that the router creates and inserts may change if the Fitter preservation level is not set to **Placement and Routing**. You may also see slightly different numbers of logic cells due to logic cells being used to achieve better routing. In addition, the fit results

may be slightly different due to optimizations performed during routing, such as rotation of the inputs to the look-up table (LUT) within the logic cell.

#### Routing Preservation in Bottom-Up Compilation Flows

The Quartus II software does not export routing information from lower-level partitions in a bottom-up methodology, so you can not import routing information into the top-level partition.

For imported netlists, the Post-Fit netlist contains the atoms and the placement information of the partition. Therefore, when the Quartus II software uses a Post-Fit netlist for a partition, the placement of the partition is preserved. Performance preservation can typically be achieved even though the routing of the partition is not restored, because the router is generally not as sensitive to small changes in input as the Fitter. In some designs, you may see variation in performance due to changed routing. To ensure that you do not experience any problems due to this effect, you can optimize your design to achieve a margin of 1 or 2% on your timing requirements.

Delay chain values are not preserved with bottom-up incremental compilation. Delay chain values are routing-dependent, and because routing is not preserved, delay chain values may change even if a Post-Fit netlist is used.

#### **Bottom-Up Design Partition Script Limitations**

The Quartus II software version 6.0 has some limitations related to bottom-up design partition scripts. Many of these limitations will be removed in future versions of the software.

#### Wildcard Support in Bottom-Up Design Partition Scripts

When applying constraints with wildcards, wildcards are not analyzed across hierarchical boundaries. For example, an assignment could be made to these nodes: Top | A:inst | B:inst | \*\*, where A and B are lower-level partitions, and hierarchy B is a child of A, that is B is instantiated in hierarchy A. This assignment is applied to modules A, B and all children instances of B. However, the assignment Top | A:inst | B:inst\* is applied to hierarchy A, but is not applied to the B instances because the single level of hierarchy represented by B:inst\* is not expanded into multiple levels of hierarchy. To avoid this issue, ensure that you apply the wildcard to the hierarchical boundary if it should represent multiple levels of hierarchy.

When using the wildcard to represent a level of hierarchy, only single wildcards are supported. This means assignments such as **Top | A:inst | \* | B:inst | \*** are not supported. The Quartus II software issues a warning in these cases.

#### Derived Clocks & PLLs in Bottom-Up Design Partition Scripts

If a clock in the top level is not directly connected to a pin of a lower-level partition, then the lower-level partition does not receive assignments and constraints from the top-level pin in the design partition scripts.

This issue is of particular importance for clock pins that require timing constraints and clock group settings. Problems can occur if your design uses logic or inversion to derive a new clock from a clock input pin. Make appropriate timing assignments in your lower-level Quartus II project to ensure that clocks are not unconstrained.

In addition, if you use a PLL in your top-level design and connect it to lower-level partitions, the lower-level partitions do not have information about the multiplication or phase shift factors in the PLL. Make appropriate timing assignments in your lower-level Quartus II project to ensure that clocks are not unconstrained or constrained with the incorrect frequency.

#### Virtual Pin Timing Assignments in Bottom-Up Design Partition Scripts

The design partition scripts use INPUT\_MAX\_DELAY and OUTPUT\_MAX\_DELAY assignments to specify the inter-partition delays associated with input and output pins which would not otherwise be visible to the project. These assignments require that the software specify the clock domain for the assignment, and the software sets this clock domain to "\*. This means that there may be some paths constrained and reported by the timing analysis engine that are not required.

To restrict which clock domains are included in these assignments, edit the generated scripts or change the assignments in your lower-level Quartus II project.

#### Top-Level Ports that Feed Multiple Lower-Level Pins in Bottom-Up Design Partition Scripts

When a single top-level I/O port drives multiple pins on a lower-level module, it unnecessarily restricts the quality of the synthesis and placement at the lower-level. This occurs because in the lower-level design, the software must maintain the hierarchical boundary and cannot use any information about pins being logically equivalent at the top level. In addition, because I/O constraints are passed from the top-level pin to

each of the children, it is possible to have more pins in the lower level than at the top level, and these pins use the top-level I/O constraints and placement options that might make them impossible to place at the lower-level. The software avoids this situation when possible, but it is best to avoid this design practice to avoid these potential problems. Restructure your design so that the single I/O port feeds the design partition boundary, and then the connection is split into multiple signals within the lower-level partition.

#### Support for the TimeQuest Timing Analyzer & SDC Constraints

If you use constraints with the TimeQuest Timing Analyzer, the assignments are not passed to the lower levels. You must use constraints made for the Classic Timing Analyzer. You can then use the **Generate SDC File from QSF** command to convert the Classic Timing Analyzer constraints in a Quartus II Settings File (.qsf) to a Synopsys Design Constraints (.sdc) for the TimeQuest analyzer.



For more information about timing constraints and conversion from the QSF file to the SDC file, refer to *Classic Timing Analyzer*, *TimeQuest Timing Analyzer*, and *Switching to the TimeQuest Timing Analyzer* chapters in volume 3 of the *Quartus II Handbook*.

#### **Register Packing & Partition Boundaries**

The Quartus II software automatically performs register packing during compilation. However, when incremental compilation is enabled, logic in different partitions cannot be packed together because partition boundaries prevent cross-boundary optimization. (Refer to "Guidelines for Creating Good Design Partitions" on page 1–20 for more information.) This restriction applies for all types of register packing, including I/O cells, DSP blocks, sequential logic, and unrelated logic.

#### I/O Register Packing

Cross-partition register packing of I/O registers is allowed in certain cases where your input and output pins exist in the top hierarchy level (and the Top partition), but the corresponding I/O registers exist in other partitions.

The following specific circumstances are required for cross-partition register packing of input pins:

- The input pin feeds exactly one register
- The path between the input pin and the register includes only input ports of partitions that have one fan-out each

The following specific circumstances are required for cross-partition register packing of output registers:

- The register feeds exactly one output pin
- The output pin is fed by only one signal
- The path between the register and the output pin includes only output ports of partitions that have one fan-out each

Output pins with an output enable signal cannot be packed into the device I/O cell if the output enable logic is part of a different partition from the output register. To allow register packing for output pins with an output enable signal, structure your HDL code or design partition assignments so that the register and the tri-state logic are defined in the same partition.

Bidirectional pins are handled in the same way as output pins with an output enable. If the registers that need to be packed are in the same partition as the tri-state logic, then register packing can be performed.

The restrictions on tri-state logic are due to the fact that the I/O atom (device primitive) is created as part of the partition that contains the tri-state logic. If an I/O register and its tri-state logic are contained in the same partition, the register can always be packed with the tri-state logic into the I/O atom. The same cross-partition register packing restrictions also apply to I/O atoms for input and output pins. The I/O atom must feed the I/O pin directly with exactly one signal and the path between the I/O atom and the I/O pin must include only ports of partitions that have one fan-out each.

#### Examples of I/O Register Packing Across Partition Boundaries

The following examples provide detailed explanations for various I/O and partition configurations. The examples use BDF schematics to illustrate the design logic.

#### Example 1—Output Register in Partition Feeding Output Pin

In this example, a subdesign contains a single register, as shown in Figure 1–15. As shown in Figure 1–16, the top-level design instantiates the subdesign with a single fanout directly feeding an output pin, and designates the subdesign as a separate design partition.

Figure 1–15. Subdesign with One Register, Designated as a Separate Partition



Figure 1–16. Top-level Design Instantiating the Subdesign in Figure 1–15 as an Output Register



The Quartus II software performs cross-partition register packing if there is a Fast Output Register assignment on pin "out." This type of cross-partition output register packing is permitted because the port interface of the subdesign partition does not need to be changed and the partition port feeds an output pin directly.

### **Example 2—Output Register in Partition Feeding Multiple Output Pins**

In this example, a subdesign designated as a separate partition contains a register as in Figure 1–15. The top-level design instantiates the subdesign as an output register with more than one fanout signal, as shown in Figure 1–17.

Figure 1–17. Top-level Design Instantiating the Subdesign in Figure 1–15 with Two Output Pins



In this case, the software does not perform output register packing. If there is a Fast Output Register assignment on pin "out", the software issues a warning that the fitter can't pack the node to an I/O pin because the node and the I/O cell are connected across a design partition boundary.

This kind of cross partition register packing is not permitted because it would require modification to the interface of the subdesign partition. In order to perform incremental compilation, the interface of design partitions must be preserved.

To allow the software to pack the register in the subdesign from Figure 1-15 with the output pin "out" in Figure 1-17, make one of the following changes:

- Remove the design partition assignment to the subdesign. This allows the fitter to perform all cross hierarchy optimizations, however, prevents you from using incremental compilation for this block of hierarchy. A good design partition should have a well-defined interface so that the Fitter does not have to perform cross-boundary optimizations.
- Restructure your HDL code to place the register in the same partition as the output pin. The simplest option is to move the register from the subdesign partition into the partition containing the output pin. This guarantees that the fitter can optimize the two nodes without violating any partition boundaries.
- Restructure your HDL code so the register feeds only one output pin. Turn off the Analysis & Synthesis setting Remove Duplicate Registers. Duplicate the register in your subdesign HDL as in Figure 1–18 so that each register feeds only one pin, then connect the extra output pin to the new port in the top-level design as shown in Figure 1–19. This converts the cross-partition register packing into the simplest case where the register has a single fanout.



Figure 1–19. Modified Top-Level Design from Figure 1–17 Connecting Two Output Ports to Output Pins



### Example 3—Output Register, Output Enable Register & Tri-State Logic in Partition Feeding Output Pin

In this example, a subdesign designated as a separate partition contains an output register, an output enable register, and the tri-state logic to drive the output pin, as shown in Figure 1–20. The top-level design instantiates the subdesign with a single fanout directly feeding an output pin, as shown in Figure 1–21.

Figure 1–20. Subdesign with Output Register, Output Enable Register & Tri-State Logic, Designated as a Separate Partition



Figure 1–21. Top-level Design Instantiating the Subdesign in Figure 1–20



The Quartus II software performs cross-partition register packing if there is a Fast Output Register assignment and/or Fast Output Enable Register assignment on pin "out." This kind of cross-partition output register packing is permitted because the port interface of the subdesign partition does not need to be changed, no logic needs to be optimized across the partition boundary, and the partition port feeds an output pin directly.

### Example 4—Output Register and/or Output Enable Register in Partition Feeding Tri-State Output Pin

In this example, a subdesign designated as a separate partition contains two registers, as shown in Figure 1–22. The top-level design instantiates the subdesign with the registers driving the output and the output enable signal for an output pin, as shown in Figure 1–23.

Figure 1–22. Subdesign with Two Registers, Designated as a Separate Partition



Figure 1–23. Top-level Design Instantiating the Subdesign in Figure 1–24 to Drive Output Enable Logic



In this case, the software can not perform register packing. If there is a Fast Output Register or Fast Output Enable Register assignment on pin "out," the software issues a warning that the fitter can't pack the node to an I/O pin because the node and the I/O cell are connected across a design partition boundary.

The same restrictions apply in the case that the top-level design includes either the output register or the output enable register as well as the tri-state logic. The software can not pack the register that is part of the subdesign partition into the I/O register.

This type of register packing is not permitted because it would require moving logic across a design partition boundary to place into a single I/O device atom. To perform register packing, either the register(s) must be moved out of the subdesign partition or the tri-state logic must be moved into the subdesign partition. In order to guarantee correctness of the design with subsequent incremental compilations, the contents of design partitions must be preserved.

To allow the software to pack the output register and/or output enable register in the subdesign from Figure 1–22 with the output pin "out" in Figure 1–23, make one of the following changes:

- Remove the design partition assignment to the subdesign. This allows the Fitter to perform all cross hierarchy optimizations, however, prevents you from using incremental compilation for this block of hierarchy. A good design partition should have a well defined interface so that the Fitter does not need to perform cross-boundary optimizations.
- Restructure your HDL code to place the register in the same partition as the output pin. The simplest option is to move the register from the subdesign partition into the top-level partition containing the output pin. This guarantees that the fitter can optimize the two nodes without violating any partition boundaries.
- Restructure your HDL code so the register and the tri-state logic are contained in the same partition. Move the tri-state logic from the top-level block into the subdesign with both registers as shown in Figure 1–20. Then connect the subdesign to an output pin in the top-level design, as shown in Figure 1–21.

**Example 5—Bidirectional Logic in Partition Feeding Bidirectional Pin** The behavior for bidirectional pins is similar to that of an output pin with an output enable. To allow register packing, the registers must be included in the same partition as the tri-state logic that drives the bidirectional pin.

In this example, a subdesign designated as a separate partition contains three registers and the tri-state logic for a bidirectional pin, as shown in Figure 1–24. The top-level design instantiates the subdesign with ports feeding bidirectional and output pins, as shown in Figure 1–25.



Figure 1–24. Subdesign with Three Registers & Tri-State Logic, Designated as a Separate Partition

Figure 1–25. Top-level Design Instantiating the Subdesign in Figure 1–27



The Quartus II software performs cross-partition register packing if there is a Fast Output Register, Fast Output Enable Register, or Fast Input Register assignment on pin bidir. This type of cross-partition output register packing is permitted because the port interface of the subdesign partition does not need to be changed and the partition port feeds a bidirectional pin directly.

Registers can not be packed in designs that have the registers and tri-state logic in different partitions. The situations described in "Example 4—Output Register and/or Output Enable Register in Partition Feeding Tri-State Output Pin" on page 1–68 apply similarly to bidirectional pins if you replace the output pin "out" with a bidirectional pin in the top-level design.

#### Example 6—Input Register in Partition Fed by Input Pin

In this example, a subdesign contains a single register, as shown in Figure 1–26. The top-level design instantiates the subdesign with a single fanin directly fed by an input pin, as shown in Figure 1–27, and designates the subdesign to be a separate design partition.

Figure 1–26. Subdesign with One Register, Designated as a Separate Partition



Figure 1–27. Top-level Design Instantiating the Subdesign in Figure 1–26 as an Input Register



The Quartus II software performs cross-partition register packing if there is a Fast Input Register assignment on pin "in." This type of cross-partition output register packing is permitted because the port interface of the subdesign partition does not have to be changed and the partition port is fed by an input pin directly.

### Example 7—Input Register in Partition Fed by Input with Multiple Fanout

In this example, a subdesign designated as a separate partition contains a register as in Figure 1–26. The top-level design instantiates the subdesign as an input register but the input pin also feeds another destination, as shown in Figure 1–28.

Figure 1–28. Top-level Design Instantiating the Subdesign in Figure 1–26 as an Input Register for a Pin with Two Destinations



In this case, the software does not perform input register packing. If there is a Fast Input Register assignment on pin "in," the software issues a warning that the fitter can't pack the node to an I/O pin because the node and the I/O cell are connected across a design partition boundary.

This type of cross-partition register packing is not permitted because it would require modification to the interface of the subdesign partition. In order to perform incremental compilation, the interface of design partitions must be preserved.

To allow the software to pack the register in the subdesign from Figure 1–26 with the input pin "in" in Figure 1–28, make one of the following changes:

- Remove the design partition assignment to the subdesign. This allows the fitter to perform all cross-hierarchy optimizations, however, it also prevents you from using incremental compilation for this block of hierarchy. A good design partition should have a well defined interface so that the Fitter does not have to perform cross-boundary optimizations.
- Restructure your HDL code to place the register in the same partition as the input pin. The simplest option is to move the register from the subdesign partition into the partition containing the input pin. This guarantees that the fitter can optimize the two nodes without violating any partition boundaries.

**Example 8—Inverted Input Register in Partition Fed by Input Pin** In this example, a subdesign designated as a separate partition contains an inverted register as in Figure 1–29. The top-level design instantiates the subdesign as an input register, as shown in Figure 1–30.

Figure 1–29. Subdesign with an Inverted Register, Designated as a Separate Partition



Figure 1–30. Top-level Design Instantiating the Subdesign in Figure 1–29 as an Input Register



The Quartus II software performs cross-partition register packing if there is a Fast Input Register assignment on pin "in." This kind of cross-partition input register packing is permitted because the software can implement the logic for the inversion with the input register inside the partition, and then the partition port is fed by an input pin directly.

### Example 9—Input Register in Partition Fed by Inverted Input Pin, or Output Register in Partition Feeding Inverted Output Pin

In this example, a subdesign designated as a separate partition contains a register as in Figure 1–31. The top-level design in Figure 1–32 instantiates the subdesign as an input register with the input pin inverted. The top-level design in Figure 1–33 instantiates the subdesign as an output register with the signal inverted before feeding an output pin.

Figure 1–31. Subdesign with One Register, Designated as a Separate Partition



Figure 1–32. Top-level Design Instantiating the Subdesign in Figure 1–31 as an Input Register with an Inverted Input Pin



Figure 1–33. Top-level Design Instantiating the Subdesign in Figure 1–32 as an Output Register Feeding an Inverted Output Pin



In these cases, the software does not perform register packing. If there is a Fast Input Register assignment on "in" in Figure 1–32 or a Fast Output Register assignment on pin "out" in Figure 1–33, the software issues a warning that the fitter can't pack the node to an I/O pin because the node and the I/O cell are connected across a design partition boundary.

This type of register packing is not permitted because it would require moving logic across a design partition boundary to place into a single I/O device atom. To perform register packing, either the register must be moved out of the subdesign partition or the inverter must be moved into the subdesign partition to be implemented in the register. In order to guarantee correctness of the design with subsequent incremental compilations, the contents of design partitions must be preserved.

To allow the software to pack the register in the subdesign from Figure 1–31 with the input pin "in" in Figure 1–32 or the output pin "out" in Figure 1–33, make one of the following changes:

- Remove the design partition assignment from the subdesign. This allows the fitter to perform all cross hierarchy optimizations, however, it prevents you from using incremental compilation for this block of hierarchy. A good design partition should have a well defined interface so that the Fitter does not have to perform cross-boundary optimizations.
- Restructure your HDL code to place the register in the same partition as the pin. The simplest option is to move the register from the subdesign partition into the top-level partition containing the pin. This ensures that the fitter can optimize the two nodes without violating any partition boundaries.
- Restructure your HDL code so the register and the inverter are contained in the same partition. Move the inverter from the top-level block into the subdesign as shown in Figure 1–29 for an input pin. Then connect the subdesign to a pin in the top-level design, as shown in Figure 1–30 for an input pin.

# 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*. 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*.

#### **Generate Incremental Compilation Tcl Script Command**

To create a template Tcl script for full incremental compilation, use the Generate Incremental Compilation Tcl Script feature. Right-click in the Design Partition Window and click Generate Incremental Compilation Tcl Script.

If you have made any partition assignments in the user interface, this script contains the Tcl equivalents of the assignments. The Tcl assignments are described in the following sections.

#### **Preparing a Design for Incremental Compilation**

To set or modify the current mode of incremental compilation, use the following command:

```
set_global_assignment -name INCREMENTAL_COMPILATION \
<value>
```

The incremental compilation *<value>* setting must be one of the following values:

- FULL\_INCREMENTAL\_COMPILATION—Full incremental compilation
- INCREMENTAL SYNTHESIS—Incremental synthesis only
- OFF—No incremental compilation is performed

#### **Creating Design Partitions**

To create a partition, use the following command:

```
set_instance_assignment -name PARTITION_HIERARCHY \
<file name> -to <destination> -section_id <partition name>
```

The *<destination>* should be the entity's short hierarchy path. A short hierarchy path is the full hierarchy path without the top-level name (including quotation marks), for example:

```
"ram:ram unit altsyncram:altsyncram component"
```

(with quotation marks). For the top-level partition, you can use the pipe (|) symbol to represent the top-level entity.



For more information on hierarchical naming conventions, refer to *Node-Naming Conventions in Quartus II Integrated Synthesis* in the *Quartus II Integrated Synthesis* chapter in volume 1 of the *Quartus II Handbook*.

The *<file name>* is the name used for internally generated netlists files during incremental compilation. Netlists are named automatically by the Quartus II software based on the instance name if you create the partition in the user interface. If you are using Tcl to create your partitions, you must assign a custom file name that is unique across all partitions. For the top-level partition, the specified file name is ignored, and you can use any dummy value. To ensure the names are safe and platform independent, file names must be unique regardless of case. For example, if a partition uses the file name my\_file, no other partition can use the file name MY\_FILE. For simplicity, Altera recommends that you base each file name on the corresponding instance name for the partition.

The software stores all netlists in the \db compilation database directory.

#### **Setting Properties of Design Partitions**

After a partition is created, set its Netlist Type with the following command:

 $\verb|set_global_assignment - name PARTITION_NETLIST_TYPE < value> - \verb|section_id | | < partition name> |$ 

The netlist type *<value>* setting is one of the following values:

- SOURCE—Source File
- POST SYNTH—Post-Synthesis
- POST FIT—Post-Fit
- STRICT\_POST\_FIT—Post-Fit (Strict)
- IMPORTED—Imported
- IMPORT\_BASED\_POST\_FIT—Post-Fit (Import-based)
- EMPTY—Empty

Set the Fitter Preservation Level for a post-fit or imported netlist using the following command:

set\_global\_assignment -name PARTITION\_FITTER\_PRESERVATION\_LEVEL <value>\
-section\_id <partition name>

The fitter preservation level *<value>* setting should be one of the following values:

- NETLIST ONLY—Netlist Only
- PLACEMENT—Placement
- PLACEMENT AND ROUTING—Placement and Routing

For details about these partition properties, refer to "Setting Properties of Design Partitions" on page 1–77.

#### Recommendations for Creating Good Floorplan Location Assignments—Excluding or Filtering Certain Device Elements (Such as RAM or DSP Blocks)

Resource filtering uses the optional Tcl argument -exclude\_resources in the set\_logiclock\_contents function of the LogicLock Tcl package. If left unspecified, no resource filter is created.

The argument takes a list of resources-to-be-excluded as input. The list is a colon-delimited string of the following keywords:

| Table 1–4. Resources-to-be-Excluded Keywords |                                                       |  |
|----------------------------------------------|-------------------------------------------------------|--|
| Keyword                                      | Resource                                              |  |
| REGISTER                                     | Maps to any registers in the logic cells              |  |
| COMBINATIONAL                                | Maps to any combinational elements in the logic cells |  |
| SMALL_MEM                                    | Maps to the M512 memory blocks                        |  |
| MEDIUM_MEM                                   | Maps to the M4K memory blocks                         |  |
| LARGE_MEM                                    | Maps to the M-RAM memory blocks                       |  |
| DSP                                          | Maps to any DSP blocks                                |  |

For example, the following command assigns everything under alu:alu\_unit to the ALU region, excluding all the DSP and M512 blocks:

set\_logiclock\_contents -region ALU -to alu:alu\_unit -exclude\_resources \
"DSP:SMALL MEM"

In the QSF file, resource filtering uses an extra LogicLock membership assignment called LL\_MEMBER\_RESOURCE\_EXCLUDE. For example, the following line in the QSF is used to specify a resource filter for the <code>alu:alu\_unit</code> entity assigned to the ALU region. The value of the assignment takes the same format as the resource listing string taken by the previous Tcl command.

set\_instance\_assignment -name LL\_MEMBER\_RESOURCE\_EXCLUDE "DSP:SMALL\_MEM" \
-to "alu:alu\_unit" -section\_id ALU

#### **Generating Bottom-Up Design Partition Scripts**

To generate scripts, type the following Tcl command at a Tcl prompt:

generate bottom up scripts <options> ←

The command is part of the database\_manager package, which must be loaded using the following command before the command can be used:

load package database manager

You must open a project before you can generate scripts.

The Tcl options are the same as those available in the GUI. The exact format of each option is specified in Table 1–5.

| Table 1–5. Options for Generating Bottom-Up Partition Scripts with Tcl Commands |                           |  |
|---------------------------------------------------------------------------------|---------------------------|--|
| Option                                                                          | Default                   |  |
| -include_makefiles <on off></on off>                                            | On                        |  |
| -include_project_creation <on off></on off>                                     | On                        |  |
| -include_virtual_pins <on off></on off>                                         | On                        |  |
| -include_virtual_pin_timing <on off></on off>                                   | On                        |  |
| -include_virtual_pin_locations <on off></on off>                                | On                        |  |
| -include_logiclock_regions <0n off>                                             | On                        |  |
| -include_all_logiclock_regions <0n off>                                         | On                        |  |
| -include_global_signal_promotion <on off></on off>                              | Off                       |  |
| -include_pin_locations <on off></on off>                                        | On                        |  |
| -include_timing_assignments <on off></on off>                                   | On                        |  |
| -include_design_partitions <on off></on off>                                    | On                        |  |
| -remove_existing_regions <0n off>                                               | On                        |  |
| -disable_auto_global_promotion <on off></on off>                                | Off                       |  |
| -bottom_up_scripts_output_directory <output directory=""></output>              | Current project directory |  |
| -virtual_pin_delay <delay in="" ns=""></delay>                                  | (1)                       |  |

Note to Table 1-5:

(1) No default.

The following example shows how to use the Tcl command:

```
load_package database_manager
set project test_proj
project_open $project
generate_bottom_up_scripts -bottom_up_scripts_output_directory test \
    -include_virtual_pin_timing on -virtual_pin_delay 1.2
project close
```

#### Command Line Support

To generate scripts at the command prompt, type the following command:

Once again the options map to the same as those in the GUI. To add an option, append "--*coption\_name>=cval>*" to the command line call.

The command prompt options are the same as those available in the GUI, and are listed in Table 1–6.

| Table 1–6. Options for Generating Bottom-Up Partition Scripts           |                           |  |
|-------------------------------------------------------------------------|---------------------------|--|
| Option                                                                  | Default                   |  |
| include_makefiles_with_bottom_up_scripts= <on off></on off>             | On                        |  |
| include_project_creation_in_bottom_up_scripts= <on off></on off>        | On                        |  |
| include_virtual_pins_in_bottom_up_scripts= <on off></on off>            | On                        |  |
| include_virtual_pin_timing_in_bottom_up_scripts= <on off></on off>      | On                        |  |
| bottom_up_scripts_virtual_pin_delay= <delay in="" ns=""></delay>        | (1)                       |  |
| include_virtual_pin_locations_in_bottom_up_scripts= <on off></on off>   | On                        |  |
| include_logiclock_regions_in_bottom_up_scripts= <on off></on off>       | On                        |  |
| include_all_logiclock_regions_in_bottom_up_scripts= <on off></on off>   | On                        |  |
| include_global_signal_promotion_in_bottom_up_scripts= <on off></on off> | Off                       |  |
| include_pin_locations_in_bottom_up_scripts= <on off></on off>           | On                        |  |
| include_timing_assignments_in_bottom_up_scripts= <on off></on off>      | On                        |  |
| include_design_partitions_in_bottom_up_scripts= <on off></on off>       | On                        |  |
| remove_existing_regions_in_bottom_up_scripts= <on off></on off>         | On                        |  |
| disable_auto_global_promotion_in_bottom_up_scripts= <on off></on off>   | Off                       |  |
| bottom_up_scripts_output_directory= <output directory=""></output>      | Current project directory |  |

#### Note to Table 1-6:

(1) No default. You must provide this option if you are including virtual pin timing.

#### **Exporting a Partition to be Used in a Top-Level Project**

Use the quartus\_cdb executable to export a file for a bottom-up incremental compilation flow with the following command:

quartus\_cdb --INCREMENTAL\_COMPILATION\_EXPORT=<file> ←

The *<file>* argument is the file path to the exported file.

The command reads the assignment INCREMENTAL\_COMPILATION\_EXPORT\_NETLIST\_TYPE to determine which netlist type to export; the default is post-fit.

You can also use the flow INCREMENTAL\_COMPILATION\_EXPORT in the execute\_flow Tcl command contained in the flow Tcl package.

The following example exports a post-fit netlist for the current project.

```
load_package flow
set_global_assignment -name INCREMENTAL_COMPILATION_EXPORT_FILE alu.qxp
set_global_assignment -name INCREMENTAL_COMPILATION_EXPORT_NETLIST_TYPE \
POST_FIT
execute flow -INCREMENTAL COMPILATION EXPORT
```

To specify the name of the Quartus II Exported Partition file, use the following Tcl command:

```
set_global_assignment -name INCREMENTAL_COMPILATION_EXPORT_FILE \
<filname>.qxp
```

To turn on the option to always perform exportation following compilation, use the following Tcl command:

```
set_global_assignment -name AUTO_EXPORT_INCREMENTAL_COMPILATION ON
```

#### Importing a Lower-Level Partition into the Top-Level Project

Use the **quartus\_cdb** executable to import a lower-level partition with the following command:

```
quartus cdb -- INCREMENTAL COMPILATION IMPORT ←
```

You can also use the flow called INCREMENTAL\_COMPILATION\_IMPORT in the execute\_flow Tcl command contained in the flow Tcl package.

The following example script shows how to import a partition using a Tcl script:

```
load_package flow
# commands to set the import-related assignments for each partition
execute flow --INCREMENTAL COMPILATION IMPORT
```

Specify the location for the imported file with the PARTITION\_IMPORT\_FILE assignment. Note that the file specified by this assignment is read only during importation. For example, the project is completely independent from any files from the lower-level projects after importing. In the command-line and Tcl flow, any partition that has this assignment set to a non-empty value will be imported.

The following assignments specify how the partition should be imported:

```
PARTITION_IMPORT_PROMOTE_ASSIGNMENTS = on | off
PARTITION_IMPORT_NEW_ASSIGNMENTS = on | off
PARTITION_IMPORT_EXISTING_ASSIGNMENTS = \
replace_conflicting | skip_conflicting
PARTITION_IMPORT_EXISTING_LOGICLOCK_REGIONS = \
replace conflicting | update conflicting | skip conflicting
```

#### Make Files

For an example of how to use incremental compilation with a makefile as part of the bottom-up design flow, refer to the <code>read\_me.txt</code> file that accompanies the <code>incr\_comp</code> example located in the <code>/qdesigns/incr\_comp\_makefile</code> subdirectory. When using a bottom-up incremental compilation flow, the Generate Bottom-Up Design Partition Scripts feature can write makefiles that automatically export lower-level design partitions and import them into the top-level project whenever design files change.

### User Scenarios—Incremental Compilation Application Examples

This section provides scripting examples that cover some of the topics discussed in the main section of the chapter.

The script shown in Example 1–1 opens a project called AB\_project, sets up two partitions, entities **A** and **B**, for the first time, and performs an initial complete compilation.

#### Example 1–1. AB\_project

```
set project AB project
package require ::quartus::flow
project open $project
# Turn on incremental compilation
set global assignment -name INCREMENTAL COMPILATION \
FULL INCREMENTAL COMPILATION
# Set up the partitions
set_instance_assignment -name PARTITION_HIERARCHY \
db/A inst -to A -section id "Partition A"
set instance assignment -name PARTITION HIERARCHY \
db/B inst -to B -section id "Partition B"
# Set the netlist types to post-fit for subsequent
# compilations (all partitions are compiled during the
# initial compilation since there are no post-fit
# netlists)
set global assignment -name PARTITION NETLIST TYPE \
POST_FIT -section_id "Partition_A"
set global assignment -name PARTITION NETLIST TYPE \
POST FIT -section id "Partition B"
# Run initial compilation:
export assignments
execute_flow -full_compile
project close
```

#### Scenario 1—Changing a Source File for One of Multiple Partitions

Background: You have run the initial compilation shown in the example script under "User Scenarios—Incremental Compilation Application Examples" on page 1–82. You have modified the HDL source file for partition **A**, and would like to recompile it.

Run the standard flow compilation command in your Tcl script:

```
execute flow -full compile
```

Or, run the following command at a system command prompt:

```
quartus_sh --flow compile AB_project←
```

Assuming the source files for partition **B** do not depend on **A**, only **A** is recompiled. The placement of **B** and its timing performance is preserved, which also saves significant compilation time.

Scenario 2—Optimizing the Placement for One of Multiple Partitions

Background: You have run the initial compilation shown in the example script under "User Scenarios—Incremental Compilation Application Examples" on page 1–82. You would like to apply fitter optimizations, such as physical synthesis, only to partition **A**. No changes have been made to the HDL files.

To ensure the previous compilation result for partition **B** is preserved, and to ensure that fitter optimizations are applied to the post-synthesis netlist of partition **A**, set the netlist type of **B** to Post-Fit (which was already done in the initial compilation, but is repeated here for safety), and the netlist type of **A** to Post-Synthesis, as shown in the following script:

```
set project AB project
package require ::quartus::flow
project open $project
# Turn on Physical Synthesis Optimization
set global assignment -name \
PHYSICAL SYNTHESIS REGISTER RETIMING ON
# For A, set the netlist type to post-synthesis
set_global_assignment -name PARTITION_NETLIST_TYPE POST_SYNTH \
-section id "Partition A"
# For B, set the netlist type to post-fit
set global assignment -name PARTITION NETLIST TYPE POST FIT \
-section_id "Partition_B"
# Run incremental compilation:
export assignments
execute flow -full compile
project_close
```

#### Conclusion

With the Quartus II incremental compilation feature described in this chapter, you can preserve the results and the performance of unchanged logic in your design as you make changes elsewhere. The various applications of incremental compilation enable you to improve your productivity while designing for high-density FPGAs , using either top-down or bottom-up design methodologies. Using the techniques and recommendations presented in this chapter allows you to make good design decisions to achieve timing closure while reducing design iteration time by an average of about 60%.



# 2. Quartus II Design Flow for MAX+PLUS II Users

Q1160002-6.0.0

#### Introduction

The feature-rich Quartus® II software helps you shorten your design cycles and reduce time-to-market. With FLEX®, ACEX®, APEX<sup>TM</sup>, Stratix® II, Stratix GX, Stratix, Cyclone<sup>TM</sup> II, Cyclone<sup>TM</sup>, MAX®, and MAX II family support, the Quartus II software is the most widely accepted Altera® design software tool today.

This chapter describes how to convert MAX+PLUS® II designs to Quartus II projects, as well as the similarities and differences between the MAX+PLUS II and Quartus II design flows. This discussion includes supported device families, graphical user interface (GUI) comparisons, and the advantages of the Quartus II software.

There are many features in the Quartus II software to help MAX+PLUS II users easily transition to the Quartus II software design environment. These include a customizable **Look & Feel** feature, which changes the GUI to display menus, toolbars, and utility windows as they appear in the MAX+PLUS II software without sacrificing Quartus II software functionality.

#### Chapter Overview

This chapter covers the following topics:

- Typical Design Flow
- Device Support
- Quartus II GUI Overview
- Setting Up MAX+PLUS II Look & Feel in Quartus II
- Compiler Tool
- Quartus II Design Flow
- Quick Menu Reference

#### Typical Design Flow

Figure 2–1 shows a typical design flow with the Quartus II software.

Figure 2-1. Quartus II Software Design Flow



#### **Device Support**

The Quartus II software supports most of the devices supported in the MAX+PLUS II software, but it does not support any obsolete devices or packages. The devices supported by these two software packages are shown in Table 2–1.

| Table 2–1. Device Support Comparison |              |             |  |
|--------------------------------------|--------------|-------------|--|
| Device Supported                     | Quartus II   | MAX+PLUS II |  |
| MAX II                               | <b>✓</b>     | _           |  |
| Classic™                             | _            | ✓           |  |
| MAX 3000A                            | ✓            | ✓           |  |
| MAX 7000S/AE/B                       | ✓            | ✓           |  |
| MAX 7000E                            | _            | ✓           |  |
| MAX 9000                             | _            | ✓           |  |
| ACEX® 1K                             | <b>✓</b>     | ✓           |  |
| FLEX® 6000                           | ✓            | ✓           |  |
| FLEX 8000                            | _            | ✓           |  |
| FLEX 10K                             | <b>√</b> (1) | ✓           |  |
| FLEX 10KA                            | ✓            | ✓           |  |
| FLEX 10KE                            | <b>√</b> (2) | ✓           |  |
| Mercury™                             | <b>✓</b>     | _           |  |
| APEX™ 20K/ APEX II                   | ✓            | _           |  |
| Stratix                              | <b>✓</b>     | _           |  |
| Stratix GX                           | ✓            | _           |  |
| Stratix II                           | ✓            | _           |  |
| Cyclone™                             | <b>✓</b>     | _           |  |
| Cyclone II                           | <b>✓</b>     | _           |  |
| Hardcopy® Series                     | <b>✓</b>     | _           |  |

#### *Notes to Table 2–1:*

- (1) PGA packages (represented as package type G in the ordering code) are not supported in the Quartus II software.
- (2) Some packages are not supported.

#### Quartus II GUI Overview

The Quartus II software provides the following utility windows to assist in the development of your designs:

- Project Navigator
- Node Finder
- Tcl Console
- Messages
- Status
- Change Manager

#### **Project Navigator**

The **Hierarchy** tab of the Project Navigator window is similar to the MAX+PLUS II Hierarchy Display and provides additional information such as logic cell, register, and memory bit resource utilization. The **Files** and **Design Units** tabs of the Project Navigator window provide a list of project files and design units.

#### **Node Finder**

The Node Finder window provides the equivalent functionality of the MAX+PLUS II **Search Node Database** dialog box and allows you to find and use any node name stored in the project database.

#### Tcl Console

The Tcl Console window allows access to the Quartus II Tcl shell from within the GUI. You can use the Tcl Console window to enter Tcl commands and source Tcl scripts to make assignments, perform customized timing analysis, view information about devices, or fully automate and customize the way you run all components of the Quartus II software. There is no equivalent functionality in the MAX+PLUS II software.



For more information on using Tcl with the Quartus II software, refer to the *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*.

#### Messages

The Messages window is similar to the Message Processor window in the MAX+PLUS II software, providing detailed information, warnings, and error messages. You also can use it to locate a node from a message to various windows in the Quartus II software.

## **Status**

The Status window displays information similar to the MAX+PLUS II Compiler window. Progress and elapsed time are shown for each stage of the compilation.

## **Change Manager**

The Change Manager provides detailed tracking information on all design changes made with the Chip Editor.



For more information about the Engineering Change Manager and the Chip Editor, refer to the *Design Analysis & Engineering Change Management with Chip Editor* chapter in volume 3 of the *Quartus II Handbook*.

Figure 2–2 shows a typical Quartus II software display.



Figure 2-2. Quartus II Look & Feel

Message: 0 of 287

■ Info: Running Quartus II EDA Netlist Writer

Info: Quartus II EDA Netlist Writer was successful. 0 errors, 0 warnings
Info: Quartus II Full Compilation was successful. 0 errors, 26 warnings

♣ P Locati

Info: Command: quartus\_eda -read\_settings\_files=off --write\_settings\_files=off chiptrip -c chiptrip

Info: Generated file chiptrip.vo in folder "C:/altera/chiptrip/simulation/modelsim/" for EDA simulation

System \ Processing \( Extra Info \) Info \( Warning \) Critical Warning \( Extra Info \) Suppressed

®•••

# Setting Up MAX+PLUS II Look & Feel in Quartus II

You can choose the MAX+PLUS II look and feel by selecting MAX+PLUS II in the **Look & Feel** box of the **General** tab of the **Customize** dialog box on the Tools menu.



Any changes to the look and feel do not become effective until you restart the Quartus II software.

By default, when you select the MAX+PLUS II look and feel, the MAX+PLUS II quick menu (Figure 2–21 on page 2–35) appears on the left side of the menu bar. You can turn the Quartus II and MAX+PLUS II quick menus on or off. You also can change the preferred positions of the two quick menus. To change these options, perform the following steps:

- On the Tools menu, click Customize. The Customize dialog box is shown.
- 2. Click the **General** tab.
- 3. Under Quick menus, select your preferred options.

# MAX+PLUS II Look & Feel

The MAX+PLUS II look and feel in the Quartus II software closely resembles the MAX+PLUS II software. Figures 2–3 and 2–4 compare the MAX+PLUS II software appearance with the Quartus II MAX+PLUS II look and feel.

Figure 2-3. MAX+PLUS II Software GUI





Figure 2-4. Quartus II Software with MAX+PLUS II Look & Feel

The standard MAX+PLUS II toolbar is also available in the Quartus II software with the MAX+PLUS II look and feel in the Quartus II software (Figure 2–5).





## **Compiler Tool**

The Quartus II Compiler Tool provides an intuitive MAX+PLUS II style interface. You can edit the settings and view result files for the following modules:

- Analysis & Synthesis
- Partition Merge
- Fitter
- Assembler
- Timing Analyzer
- EDA Netlist Writer
- Design Assistant

Each of these modules is described later in this section.

To start a compilation using the Compiler Tool, click **Compiler Tool** from either the MAX+PLUS II menu or the Tools menu and click **Start** in the Compiler Tool. The Compiler Tool, shown in Figure 2–6, displays all modules, including optional modules such as Partition Merge, Assembler, EDA Netlist Writer, and the Design Assistant.



For information about using the Quartus II software modules at the command line, refer to the *Command-Line Scripting* chapter in volume 2 of the *Quartus II Handbook*.

Figure 2-6. Running a Full Compilation with the Compiler Tool



## **Analysis & Synthesis**

The Quartus II Analysis & Synthesis module analyzes your design, builds the design database, optimizes the design for the targeted architecture, and maps the technology to the design logic.

In MAX+PLUS II software, these functions are performed by the Compiler Netlist Extractor, Database Builder, and Logic Synthesizer. There is no module in the Quartus II software similar to the MAX+PLUS II Partitioner module.

## **Partition Merge**

The optional Quartus II Partition Merge module merges the partitions to create a flattened netlist for further stages of the Quartus II compilation flow. The Partition Merge module is not similar to the MAX+PLUS II Partitioner. This tool is available only if you turn on incremental compilation. You can turn on incremental compilation by performing the following steps:

- On the Assignment menu, click Settings. The Settings dialog box appears.
- In the Category list, click the + icon to expand Compilation Process Settings, and select Incremental Compilation. The Full Incremental Compilation page appears.
- 3. Under **Incremental compilation**, turn on Incremental Compilation.

#### **Fitter**

The Quartus II Fitter module uses the PowerFit<sup>TM</sup> fitter to fit your design into the available resources of the targeted device. The Fitter places and routes the design. The Fitter module is similar to the Fitter stage of the MAX+PLUS II software.

## **Assembler**

The optional Quartus II Assembler module creates a device programming image of your design so that you can configure your device. You can select from the following types of programming images:

- Programmer Object File (.pof)
- SRAM Output File (.sof)
- Hexadecimal (Intel-Format) Output File (.hexout)
- Tabular Text File (.ttf)
- Raw Binary File (.rbf)
- Jam<sup>TM</sup> STAPL Byte Code 2.0 File (.jbc)
- JEDEC STAPL Format File (.jam)

You can turn off the Assembler module during compilation by turning off **Run assembler** in the **Compilation Process Settings** page in the **Settings** dialog box. You also can turn off the Assembler by right-clicking in the Compiler Tool window. The Assembler module is similar to the Assembler stage of the MAX+PLUS II software.

## **Timing Analyzer**

The Quartus II Timing Analyzer allows you to analyze more complex clocking schemes than is possible with the MAX+PLUS II Timing Analyzer. The Quartus II Timing Analyzer analyzes all clock domains in your design, including paths that cross clock domains, and also reports both f<sub>MAX</sub> and slack. Slack is the margin by which the timing requirement is met or is not met. For more information on the Timing Analyzer, refer to "Timing Analysis" on page 2–27.

## **EDA Netlist Writer**

The optional Quartus II EDA Netlist Writer module generates a netlist for simulation with an EDA simulation tool. The EDA Netlist Writer module is comparable to the VHDL and Verilog Netlist Writer in the MAX+PLUS II software.

## **Design Assistant**

The optional Quartus II Design Assistant module checks the reliability of your design based on a set of design rules. The Design Assistant analyzes and generates messages for a design targeting any Altera device and is especially useful for checking the reliability of a design to be converted to HardCopy series devices. The Design Assistant is similar to the Design Doctor in the MAX+PLUS II software.

In the Quartus II software, you can reduce subsequent compilation time significantly by turning **Use Smart compilation** on before compiling your design. The Smart Compilation feature skips any compilation stages which are not required and which may use more disk space. This Quartus II smart compilation option is similar to the MAX+PLUS II **Smart Recompile** command. To turn the **Use Smart compilation** option on, perform the following steps:

- On the Assignments menu, click Settings. The Settings dialog box appears.
- In the Category list, select Compilation Process Settings. The Compilation Process Settings page appears.
- 3. Turn on **Use Smart compilation**.

# MAX+PLUS II Design Conversion

With the Quartus II software, you can open MAX+PLUS II designs and convert MAX+PLUS II assignments and files.

The Quartus II software is project based. All the files for your design (HDL input, simulation vectors, assignments, and other relevant files) are associated with a project file. For more information about creating a new project, refer to "Creating a New Project" on page 2–16.

## Converting an Existing MAX+PLUS II Design

You can easily convert an existing MAX+PLUS II design for use with the Quartus II software with the **Convert MAX+PLUS II Project** command in the Quartus II software or the **Open Project** command. You can find these commands on the File menu

If you use the **Convert MAX+PLUS II Project** command, browse to the MAX+PLUS II Assignments and Configuration File (.acf) or top-level design file (Figure 2–7) and click **Open**. The **Convert MAX+PLUS II Project** command generates a Quartus II Project File (.qpf) and a Quartus II Settings File (.qsf). The Quartus II software stores project and design assignments in the Quartus II Settings File, which is equivalent to the Assignments and Configuration File in the MAX+PLUS II software.

You also can open and convert a MAX+PLUS II design with the **Open Project** command. In the **Open Project** dialog box, browse to the Assignments and Configuration File or the top-level design file. Click **Open** to display the **Convert MAX+PLUS II Project** dialog box.



The Quartus II software can import all MAX+PLUS II-generated files, but it cannot save files in the MAX+PLUS II format. You cannot open a Quartus II project in the MAX+PLUS II software, nor can you convert a Quartus II project to a MAX+PLUS II project.

Figure 2-7. Convert MAX+PLUS II Project Dialog Box



The conversion process performs the following actions:

- Converts the MAX+PLUS II Assignments and Configuration File into a Quartus II Settings File (equivalent to importing all MAX+PLUS II assignments)
- Creates a Quartus II Project File
- Displays all errors and warnings in the Quartus II message window



The Quartus II software can read MAX+PLUS II generated Graphic Design Files (.gdf) and Simulation Channel Files (.scf) without converting them. These files are not modified during a MAX+PLUS II design conversion.

## Converting MAX+PLUS II Graphic Design Files

The Quartus II Block Editor (similar to the MAX+PLUS II Graphic Editor) saves files as Block Design Files (.bdf). You can convert your MAX+PLUS II Graphic Design File into a Quartus II Block Design File using one of the following methods:

- 1. Open the Graphic Design File and on the File menu, click **Save As**. The **Save As** dialog box is shown.
- 2. In the Save as type list, select Block Diagram/Schematic File (\*.bdf).

3. Run the quartus\_g2b.exe command line executable located in the \<Quartus II installation>\bin directory. For example, to convert the chiptrip.gdf file to a Block Design File, type the following command at a command prompt:

```
quartus_g2b.exe chip_trip.gdf ←
```

## Importing MAX+PLUS II Assignments

You can import MAX+PLUS II assignments into an existing Quartus II project. Open the project, and on the Assignments menu, click **Import Assignments**. Browse to the Assignments and Configuration File (Figure 2–8). You can also import Quartus II Settings Files and Entity Setting Files (.esf).

Figure 2-8. Import Assignments Dialog Box



The Quartus II software accepts most MAX+PLUS II assignments. However, some assignments can be imported incorrectly from the MAX+ PLUS II software into the Quartus II software due to differences in node naming conventions and the advanced Quartus II integrated synthesis algorithms.

The differing node naming conventions in the Quartus II and MAX+PLUS II software can cause improper mapping when importing your design from MAX+PLUS II software into the Quartus II software. Improper node names can interfere with the design logic if you are unaware of these node name differences and do not take appropriate

steps to prevent improper node name mapping. Table 2–2 compares the differences between the naming conventions used by the Quartus II and MAX+PLUS II software.

| Table 2–2. Quartus II & MAX+PLUS II Node & Pin Naming Conventions |                  |                    |  |
|-------------------------------------------------------------------|------------------|--------------------|--|
| Feature Quartus II Format                                         |                  | MAX+PLUS II Format |  |
| Node name auto_max:auto q0                                        |                  | auto_max:auto q0   |  |
| Pin name                                                          | d[0], d[1], d[2] | d0, d1, d2         |  |

When you import MAX+PLUS II assignments containing node names that use numbers, such as signal0 or signal1, the Quartus II software imports the original assignment and also creates an additional copy of the assignment. The additional assignment has square brackets inserted around the number, resulting in signal[0] or signal[1]. The square bracket format is legal for signals that are part of a bus, but creates illegal signal names for signals that are not part of a bus in the Quartus II software. If your MAX+PLUS II design contains node names that end in a number and are not part of a bus, you can edit the Quartus II Settings File to remove the square brackets from the node names after importing them.



You can remove obsolete assignments in the **Remove Assignments** dialog box. Open this dialog box on the Assignments menu by clicking **Remove Assignments**.

The Quartus II software may not recognize valid MAX+PLUS II node names, or may split MAX+PLUS II nodes into two different nodes. As a result, any assignments made to synthesized nodes are not recognized during compilation.



For more information about Quartus II node naming conventions, refer to the *Quartus II Integrated Synthesis* chapter in volume 1 of the *Quartus II Handbook*.

# Quartus II Design Flow

The following sections include information to help you get started using the Quartus II software. They describe the similarities and differences between the Quartus II software and the MAX+PLUS II software. The following sections highlight improvements and benefits in the Quartus II software.

## **Creating a New Project**

The Quartus II software provides a wizard to help you create new projects. On the File menu, click **New Project Wizard** to start the New Project Wizard. The New Project Wizard generates the Quartus II Project File and Quartus II Settings File for your project.

## **Design Entry**

The Quartus II software supports the following design entry methods:

- Altera HDL (AHDL) Text Design File (.tdf)
- Block Diagram File
- EDIF Netlist File (.edf)
- Verilog Quartus Mapping Netlist File (.vqm)
- VHDL (.vhd)
- Verilog HDL (.v)

The Quartus II software has an advanced integrated synthesis engine that fully supports the Verilog HDL and VHDL languages and provides options to control the synthesis process.



For more information, refer to the *Quartus II Integrated Synthesis* chapter in volume 1 of the *Quartus II Handbook*.

To create a new design file, perform the following steps:

- 1. On the File menu, click **New**. The **New** dialog box appears.
- 2. Click the **Device Design Files** tab.
- 3. Select a design entry type.
- 4. Click **OK** (see Figure 2–9).



Figure 2-9. New Dialog Box



You can create other files from the **Software Files** tab and **Other Files** tab of the **New** dialog box on the File menu. For example, the Vector Waveform File (.vwf) is located in the **Other Files** tab.

To analyze a netlist file created by an EDA tool, perform the following steps:

- 1. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
- 2. In the **Category** list, select **Design Entry & Synthesis**. The **Design Entry & Synthesis** page appears.
- 3. In the **Tool** name list, select the synthesis tool used to generate the netlist (Figure 2–10).



Figure 2–10. Settings Dialog Box Specifying Design Entry Tool

The Quartus II Block Editor has many advantages over the MAX+PLUS II Graphic Editor. The Block Editor offers an unlimited sheet size, multiple region selections, an enhanced Symbol Editor, and conduits.

The Symbol Editor allows you to change the positions of the ports in a symbol (refer to the three images in Figure 2–11). You can reduce wire congestion around a symbol by changing the positions of the ports.



Figure 2–11. Various Port Position for a Symbol

To make changes to a symbol in a Block Design File, right-click a symbol in the Block Editor and select **Properties** to display the **Symbol Properties** dialog box. This dialog box allows you to change the instance name, add parameters, and specify the line and text color.

You can use conduits to connect blocks (including pins) in the Block Editor. Conduits contain signals for the connected objects (see Figure 2–12). You can determine the connections between various blocks in the **Conduit Properties** dialog box by right-clicking a conduit and clicking **Properties**.



Figure 2-12. Blocks & Pins Connected with Conduits

## **Making Assignments**

The Quartus II software stores all project and design assignments in a Quartus II Settings File, which is a collection of assignments stored as Tcl commands and organized by the compilation stage and assignment type. The Quartus II Settings File stores all assignments, regardless of how they are made, from the Floorplan Editor, the Pin Planner, the Assignment Editor, with Tcl, or any other method.

## Assignment Editor

The Assignment Editor is an intuitive spreadsheet interface designed to allow you to make, change, and manage a large number of assignments easily. With the Assignment Editor, you can list all available pin numbers and design pin names for efficiently creating pin assignments. You also can filter all assignments based on assignment categories and node names for viewing and creating assignments.

The Assignment Editor is composed of the Category Bar, Node Filter Bar, Information Bar, Edit Bar, and spreadsheet.

To make an assignment, follow these steps:

- On the Assignments menu, click Assignment Editor. The Assignment Editor window appears.
- 2. Select an assignment category in the **Category** bar.
- Select a node name using the Node Finder or type a node name filter into the Node Filter bar. (This step is optional; it excludes all assignments unrelated to the node name.)
- 4. Type the required values into the spreadsheet.
- 5. On the File menu, click Save.

If you are unsure about the purpose of a cell in the spreadsheet, select the cell and read the description displayed in the **Information** bar.

You can use the **Edit** bar to change the contents of multiple selected cells simultaneously. Select cells in the spreadsheet and type the value in the **Edit** box.

Other advantages of the Assignment Editor include clipboard support in the spreadsheet and automatic font coloring to identify the status of assignments.



For more information, refer to the *Assignment Editor* chapter in volume 1 of the *Quartus II Handbook*.

#### Timing Assignments

You can use the timing wizard to help you set your timing requirements. On the Assignments menu, click **Timing Wizard** to create global clock and timing settings. The settings include  $f_{MAX}$ , setup times, hold times, clock to output delay times, and individual absolute or derived clocks.

You also can set timing settings manually by performing the following steps:

- On the Assignments menu, click Settings. The Setting dialog box is shown.
- 2. In the Category list, select Timing Requirements & Options. The Timing Requirements & Options page is shown.
- 3. Set your timing settings.

You can make more complex timing assignments with the Quartus II software than allowed by the MAX+PLUS II software, including multicycle and point-to-point assignments using wildcards and time groups.



A time group is a collection of design nodes grouped together and represented as a single unit for the purpose of making timing assignments to the collection.

Multicycle timing assignments allow you to identify register-to-register paths in the design where you expect a delayed latch edge. This assignment enables accurate timing analysis of your design.

Point-to-point timing assignments allow you to specify the required delay between two pins, two registers, or a pin and a register. This assignment helps you optimize and verify your design timing requirements.

Wildcard characters "?" and "\*" allow you to apply an assignment to a large number of nodes with just a few assignments. For example, Figure 2–13 shows a 4 ns  $t_{\rm SU}$  requirement assignment to all paths from any node to the "d" bus in the Assignment Editor.

Assignment Editor All ▼ | 🙀 All 🕪 Pin | 💍 Timing | 🗈 Logic Options Category: XVI Edit: Value From То Enabled ₽ **∰** \* d[?] tsu Requirement 4 ns Yes <<new>> <<new>> 閉

Figure 2–13. Single  $t_{SII}$  Timing Assignment Applied to All Nodes of a Bus

•

For more information, refer to the *Classic Timing Analyzer* or the *TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

## **Synthesis**

The Quartus II advanced integrated synthesis software fully supports the hardware description languages, Verilog HDL, VHDL, and AHDL, schematic entry, and also provides options to control the synthesis process. With this synthesis support, the Quartus II software provides a complete, easy-to-use, stand-alone solution for today's designs.

You can specify synthesis options in the **Analysis & Synthesis Settings** page of the **Settings** dialog box. Similar to MAX+PLUS II synthesis options, you select one of these optimization techniques: **Speed, Area,** or **Balanced**.

To achieve higher design performance, you can turn on synthesis netlist optimizations that are available when targeting certain devices. You can unmap a netlist created by an EDA tool and remap the components in the netlist back to Altera primitives by turning on **Perform WYSIWYG primitive resynthesis**. Additionally, you can move registers across combinational logic to balance timing without changing design functionality by turning on **Perform gate-level register retiming**. Both of these options are accessible from the **Synthesis Netlist Optimizations** page under **Analysis & Synthesis Settings** in the **Settings** dialog box on the Assignments menu.



For more information, refer to the *Quartus II Integrated Synthesis* chapter in volume 1 of the *Quartus II Handbook*.

## **Functional Simulation**

Similar to the MAX+PLUS II Simulator, the Quartus II Simulator Tool performs both functional and timing simulations.

To open the Simulator Tool, on MAX+PLUS II menu, click **Simulator** or on the Tools menu, click **Simulator Tool**. Before you perform a functional simulation, an internal functional simulation netlist is required. Click **Generate Functional Simulation Netlist** in the **Simulator Tool** window (Figure 2–14), or on the Processing menu, click **Generate Functional Simulation Netlist**.



Generating a functional simulation netlist creates a separate database that improves the performance of the simulation significantly.

Simulator Tool Simulation mode: Functional Generate Functional Simulation Netlist Simulation input: chiptrip.sef Simulation period Run simulation until all vector stimuli are used End simulation at: 800.0 • Simulation options Automatically add pins to simulation output waveforms Check outputs Waveform Compare Settings Setup and hold time violation detection Glitch detection: 0.0 ns ▼ Overwrite simulation input file with simulation results Generate Signal Activity File: 00:00:00 ≿ Start and Stop 🀠 Open A Report

Figure 2-14. Simulator Tool Dialog Box

You can view and modify the simulator options on the **Simulator** page of the **Settings** dialog box or in the **Simulator Tool** window. You can set the simulation period and turn **Check outputs** on or off. You can choose to display the simulation outputs in the simulation report or in the Vector Waveform File. To display the simulation results in the simulation input vector waveform file, which is the MAX+PLUS II behavior, turn on **Overwrite simulation input file with simulation results**.

When using either the MAX+PLUS II or Quartus II software, you may have to compile additional behavioral models to perform a simulation with an EDA simulation tool. In the Quartus II software, behavioral models for library of parameterized modules (LPM) functions and Altera-specific megafunctions are available in the altera\_mf and 220model library files, respectively. The 220model and altera\_mf files can be found in the \<Quartus II Installation>\eda\sim\_lib directory.

The Quartus II schematic design files (Block Design File, or .bdf) are not compatible with EDA simulation tools. To perform a register transfer level (RTL) functional simulation of a Block Design File using an EDA tool, convert your schematic designs to a VHDL or Verilog HDL design file. Open the schematic design file and on the File menu, click Create/Update > Create HDL Design File for Current File to create an HDL design file that corresponds to your Block Design File.

You can export a Vector Waveform File or Simulator Channel File as a Verilog HDL or VHDL test bench file for simulation with an EDA tool. Open your Vector Waveform File or Simulator Channel File and on the File menu, click Export. See Figure 2–15. Select Verilog or VHDL Test Bench File (\*.vt) from the Save as type list. Turn on Add self-checking code to file to add additional self-checking code to the test bench.



Figure 2-15. Export Dialog Box

## Place & Route

The Quartus II PowerFit is an incremental fitter that performs place-and-route to fit your design into the targeted device. You can control the Fitter behavior with options in the **Fitter Settings** page of the **Settings** dialog box on the Assignments menu.

High-density device families supported in the Quartus II software, such as the Stratix series, sometimes require significant fitter effort to achieve an optimal fit. The Quartus II software offers several options to reduce the time required to fit a design. You can control the effort the Quartus II Fitter expends to achieve your timing requirements with these options:

- Optimize timing performs timing-based placement using the timing requirements you specify for the design. You can use this option by itself or with one or more of the options below.
- Optimize hold timing optimizes the hold times within a device to meet timing requirements and assignments you specify. You can select this option only if the Optimize timing option is also chosen.
- Optimize fast-corner timing instructs the Fitter, when optimizing your design, to consider fast-corner delays, in addition to slow-corner delays, from the fast-corner timing model (fastest manufactured device, operating in low-temperature and high-voltage conditions). You can select this option only if the Optimize timing option is also chosen.

If minimizing compilation time is more important than achieving specific timing results, you can turn these options off.

Another way to decrease the processing time and effort the Fitter expends to fit your design is to select either **Standard Fit** or **Fast Fit** in the **Fitter Effort** box of the **Fitter Settings** page in the **Settings** dialog box on the Assignments menu. The option you select affects the Fitter behavior and your design as described below.

- Select Standard Fit for the Fitter to use the highest effort and preserve the performance from previous compilations.
- Select Fast Fit for up to 50% faster compilation times, although this may reduce design performance.

You can also select **Auto Fit** to decrease compilation time by directing the Fitter to reduce Fitter effort after meeting your timing requirements. The **Auto Fit** option is available for select devices.



For more information, refer to the *Area & Timing Optimization* chapter in volume 2 of the *Quartus II Handbook*.

To further reduce compilation times, turn on **Limit to one fitting attempt** in the **Fitter Settings** page in the **Settings** dialog box on the Assignments menu.

If your design is very close to meeting your timing requirements, you can control the seed number used in the fitting algorithm by changing the value in the **Seed** box of the **Fitter Settings** page of the **Settings** dialog box on the Assignments menu. The default seed value is 1. You can specify any non-negative integer value. Changing the value of the seed only repositions the starting location of the Fitter, but does not affect compilation time or the Fitter effort level. However, if your design is difficult to fit optimally or takes a long time to fit, sometimes you can improve results or processing time by changing the seed value.

## **Timing Analysis**

You can use the Quartus II Timing Analyzer to analyze more complex clocking schemes than is possible with the MAX+PLUS II Timing Analyzer.

Launch the Timing Analyzer Tool on the MAX+PLUS II menu by clicking **Timing Analyzer** or on the Tools menu by clicking **Timing Analyzer Tool**. See Figure 2–16. To start the analysis, click **Start** in the Timing Analyzer Tool or on the Processing menu, by pointing to Start, and clicking **Start Timing Analyzer**.



Figure 2–16. Registered Performance Tab of the Timing Analyzer Tool

The Quartus II Timing Analyzer analyzes all clock domains in your design, including paths that cross clock domains. You can ignore paths that cross clock domains by using the following options in the **Timing Requirements & Options** page in the **Settings** dialog box on the Assignments menu:

- Create a Cut Timing Path assignment
- Turn on Cut paths between unrelated clock domains

To view the results from the Timing Analyzer Tool, you can click on the **Report**, or to get specific information, click on any of the following tabs at the top of the Timing Analyzer window:

- Registered Performance
- $t_{PD}$
- t<sub>SU</sub>
- t<sub>CO</sub>
- t<sub>H</sub>
- Custom Delays

The Quartus II Timing Analyzer reports both  $f_{MAX}$  and slack. Slack is the margin by which the timing requirement was met or not met. A positive slack value, displayed in black, indicates the margin by which a requirement was met. A negative slack value, displayed in red, indicates the margin by which a requirement was not met.

To analyze a particular path in more detail, select a path in the Timing Analyzer Tool and click **List Paths**. This displays a detailed description of the path in the **System** tab of the **Messages** window (Figure 2–17).

Figure 2–17. Messages Window Displaying Detailed Timing Information





For more information, refer to the *Classic Timing Analyzer* or the *TimeQuest Timing Analyzer* chapter in volume 3 of the *Quartus II Handbook*.

## **Timing Closure Floorplan**

The Quartus II Timing Closure Floorplan is similar to the MAX+PLUS II Floorplan Editor but has many improvements to help you more effectively view and debug your design. With its ability to display logic cell usage, routing congestion, critical paths, and LogicLock<sup>TM</sup> regions, the Timing Closure Floorplan also makes the task of improving your design performance much easier.

To view the Timing Closure Floorplan, on the MAX+PLUS II menu, click Floorplan Editor or Timing Closure Floorplan.

The Timing Closure Floorplan Editor provides Interior Cell views equivalent to the MAX+PLUS II logic array block (LAB) views. In addition to these views, available from the View menu, you also can select from the Interior MegaLABs (where applicable), Interior LABs, and Field views.



The Pin Planner is equivalent to the MAX+PLUS II Device view. The Pin Planner can be launched from the Timing Closure Floorplan Editor by selecting **Package** (Top or Bottom) from the View menu or on the Assignments menu by clicking **Pin Planner**.

The Interior LABs view hides cell details for logic cells, Adaptive Logic Modules (ALM), and macrocells, and shows LAB information (see Figure 2–18). You can display the number of cells used in each LAB on the View menu by clicking **Show Usage Numbers**.

Figure 2–18. Interior LAB View of the Timing Closure Floorplan



The Field view is a color-coded, high-level view of your device resources that hides both cell and LAB details. In the Field view, you can see critical paths and routing congestion in your design.

The View Critical Paths feature shows a percentage of all critical paths in your floorplan. You can enable this feature on the View menu by clicking **Show Critical Paths**. You can control the number of critical paths shown by modifying the settings in the **Critical Paths Settings** dialog box on the View menu.

The View Congestion feature displays routing congestion by coloring and shading logic resources. Darker shading shows greater resource utilization. This feature assists in identifying locations where there is a lack of routing resources.



To show lower level details in any view, right-click on a resource and click **Show Details**.



For more information, refer to the *Timing Closure Floorplan* chapter in volume 2 of the *Quartus II Handbook*.

## **Timing Simulation**

Timing simulation is an important part of the verification process. The Quartus II software supports native timing simulation and exports simulation netlists to third-party software for design verification.

#### Quartus II Simulator Tool

The Quartus II Simulator tool is an easy-to-use integrated solution that uses the compiler database to simulate the logical and timing performance of your design (Figure 2–19). When performing timing simulation, the simulator uses place-and-route timing information.



Figure 2-19. Quartus II Simulator Tool

You can use Vector Table Output Files (.tbl), Vector Waveform Files, Vector Files (.vec), or an existing Simulator Channel File as the vector stimuli for your simulation.

The simulation options available are similar to the options available in the MAX+PLUS II Simulator. You can control the length of the simulation and the type of checks performed by the Simulator. When the MAX+PLUS II look and feel is selected, the **Overwrite simulation input file with simulation results** option is on by default. If you turn it off, the simulation results are written to the report file. To view the report file, click **Report** in the Simulator Tool window.

## EDA Timing Simulation

The Quartus II software also supports timing simulation with other EDA simulation software. Performing timing simulation with other EDA simulation software requires a Quartus II generated timing netlist file in the form of a Verilog Output File (.vo) or VHDL Output File (.vho), a Standard Delay Format Output File (.sdo), and a device-specific atom file (or files), shown in Table 2–3.

| Table 2–3. Altera Timing Simulation Library Files  |                                                           |
|----------------------------------------------------|-----------------------------------------------------------|
| Verilog                                            | VHDL                                                      |
| <pre><device_family>_atoms.v</device_family></pre> | <pre><device_family>_atoms_87.vhd</device_family></pre>   |
|                                                    | <pre><device_family>_atoms.vhd</device_family></pre>      |
|                                                    | <pre><device_family>_components.vhd</device_family></pre> |

Specify your EDA simulation tool by performing the following steps:

- 1. On the Assignments menu, click **EDA Tool Settings**. The **Settings** dialog box appears.
- In the Category list, select Simulation. The Simulation page appears.
- 3. In the **Tool name list**, select your EDA Tool.

You can generate a timing netlist for the selected EDA simulator tool by running a full compile or on the Processing menu, by pointing to Start and clicking **Start EDA Netlist Writer**. The generated netlist and SDF file are placed into the *\project directory* **\simulation** *\<EDA simulator tool* directory. The device-specific atom files are located in the *\<Quartus II Install* **\\eda\\sim\_lib** directory.

#### **Power Estimation**

To develop an appropriate power budget and to design the power supplies, voltage regulators, heat sink, and cooling system, you need an accurate estimate of the power that your design consumes. You can estimate power by using the PowerPlay Early Power Estimation spreadsheet available on the Altera Web Site at www.altera.com, or with the PowerPlay Power Analyzer in the Quartus II software.

You can perform early power estimation with the PowerPlay Early Power Estimation spreadsheet by entering device resource and performance information. The Quartus II PowerPlay Analyzer tool performs vector-based power analysis by reading either a Signal Activity File (.saf), generated from a Quartus II simulation, or a Value Change Dump File (VCD) generated from a third-party simulation.



For more information about how to use the PowerPlay Power Analyzer tool, refer to the *PowerPlay Power Analysis* chapter in volume 3 of the *Quartus II Handbook*.

## **Programming**

The Quartus II Programmer has the same functionality as the MAX+PLUS II Programmer, including programming, verifying, examining, and blank checking operations. Additionally, the Quartus II Programmer now supports the erase capability for CPLDs. To improve usability, the Quartus II Programmer displays all programming-related information in one window (Figure 2–20).

Click **Add File** or **Add Device** in the Programmer window to add a file or device, respectively.

Figure 2-20. Programmer Window





Figure 2–20 shows that the Programmer Window now supports Erase capability.

You can save the programmer settings as a Chain Description File (.cdf). The CDF is an ASCII text file that stores device name, device order, and programming file name information.

## **Conclusion**

The Quartus II software is the most comprehensive design environment available for programmable logic designs. Features such as the MAX+PLUS II look and feel help you make the transition from Altera's MAX+PLUS II design software and become more productive with the Quartus II software. The Quartus II software has all the capabilities and features of the MAX+PLUS II software and many more to speed up your design cycle.

# Quick Menu Reference

The commands displayed in the MAX+PLUS II Quick Menu and the Quartus II Quick Menu vary based on whichever window is active (Figures 2–21). In the following figure, the Graphic Editor window is active.

Figure 2–21. MAX+PLUS II Quick Menus in MAX+PLUS II and Quartus II Software

MAX+PLUS II Quick Menu



MAX+PLUS II Quick Menu in Quartus II Software



# Quartus II Command Reference for MAX+PLUS II Users

Table 2–4 lists the commands in the MAX+PLUS II software and gives their equivalent commands in the Quartus II software.

NA means either Not Applicable or Not Available. If a command is not listed, then the command is the same in both tools.

| Tabi                 | Table 2–4. Quartus II Command Reference for MAX+PLUS II Users (Part 1 of 10) |                                                                |
|----------------------|------------------------------------------------------------------------------|----------------------------------------------------------------|
| MAX+PLUS II Software |                                                                              | Quartus II Software                                            |
| MAX+PLUS II Menu     |                                                                              |                                                                |
|                      | Hierarchy Display                                                            | View menu, Utility Windows, Project Navigator                  |
| S                    | Graphic Editor                                                               | Block Editor                                                   |
| S                    | Symbol Editor                                                                | Block Symbol Editor                                            |
| 0                    | Text Editor                                                                  | Text Editor                                                    |
|                      | Waveform Editor                                                              | Waveform Editor                                                |
| S                    | Floorplan Editor                                                             | Assignments menu, Timing Closure Floorplan                     |
|                      | Compiler                                                                     | Tools menu, Compiler Tool                                      |
|                      | Simulator                                                                    | Tools menu, Simulator Tool                                     |
|                      | Timing Analyzer                                                              | Tools menu, Timing Analyzer Tool                               |
|                      | Programmer                                                                   | Tools menu, Programmer                                         |
| *                    | Message Processor                                                            | View menu, Utility Windows, Messages                           |
| File Menu            |                                                                              |                                                                |
| 基                    | File menu, Project, Name (Ctrl+J)                                            | File menu, Open Project (Ctrl+J)                               |
| 靐                    | File menu, Project, <b>Set Project to Current File</b> (Ctrl+Shift+J)        | Project menu, Set as Top-Level Entity (Ctrl+Shift+J)           |
|                      |                                                                              | File menu, New Project Wizard                                  |
|                      | File menu, Project, Save & Check (Ctrl+K)                                    | Processing menu, Start, Start Analysis & Synthesis (Ctrl+K) or |
|                      |                                                                              | Processing menu, Start, Start Analysis & Elaboration           |
|                      | File menu, Project, Save & Compile (Ctrl+L)                                  | Processing menu, Start Compilation (Ctrl+L)                    |

| Table 2–4. Quartus II Command Reference for MAX+PLUS II Users (Part 2 of 10) |                                                                                        |  |
|------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|--|
| MAX+PLUS II Software                                                         | Quartus II Software                                                                    |  |
| File menu, Project, Save & Simulate (Ctrl+Shift+L)                           | Processing menu, Start Simulation (Ctrl+I)                                             |  |
| File menu, Project, <b>Compile &amp; Simulate</b> (Ctrl+Shift+K)             | Processing menu, Start Compilation & Simulation (Ctrl+Shift+K)                         |  |
| File menu, Project, Archive                                                  | Project menu, Archive Project                                                          |  |
| File menu, Project, < Recent Projects>                                       | File menu, < Recent Projects>                                                          |  |
| File menu, <b>Delete File</b>                                                | NA                                                                                     |  |
| File menu, <b>Retrieve</b>                                                   | NA                                                                                     |  |
| File menu, Info (Ctrl+I)                                                     | File menu, File Properties                                                             |  |
| File menu, Create Default Symbol                                             | File menu, Create/Update, Create Symbol Files for Current File                         |  |
| File menu, Edit Symbol                                                       | (Block Editor) Edit menu, Edit Selected Symbol                                         |  |
| File menu, Create Default Include File                                       | File menu, Create/Update, Create AHDL Include Files for Current File                   |  |
| File menu, Hierarchy Project Top (Ctrl+T)                                    | Project menu, Hierarchy, Project Top (Ctrl+T)                                          |  |
| File menu, Hierarchy, <b>Up</b> (Ctrl+U)                                     | Project menu, Hierarchy, <b>Up</b> (Ctrl+U)                                            |  |
| File menu, Hierarchy, <b>Down</b> (Ctrl+D)                                   | Project menu, Hierarchy, <b>Down</b> (Ctrl+D)                                          |  |
| File menu, Hierarchy, <b>Top</b>                                             | NA                                                                                     |  |
| File menu, Hierarchy, Project Top (Ctrl+T)                                   | Project menu, Hierarchy, Project Top (Ctrl+T)                                          |  |
| File menu, MegaWizard Plug-In Manager                                        | Tools menu, MegaWizard Plug-In Manager                                                 |  |
| (Graphic Editor) File menu, Size                                             | NA                                                                                     |  |
| (Waveform Editor) File menu, End Time                                        | (Waveform Editor) Edit menu, End Time                                                  |  |
| (Waveform Editor) File menu, Compare                                         | (Waveform Editor) View menu, Compare to Waveforms in File                              |  |
| (Waveform Editor) File menu, Import Vector File                              | File menu, Open (Ctrl+O)                                                               |  |
| (Waveform Editor) File menu, Create Table File                               | File menu, Save As                                                                     |  |
| (Hierarchy Display) File menu, Select Hierarchy                              | NA                                                                                     |  |
| (Hierarchy Display) File menu, Open Editor                                   | (Project Navigator) Double-click                                                       |  |
| (Hierarchy Display) File menu, Close Editor                                  | NA                                                                                     |  |
| (Hierarchy Display) File menu, Change File Type                              | (Project Navigator) Select file in Files tab and select Properties on right click menu |  |
| (Hierarchy Display) File menu, Print Selected Files                          | NA                                                                                     |  |

| MAX+PLUS II Software                                             | Quartus II Software                                                                                              |
|------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| (Programmer) File menu, Select Programming File                  | File menu, <b>Open</b>                                                                                           |
| (Programmer) File menu, Save Programming<br>Data As              | File menu, Save                                                                                                  |
| (Programmer) File menu, Inputs/Outputs                           | NA                                                                                                               |
| (Programmer) File menu, Convert SRAM Object Files                | File menu, Convert Programming Files                                                                             |
| (Programmer) File menu, <b>Archive JTAG Programming Files</b>    | NA                                                                                                               |
| (Programmer) File menu, Create Jam or SVF File                   | File menu, Create/Update, Create JAM, SVF, or ISC File                                                           |
| (Message Processor) Select Messages                              | NA                                                                                                               |
| (Message Processor) Save Messages As                             | (Messages) Save Messages on right click menu                                                                     |
| (Timing Analyzer) Save Analysis As                               | Processing menu, <b>Compilation Report</b> - Save Current Report on right click menu in Timing Analyzer sections |
| (Simulator) Create Table File                                    | (Waveform Editor) File menu, Save As                                                                             |
| (Simulator) Execute Command File                                 | NA                                                                                                               |
| (Simulator) Inputs/Outputs                                       | NA                                                                                                               |
| Edit Menu                                                        |                                                                                                                  |
| (Waveform Editor) Edit menu, Overwrite                           | (Waveform Editor) Edit menu, Value                                                                               |
| (Waveform Editor) Edit menu, Insert                              | (Waveform Editor) Edit menu, Insert Waveform Interval                                                            |
| (Waveform Editor) Edit menu, <b>Align to Grid</b> (Ctrl+Y)       | NA                                                                                                               |
| (Waveform Editor) Edit menu, Repeat                              | (Waveform Editor) Edit menu, Repeat Paste                                                                        |
| (Waveform Editor) Edit menu, Grow or Shrink                      | Edit menu, Grow or Shrink (Ctrl+Alt+G)                                                                           |
| (Text Editor) Edit menu, Insert Page Break                       | (Text Editor) Edit menu, Insert Page Break                                                                       |
| (Text Editor) Edit menu, Increase Indent (F2)                    | (Text Editor) Edit menu, Increase Indent                                                                         |
| (Text Editor) Edit menu, <b>Decrease Indent</b> (F3)             | (Text Editor) Edit menu, Decrease Indent                                                                         |
| (Graphic Editor) Edit menu, Toggle Connection Dot (Double-Click) | (Block Editor) Edit menu, Toggle Connection Dot                                                                  |
| (Graphic Editor) Edit menu, Flip Horizontal                      | (Block Editor) Edit menu, Flip Horizontal                                                                        |
| (Graphic Editor) Edit menu, Flip Vertical                        | (Block Editor) Edit menu, Flip Vertical                                                                          |
| (Graphic Editor) Edit menu, Rotate                               | (Block Editor) Edit menu, Rotate by Degrees                                                                      |

|                                                          | IAX+PLUS II Users (Part 4 of 10)                                              |
|----------------------------------------------------------|-------------------------------------------------------------------------------|
| MAX+PLUS II Software                                     | Quartus II Software                                                           |
| View Menu                                                |                                                                               |
| View menu, Fit in Window (Ctrl+W)                        | View menu, Fit in Window (Ctrl+W)                                             |
| View menu, <b>Zoom In</b> (Ctrl+Space)                   | View menu, <b>Zoom In</b> (Ctrl+Space)                                        |
| View menu, <b>Zoom Out</b> (Ctrl+Shift+Space)            | View menu, Zoom Out (Ctrl+Shift+Space)                                        |
| View menu, Normal Size (Ctrl+1)                          | NA                                                                            |
| View menu, Maximum Size (Ctrl+2)                         | NA                                                                            |
| (Hierarchy Display) View menu, <b>Auto Fit in Window</b> | NA                                                                            |
| (Waveform Editor) View menu, Time Range                  | View menu, <b>Zoom</b>                                                        |
| Assign menu, <b>Device</b>                               | Assignments menu, <b>Device</b>                                               |
|                                                          | Assignments menu, Settings (Ctrl+Shift+E)                                     |
| Assign menu, Pin/Location/Chip                           | Assignments menu, Assignment Editor - Locations category                      |
| Assign menu, Timing Requirements                         | Assignments menu, Assignment Editor - Timing category                         |
| Assign menu, Clique                                      | Assignments menu, Assignment Editor - Cliques category                        |
| Assign menu, Logic Options                               | Assignments menu, Assignment Editor - Logic Options category                  |
| Assign menu, <b>Probe</b>                                | NA                                                                            |
| Assign menu, Connected Pins                              | Assignments menu, Assignment Editor - Simulation category                     |
| Assign menu, Local Routing                               | Assignments menu, Assignment Editor - Local Routing category                  |
| Assign menu, Global Project Device Options               | Assignments menu, <b>Device</b> - Device & Pin Options                        |
| Assign menu, Global Project Parameters                   | Assignments menu, <b>Settings</b> - Analysis & Synthesis - Default Parameters |
| Assign menu, Global Project Timing Requirements          | Assignments menu, Timing Settings                                             |
| Assign menu, Global Project Logic Synthesis              | Assignments menu, Settings - Analysis & Synthesis                             |
| Assign menu, Ignore Project Assignments                  | Assignments menu, Assignment Editor - disable                                 |
| Assign menu, Clear Project Assignments                   | Assignments menu, Remove Assignments                                          |
| Assign menu, Back-Annotate Project                       | Assignments menu, Back-Annotate Assignments                                   |

| Table 2–4. Quartus II Command Reference for MAX+PLUS II Users (Part 5 of 10) |                                                                                 |  |
|------------------------------------------------------------------------------|---------------------------------------------------------------------------------|--|
| MAX+PLUS II Software                                                         | Quartus II Software                                                             |  |
| Assign menu, Convert Obsolete Assignment Format                              | NA                                                                              |  |
| Utilities Menu                                                               |                                                                                 |  |
| Utilities menu, Find Text (Ctrl+F)                                           | Edit menu, <b>Find</b> (Ctrl+F)                                                 |  |
| Utilities menu, Find Node in Design File (Ctrl+B)                            | Project menu, Locate, Locate in Design File                                     |  |
| Utilities menu, Find Node in Floorplan                                       | Project menu, Locate, Locate in Timing Closure Floorplan                        |  |
| Utilities menu, Find Clique in Floorplan                                     | NA                                                                              |  |
| Utilities menu, Find Node Source (Ctrl+Shift+S)                              | NA                                                                              |  |
| Utilities menu, Find Node Destination (Ctrl+Shift+D)                         | NA                                                                              |  |
| Utilities menu, Find Next (Ctrl+N)                                           | Edit menu, Find Next (F3)                                                       |  |
| Utilities menu, Find Previous (Ctrl+Shift+N)                                 | NA                                                                              |  |
| Utilities menu, Find Last Edit                                               | NA                                                                              |  |
| Utilities menu, Search and Replace (Ctrl+R)                                  | Edit menu, Replace (Ctrl+H)                                                     |  |
| Utilities menu, Timing Analysis Source (Ctrl+Alt+S)                          | NA                                                                              |  |
| Utilities menu, <b>Timing Analysis Destination</b> (Ctrl+Alt+D)              | NA                                                                              |  |
| Utilities menu, <b>Timing Analysis Cutoff</b> (Ctrl+Alt+C)                   | NA                                                                              |  |
| Utilities menu, Analyze Timing                                               | NA                                                                              |  |
| Utilities menu, Clear All Timing Analysis Tags                               | NA                                                                              |  |
| (Text Editor) Utilities menu, <b>Go To</b> (Ctrl+G)                          | Edit menu, <b>Go To</b> (Ctrl+G)                                                |  |
| (Text Editor) Utilities menu, Find Matching Delimiter (Ctrl+M)               | (Text Editor) Edit, Find Matching Delimiter (Ctrl+M)                            |  |
| (Waveform Editor) Utilities menu, Find Next<br>Transition (Right Arrow)      | (Waveform Editor) View menu, <b>Next Transition</b> (Right Arrow)               |  |
| (Waveform Editor) Utilities menu, Find Previous Transition (Left Arrow)      | (Waveform Editor) View menu, <b>Next Transition</b> (Left Arrow)                |  |
| Options Menu                                                                 |                                                                                 |  |
| Options menu, User Libraries                                                 | Assignments menu, Settings (Ctrl+Shift+E) Tools, Options, Global User Libraries |  |
| Options menu, Color Palette                                                  | Tools menu, <b>Options</b>                                                      |  |

| MAX+PLUS II Software                                                           | Quartus II Software                                   |  |
|--------------------------------------------------------------------------------|-------------------------------------------------------|--|
| Options menu, License Setup                                                    | Tools menu, License Setup                             |  |
| Options menu, <b>Preferences</b>                                               | Tools menu, <b>Options</b>                            |  |
| (Hierarchy Display) Options menu, Orientation                                  | NA                                                    |  |
| (Hierarchy Display) Options menu, Compact Display                              | NA                                                    |  |
| (Hierarchy Display) Options menu, Show All<br>Hierarchy Branches               | (Project Navigator) Expand All on right click menu    |  |
| (Hierarchy Display) Options menu, Hide All<br>Hierarchy Branches               | NA                                                    |  |
| (Editors) Options menu, Font                                                   | Tools menu, <b>Options</b>                            |  |
| (Editors) Options menu, Text Size                                              | Tools menu, <b>Options</b>                            |  |
| (Graphic Editor) Options menu, Line Style                                      | Edit menu, <b>Line</b>                                |  |
| (Graphic Editor) Options menu,  Rubberbanding                                  | Tools menu, <b>Options</b>                            |  |
| (Graphic Editor) Options menu, Show Parameters                                 | View menu, Show Parameter Assignments                 |  |
| (Graphic Editor) Options menu, Show Probes                                     | NA                                                    |  |
| (Graphic Editor) Options menu, Show Pins/Locations/Chips                       | View menu, Show Pin and Location Assignments          |  |
| (Graphic Editor) Options menu, Show Clique, Timing & Local Routing Assignments | NA                                                    |  |
| (Graphic Editor) Options menu, Show Logic Options                              | NA                                                    |  |
| (Graphic Editor) Options menu, Show All (Ctrl+Shift+M)                         | NA                                                    |  |
| (Graphic Editor) Options menu, <b>Show Guidelines</b> (Ctrl+Shift+G)           | Tools menu, <b>Options</b> - Block/Symbol Editor page |  |
| (Graphic Editor) Options menu, Guideline Spacing                               | Tools menu, <b>Options</b> - Block/Symbol Editor page |  |
| (Symbol Editors) Options menu, Snap to Grid                                    | Tools menu, <b>Options</b> - Block/Symbol Editor page |  |
| (Text Editor) Options menu, <b>Tab Stops</b>                                   | Tools menu, <b>Options</b> - Text Editor page         |  |
| (Text Editor) Options menu, Auto-Indent                                        | Tools menu, <b>Options</b> - Text Editor page         |  |
| (Text Editor) Options menu, Syntax Coloring                                    | NA                                                    |  |
| (Waveform Editor) Options menu, Snap to Grid                                   | View menu, Snap to Grid                               |  |
| (Waveform Editor) Options menu, <b>Show Grid</b> (Ctrl+Shift+G)                | Tools menu, <b>Options</b> - Waveform Editor page     |  |
| ` '                                                                            |                                                       |  |

| MAX+PLUS II Software                                                    | Quartus II Software                                    |  |  |
|-------------------------------------------------------------------------|--------------------------------------------------------|--|--|
| (Floorplan Editor) Options menu, <b>Routing</b><br><b>Statistics</b>    | NA                                                     |  |  |
| (Floorplan Editor) Options menu, Show Node Fan-In                       | View menu, Routing, Show Fan-In                        |  |  |
| (Floorplan Editor) Options menu, Show Node Fan-Out                      | View menu, Routing, Show Fan-Out                       |  |  |
| (Floorplan Editor) Options menu, Show Path                              | View menu, Routing, Show Paths between Nodes           |  |  |
| (Floorplan Editor) Options menu, Show Moved Nodes in Gray               | NA                                                     |  |  |
| (Simulator) Options menu, Breakpoint                                    | Processing menu, Simulation Debug, Breakpoints         |  |  |
| (Simulator) Options menu, Hardware Setup                                | NA                                                     |  |  |
| (Timing Analyzer) Options menu, <b>Time</b><br><b>Restrictions</b>      | Assignments menu, Timing Settings                      |  |  |
| (Timing Analyzer) Options menu,<br><b>Auto-Recalculate</b>              | NA                                                     |  |  |
| (Timing Analyzer) Options menu, Cell Width                              | NA                                                     |  |  |
| (Timing Analyzer) Options menu, Cut Off I/O Pin Feedback                | Assignments menu, Timing Settings                      |  |  |
| (Timing Analyzer) Options menu, <b>Cut Off Clear &amp; Reset Paths</b>  | Assignments menu, Timing Settings                      |  |  |
| (Timing Analyzer) Options menu, Cut Off Read During Write Paths         | Assignments menu, Timing Settings                      |  |  |
| (Timing Analyzer) Options menu, <b>List Only</b><br><b>Longest Path</b> | NA                                                     |  |  |
| (Programmer) Options menu, <b>Sound</b>                                 | NA                                                     |  |  |
| (Programmer) Options menu, <b>Programming Options</b>                   | Tools menu, Options - Programmer page                  |  |  |
| (Programmer) Options menu, Select Device                                | (Programmer) Edit menu, Change Device                  |  |  |
| (Programmer) Options menu, Hardware Setup                               | (Programmer) Edit menu, Hardware Setup                 |  |  |
| Symbol (Graphic Editor)                                                 |                                                        |  |  |
| Symbol menu, <b>Enter Symbol</b> (Double-Click)                         | (Block Editor) Edit menu, Insert Symbol (Double-Click) |  |  |
| Symbol menu, <b>Update Symbol</b>                                       | Edit menu, Update Symbol or Block                      |  |  |
| Symbol menu, Edit Ports/Parameters                                      | Edit menu, <b>Properties</b>                           |  |  |
| Element (Symbol Editor)                                                 |                                                        |  |  |
| Element menu, Enter Pinstub                                             | Double-click on edge of symbol                         |  |  |

| MAX+PLUS II Software                           | Quartus II Software                                     |  |
|------------------------------------------------|---------------------------------------------------------|--|
| Element menu, Enter Parameters                 | NA                                                      |  |
| Templates (Text Editor)                        |                                                         |  |
| Templates                                      | (Text Editor) Edit menu, Insert Template                |  |
| Node (Waveform Editor)                         |                                                         |  |
| Node menu, Insert Node (Double-Click)          | Edit menu, Insert Node or Bus (Double-Click)            |  |
| Node menu, Enter Nodes from SNF                | Edit menu, Insert Node - click on Node Finder           |  |
| Node menu, <b>Edit Node</b>                    | Double-click on the Node                                |  |
| Node menu, Enter Group                         | Edit menu, <b>Group</b>                                 |  |
| Node menu, <b>Ungroup</b>                      | Edit menu, <b>Ungroup</b>                               |  |
| Node menu, <b>Sort Names</b>                   | Edit menu, Sort                                         |  |
| Node menu, Enter Separator                     | NA                                                      |  |
| Layout (Floorplan Editor)                      |                                                         |  |
| Layout menu, Full Screen                       | View menu, Full Screen (Ctrl+Alt+Space)                 |  |
| Layout menu, Report File Equation Viewer       | View menu, Equations                                    |  |
| Layout menu, <b>Device View</b> (Double-Click) | View menu, Package Top                                  |  |
|                                                | or                                                      |  |
|                                                | View menu, Package Bottom                               |  |
| Layout menu, LAB View (Double-Click)           | View menu, Interior Labs                                |  |
| Layout menu, Current Assignments Floorplan     | View menu, Assignments, Show User Assignments           |  |
| Layout menu, Last Compilation Floorplan        | View menu, Assignments, Show Fitter Assignments         |  |
| Processing (Compiler)                          |                                                         |  |
| Processing menu, <b>Design Doctor</b>          | Processing menu, Start, Start Design Assistant          |  |
| Processing menu, <b>Design Doctor Settings</b> | Assignments menu, <b>Settings</b> - Design Assistant    |  |
| Processing menu, Functional SNF Extractor      | Processing menu, Generate Functional Simulation Netlist |  |
| Processing menu, Timing SNF Extractor          | Processing menu, Start Analysis & Synthesis             |  |
| Processing menu, Optimize Timing SNF           | NA                                                      |  |
|                                                |                                                         |  |

| Table 2–4. Quartus II Command Reference for MAX+PLUS II Users (Part 9 of 10) |                                                         |  |  |  |
|------------------------------------------------------------------------------|---------------------------------------------------------|--|--|--|
| MAX+PLUS II Software                                                         | Quartus II Software                                     |  |  |  |
| Processing menu, Fitter Settings                                             | Assignments menu, <b>Settings</b> - Fitter Settings     |  |  |  |
| Processing menu, Report File Settings                                        | Assignments menu, Settings                              |  |  |  |
| Processing menu, Generate AHDL TDO File                                      | NA                                                      |  |  |  |
| Processing menu, Smart Recompile                                             | Assignments menu, <b>Settings</b> - Compilation Process |  |  |  |
| Processing menu, Total Recompile                                             | Assignments menu, <b>Settings</b> - Compilation Process |  |  |  |
| Processing menu, Preserve All Node Name<br>Synonyms                          | Assignments menu, Settings - Compilation Process        |  |  |  |
| Interfaces (Compiler)                                                        | Assignments menu, EDA Tool Settings                     |  |  |  |
| Initialize (Simulator)                                                       |                                                         |  |  |  |
| Initialize menu, Initialize Nodes/Groups                                     | NA                                                      |  |  |  |
| Initialize menu, Initialize Memory                                           | NA                                                      |  |  |  |
| Initialize menu, Save Initialization As                                      | NA                                                      |  |  |  |
| Initialize menu, Restore Initialization                                      | NA                                                      |  |  |  |
| Initialize menu, Reset to Initial SNF Values                                 | NA                                                      |  |  |  |
| Node (Timing Analyzer)                                                       |                                                         |  |  |  |
| Node menu, <b>Timing Analysis Source</b> (Ctrl+Alt+S)                        | NA                                                      |  |  |  |
| Node menu, <b>Timing Analysis Destination</b> (Ctrl+Alt+D)                   | NA                                                      |  |  |  |
| Node menu, Timing Analysis Cutoff (Ctrl+Alt+C)                               | NA                                                      |  |  |  |
| Analysis (Timing Analyzer)                                                   |                                                         |  |  |  |
| Analysis menu, <b>Delay Matrix</b>                                           | (Timing Analyzer Tool) Delay tab                        |  |  |  |
| Analysis menu, Setup/Hold Matrix                                             | NA                                                      |  |  |  |
| Analysis menu, Registered Performance                                        | (Timing Analyzer Tool) Registered Performance tab       |  |  |  |
| JTAG (Programmer)                                                            |                                                         |  |  |  |
| JTAG menu, Multi-Device JTAG Chain                                           | (Programmer) Mode: JTAG                                 |  |  |  |
| JTAG menu, Multi-Device JTAG Chain Setup                                     | (Programmer) Window                                     |  |  |  |
| JTAG menu, Save JCF                                                          | File menu, <b>Save</b>                                  |  |  |  |
| JTAG menu, Restore JCF                                                       | File menu, <b>Open</b>                                  |  |  |  |
| JTAG menu, Initiate Configuration from Configuration Device                  | Tools menu, <b>Options</b> - Programmer page            |  |  |  |

| Table 2–4. Quartus II Command Reference for MAX+PLUS II Users (Part 10 of 10) |                                   |  |
|-------------------------------------------------------------------------------|-----------------------------------|--|
| MAX+PLUS II Software Quartus II Software                                      |                                   |  |
| FLEX (Programmer)                                                             |                                   |  |
| FLEX menu, Multi-Device FLEX Chain                                            | (Programmer) Mode: Passive Serial |  |
| FLEX menu, Multi-Device FLEX Chain Setup                                      | (Programmer) Window               |  |
| FLEX menu, Save FCF                                                           | menu, Save FCF File menu, Save    |  |
| FLEX menu, Restore FCF                                                        | File menu, <b>Open</b>            |  |



# 3. Quartus II Support of HardCopy Series Devices

QII51004-6.0.0

# Introduction

This chapter includes Quartus<sup>®</sup> II Support for HardCopy<sup>®</sup> II and HardCopy Stratix devices. This chapter is divided into the following sections:

- Quartus II Support for HardCopy II Devices
- Quartus II Support for HardCopy Stratix<sup>®</sup> Devices

# HardCopy II Device Support

Altera® HardCopy II devices feature 1.2-V, 90 nm process technology, and provide a structured ASIC alternative to increasingly expensive multi-million gate ASIC designs. The HardCopy II design methodology offers a fast time-to-market schedule, providing ASIC designers with a solution to long ASIC development cycles. Using the Quartus II software, you can leverage a Stratix II FPGA as a prototype and seamlessly migrate your design to a HardCopy II device for production.

This document discusses the following topics:

- HardCopy II design development flow and companion devices
- HardCopy II Device Resource Guide
- Recommended Quartus II software settings
- HardCopy II Utilities menu options and functions



For more information about HardCopy II, HardCopy Stratix, and HardCopy APEX $^{\text{TM}}$  devices, refer to the respective device data sheets in the *HardCopy Series Handbook*.

# HardCopy II Design Benefits

Designing with HardCopy II structured ASICs offers substantial benefits over other structured ASIC offerings:

- Prototyping using a Stratix II FPGA for functional verification and system development reduces total project development time
- Seamless migration from a Stratix II FPGA prototype to a HardCopy II device reduces time to market and risk
- Unified design methodology for Stratix II FPGA design and HardCopy II design reduces the need for ASIC development software
- Low up-front development cost of HardCopy II devices reduces the financial risk to your project

#### Quartus II Features for HardCopy II Planning

With the Quartus II software you can design a HardCopy II device using a Stratix II device as a prototype. The Quartus II software contains the following expanded features for HardCopy II device planning:

 HardCopy II Companion Device Assignment—Identifies compatible HardCopy II devices for migration with the Stratix II device currently selected.



This feature constrains the pins of your Stratix II FPGA prototype making it compatible with your HardCopy II device. It also constrains the correct resources available for the HardCopy II device making sure that your Stratix II FPGA design does not become incompatible.

- HardCopy II Utilities—The HardCopy II Utilities functions create or overwrites HardCopy II companion revisions, change revisions to use, and compare revisions for equivalency.
- HardCopy II Advisor—The HardCopy II Advisor helps you follow the necessary steps to successfully submit a HardCopy II design to Altera's HardCopy Design Center.



The HardCopy II Advisor is similar to the Resource Optimization Advisor and Timing Optimization Advisor. The HardCopy II Advisor provides guidelines you can follow during development, reporting the tasks completed as well as the tasks that you still need to complete during development.

- HardCopy II Floorplan—The Quartus II software can show a preliminary floorplan view of your HardCopy II design's Fitter placement results.
- HardCopy II Design Archiving—The Quartus II software archives the HardCopy II design project's files needed to handoff the design to the HardCopy Design Center.



This feature is similar to the Quartus II software HardCopy Files Wizard used for HardCopy Stratix and HardCopy APEX families.

HardCopy II Device Preliminary Timing—The Quartus II software performs a timing analysis of HardCopy II devices based on preliminary timing models and Fitter placements. Final timing results for HardCopy II devices are provided by the HardCopy Design Center.

- HardCopy II Handoff Report—The Quartus II software generates a handoff report containing information about the HardCopy II design used by the HardCopy Design Center in the design review process.
- Formal Verification—Cadence Encounter Conformal software can now perform formal verification between the source RTL design files and post-compile gate level netlist from a HardCopy II design.

# HardCopy II Development Flow

In the Quartus II software, you have two methods for designing your Stratix II FPGA and HardCopy II companion device together in one Quartus II project.

- Design the HardCopy II device first, and create the Stratix II FPGA companion device second and build your prototype for in-system verification
- Design the Stratix II FPGA first and create a HardCopy II companion device second

Both of these flows are illustrated at a high level in Figure 3–1. The added features in the HardCopy II Utilities menu assist you in completing your HardCopy II design for submission to Altera's HardCopy Design Center for back-end implementation.



Figure 3-1. HardCopy II Flow in Quartus II Software

*Notes for Figure 3–1:* 

- (1) Refer to Figure 3–2 for an expanded description of this process.
- (2) Refer to Figure 3–3 for an expanded description of this process.

# **Designing the Stratix II FPGA First**

The HardCopy II development flow beginning with the Stratix II FPGA prototype is very similar to a traditional Stratix II FPGA design flow, but requires a few additional tasks to be performed to migrate the design to the HardCopy II companion device. To design your HardCopy II device using the Stratix II FPGA as a prototype, complete the following tasks:

- Specify a HardCopy II device for migration
- Compile the Stratix II FPGA design
- Create and compile the HardCopy II companion revision
- Compare the HardCopy II companion revision compilation to the Stratix II device compilation

Figure 3–2 provides an overview highlighting the development process for designing with a Stratix II FPGA first and creating a HardCopy II companion device second.

Figure 3-2. Designing Stratix II Device First Flow

Stratix II Prototype Device Development Phase



Prototype your HardCopy II design by selecting and then compiling a Stratix II device in the Quartus II software.

Once you compile the Stratix II design successfully, you can view the HardCopy II Device Resource Guide in the Quartus II software Fitter report to evaluate which HardCopy II devices meet your design's resource requirements. When you are satisfied with the compilation results and the choice of Stratix II and HardCopy II devices, on the Assignments menu, click **Settings**. In the **Category** list, select **Device**. In the **Device** page, select a HardCopy II companion device.

After you select your HardCopy II companion device, do the following:

- Review the HardCopy II Advisor for required and recommended tasks to perform
- Enable Design Assistant to run during compilation
- Add timing and location assignments
- Compile your Stratix II design
- Create your HardCopy II companion revision
- Compile your design for the HardCopy II companion device
- Use the HardCopy II Utilities to compare the HardCopy II companion device compilation with the Stratix II FPGA revision
- Generate a HardCopy II Handoff Report using the HardCopy II Utilities
- Generate a HardCopy II Handoff Archive using the HardCopy II Utilities
- Arrange for submission of your HardCopy II handoff archive to Altera's HardCopy Design Center for back-end implementation



For more information about the overall design flow using the Quartus II software, refer to the *Introduction to Quartus II* manual on the Altera web site at www.altera.com.

# **Designing the HardCopy II Device First**

The HardCopy II family presents a new option in designing unavailable in previous HardCopy families. You can design your HardCopy II device first and create your Stratix II FPGA prototype second in the Quartus II software. This allows you to see your potential maximum performance in the HardCopy II device immediately during development, and you can create a slower performing FPGA prototype of the design for in-system verification. This design process is similar to the traditional HardCopy II design flow where you build the FPGA first, but instead, you merely change the starting device family. The remaining tasks to complete your design for both Stratix II and HardCopy II devices roughly follow the

same process (Figure 3–3). The HardCopy II Advisor adjusts its list of tasks based on which device family you start with, Stratix II or HardCopy II, so that you can complete the process seamlessly.

Figure 3-3. Designing HardCopy II Device First Flow



# HardCopy II Device Resource Guide

The HardCopy II Device Resource Guide compares the resources required to successfully compile a design with the resources available in the various HardCopy II devices. The report rates each HardCopy II device and each device resource for how well it fits the design. The Quartus II software generates the HardCopy II Device Resource Guide for all designs successfully compiled for Stratix II devices, and is found in the Fitter folder of the Compilation Report. Figure 3–4 shows an example of the HardCopy II Device Resource Guide. Refer to Table 3–1 for an explanation of the color codes in Figure 3–4.

Color Legend: - Green: The HardCopy II package can be migrated from the Stratix II FPGA selected package, and the design has been fitted with the Package Besource: target device migration enabled. Stratix II EP2S130 HC210W\* HC210 HC220 HC220 HC230 HC240 HC240 Resource Migration Compatibility 2 Primary Migration Constraint Package Package Package Package Package Package Package Package FBGA - 484 FBGA - 1020 FBGA - 672 FBGA - 1020 FBGA - 1508 4 ⊟ Logic 5 -- Lo 10% 19% 10% 6% 4% 4% -- Logic cells 35572 ALLITS 6 7 8 9 10 11 12 13 -- DSP elements 0 ☐ Pins 515 / 335 -- Total 515 515 / 302 515 / 493 515 / 495 515 / 699 515 / 743 515 / 952 -- Differential Input 0.766 0.770 0.7.90 0 / 128 0 / 224 0 / 272 In 7.90 -- Differential Output 0 0 / 44 0 / 50 0 / 70 0 / 70 0 / 112 0 / 200 0 / 256 --- PCI / PCI-X 0 / 153 0 / 167 0 / 245 0 / 247 0 / 359 0 / 367 0 / 472 0 -- DQ 0 0 / 20 0 / 20 0 / 50 0 / 50 0 / 204 0 / 204 0 / 204 -- DQS 0 0/8 0 / 18 0 / 18 0 / 72 0 / 72 0 / 72 0/8 15 16 -- M-BAM 670 670 6/2 6/2 6/6 6/9 6/9 -- M4K blocks & M512 blocks\*\* 44 44 / 190 44 / 190 44 / 408 44 / 408 44 / 614 44 / 818 44 / 816 17 18 2/4 2/4 2/4 -- Enhanced 19 20 21 22 23 24 25 --- Fast 0 0/2 0/2 0/2 0/2 0/4 0/8 0/8 DLLs 0 0/1 0/1 071 0/2 0/2 0/1 □ SERDES -- BX 0 0 / 17 0 / 21 0 / 31 0 / 31 0 / 46 0 / 92 0 / 116 -- TX 0 0 / 18 0 / 19 0 / 29 0 / 29 0 / 44 0 / 88 0 / 116 □ Configuration 070 -- CBC n 0.70 070 0.70 0.70 0.70 0.70 26 0/0 0/0 -- ASMI 0 070 070 070 070 070 27 070 -- Remote Update 0 070 070 070 070 070 070 -- JTAG 0 0/1 0/1 0/1 0/1 0/1 0/1 0/1 \* Device is preliminary. Overall performance is expected to be degraded. Design contains one or more M512 blocks, which cannot be migrated to HardCopy II devices

Figure 3-4. HardCopy II Device Resource Guide

Use this report to determine which HardCopy II device is a potential candidate for migration of your Stratix II design. The HardCopy II device package must be compatible with the Stratix II device package. A logic

resource usage greater than 100% or a ratio greater than 1/1 in any category indicates that the design does not fit in that particular HardCopy II device.

| Table 3–1          | Table 3–1. HardCopy II Device Resource Guide Color Legend                                                                                                                    |                                                                                                                                                                                                                                                |  |  |  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Color              | Package Resource (1)                                                                                                                                                         | Device Resources                                                                                                                                                                                                                               |  |  |  |
| Green<br>(High)    | The design can migrate to the Hardcopy II package and the design has been fit with target device migration enabled in the <b>HardCopy II Companion Device</b> dialog box.    | The resource quantity is within the range of the HardCopy II device and the design can likely migrate if all other resources also fit.                                                                                                         |  |  |  |
| Orange<br>(Medium) | The design can migrate to the Hardcopy II package. However, the design has not been fit with target device migration enabled in the HardCopy II Companion Device dialog box. | The resource quantity is within the range of the HardCopy II device. However, the resource is at risk of exceeding the range for the HardCopy II package. Consult your Product Field Applications Engineer for a recommended course of action. |  |  |  |
| Red<br>(None)      | The design cannot migrate to the Hardcopy II package.                                                                                                                        | The resource quantity exceeds the range of the HardCopy II device. The design cannot migrate to this HardCopy II device.                                                                                                                       |  |  |  |

#### Note to Table 3-1:

The package resource is constrained by the Stratix II FPGA that the design was compiled for. Only vertical
migration devices within the same package are able to migrate to HardCopy II devices.

The HardCopy II architecture consists of an array of fine-grained HCells, which are used to build logic equivalent to Stratix II adaptive logic modules (ALMs) and digital signal processing (DSP) blocks. The DSP blocks in HardCopy II devices match the functionality of the Stratix II DSP blocks, though timing of these blocks will be different than the FPGA since they are constructed of HCell Macros. The M4K and M-RAM memory blocks in HardCopy II devices are equivalent to the Stratix II memory blocks. Preliminary timing reports of the HardCopy II device are available in the Quartus II software. Final timing results of the HardCopy II device are provided by the HardCopy Design Center after back-end migration is complete.



For more information about the HardCopy II device resources, refer to the *Introduction to HardCopy II Devices* and the *Description, Architecture & Features* chapters in the *HardCopy II Device Family Data Sheet* in the *HardCopy Series Handbook*.

The report example in Figure 3–4 shows the resource comparisons for a design compiled for a Stratix II EP2S130F1020 device. Based on the report, the HC230F1020 device in the 1,020-pin FineLine BGA $^{(\!R\!)}$  package is an appropriate HardCopy II device to migrate to. If the HC230F1020 device was not specified as a migration target during the compilation, its package and migration compatibility would be rated orange or Medium.

The migration compatibility of the other HardCopy II devices are rated red, or None, because the package types are incompatible with the Stratix II device. The 1,020-pin FBGA HC240 device is rated red because it is only compatible with the Stratix II EP2S180F1020 device.

Figure 3–5 shows the report after the (unchanged) design was recompiled with the HardCopy II HC230F1020 device specified as a migration target. Now the HC230F1020 device package and migration compatibility are rated green or High.

Color Legend: The HardCopy II package can be migrated from the Stratix II FPGA selected package, and the design has been fitted with the - Package Besource: target device migration enabled. Resource HC210W\* HC210 HC220 HC220 HC240 HC240 Stratix II Migration Compatibility Package Primary Migration Constraint Package Package Package Package Package Package FBGA - 1020 FBGA - 484 FBGA - 484 FBGA - 672 FBGA - 780 FBGA - 1020 FBGA - 1020 FBGA - 1508

Figure 3-5. HardCopy II Device Resource Guide with Target Migration Enabled

# HardCopy II Companion Device Selection

In the Quartus II software, you can select a HardCopy II companion device to help structure your design for migration from a Stratix II device to a HardCopy II device. To make your HardCopy II companion device selection, on the Assignments menu, click **Settings**. In the **Settings** dialog box in the **Category** list, select **Device** (Figure 3–6) and select your companion device from the **Available devices** list.

Selecting a HardCopy II Companion device to go with your Stratix II prototype constrains the memory blocks, DSP blocks, and pin assignments, so that your Stratix II and HardCopy II devices are migration-compatible. Pin assignments are constrained in the Stratix II design revision so that the HardCopy II device selected is pin-compatible. The Quartus II software also constrains the Stratix II design revision so it does not use M512 memory blocks or exceed the number of M-RAM blocks in the HardCopy II companion device.



Figure 3-6. Quartus II Settings Dialog Box

You can also specify your HardCopy II companion device using the following Tcl command:

```
set_global_assignment -name
DEVICE_TECHNOLOGY_MIGRATION_LIST <HardCopy II Device Part Number>
```

For example, to select the HC230F1020 device as your HardCopy II companion device for the EP2S130F1020C4 Stratix II FPGA, the Tcl command is:

```
set_global_assignment -name
DEVICE TECHNOLOGY MIGRATION LIST HC230F1020
```

# **Migration Compatibility Filtering**

The **Migration Devices** dialog box displays which devices are vertically migratable within the same package and family for all Altera devices. When you are designing for HardCopy II devices with a Stratix II prototype device, the **Migration Devices** dialog box filters the compatible devices between Stratix II devices and HardCopy II devices within the same package.

To view all Stratix II devices that are vertically migratable to a Stratix II device, on the Assignments menu, click **Settings**. In the **Category** list, select **Device** and on the **Device** page, in the **Family** list select **Stratix II**. In the **Available devices** list, select the desired device. Under **Companion device** in the **HardCopy II** list, select **<None>**, and click **Migration Devices**. The **Migration Devices** dialog box shows the Stratix II devices that are vertically migratable to the currently selected Stratix II device (Figure 3–7).

Figure 3–7. Available Migration Devices without Selecting a HardCopy II Device



Without HardCopy II companion device constraints, all Stratix II devices in the 1,020-pin FineLine BGA package are available for vertical migration. Selecting a HardCopy II companion device in the **Device** page, as shown in Figure 3–8, filters the list of migration devices to only those Stratix II devices that are vertically migratable within the same package and are usable as HardCopy II prototype devices.

Figure 3-8. Setting a HardCopy II Companion Device



For example, if you select the HC230F1020 device as the companion device, the **Migration Devices** dialog box shows the EP2S90F1020C4 and EP2S180F1020C4 devices as possible companion devices to the EP2S130F1020C4 device currently selected (Figure 3–9). However, the

EP2S60F1020C4 device is not a compatible device to the HC230F1020 device, even though it is in the same package, so it is not listed in the **Migration Devices** dialog box.

Migration Devices Select the migration device(s) for the current device. When the Compiler processes your project, it will be compatible with all of the migration devices you select Note: Specifying migration devices can reduce the likelihood of achieving a successful fit Current device: EP2S180E1020C5 Compatible migration devices: Selected migration devices: EP2S90F1020C5 EP2S180F1020C5 EP2S130F1020C5 >> < << Show all speed grades ΟK Cancel

Figure 3-9. Available Migration Devices after Selecting a HardCopy II Device

HardCopy II Recommended Settings in the Quartus II Software

The HardCopy II development flow involves additional planning and preparation in the Quartus II software compared to a standard FPGA design. This is because you are developing your design to be implemented in two devices: a prototype of your design in a Stratix II prototype FPGA, and a companion revision in a HardCopy II device for production. You need additional settings and constraints to make the Stratix II design compatible with the HardCopy II device and, in some cases, you must remove certain settings in the design. This section explains the additional settings and constraints necessary for your design to be successful in both Stratix II FPGA and HardCopy II structured ASIC devices.

# Limit DSP & RAM to HardCopy II Device Resources

On the Assignments menu, click **Settings** to view the **Settings** dialog box. In the **Category** list, select **Device**. In the **Family** list, select **Stratix II**. Under **Companion device**, **Limit DSP & RAM to HardCopy II device resources** is turned on by default (Figure 3–10). This maintains compatibility between the Stratix II and HardCopy II devices by ensuring your design does not use resources in the Stratix II device that are not available in the selected HardCopy II device.



If you require additional memory blocks or DSP blocks for debugging purposes using SignalTap® II, you can temporarily turn this setting off to compile and verify your design in your test environment. However, your final Stratix II and HardCopy II designs submitted to Altera for back-end migration must be compiled with this setting turned on.

Figure 3–10. Limit DSP & RAM to HardCopy II Device Resources Check Box



#### **Enable Design Assistant to Run During Compile**

You must use the Quartus II Design Assistant to check all HardCopy series designs for design rule violations before submitting the designs to the Altera HardCopy Design Center. Additionally, you must fix all critical and high-level errors.



Altera recommends turning on the Design Assistant to run automatically during each compile, so that during development, you can see the violations you must fix.



For more information about the Design Assistant and the rules it uses, refer to the *Design Guidelines for HardCopy Series Devices* chapter of the *HardCopy Series Handbook*.

To enable the Design Assistant to run during compilation, on the Assignment menu, click **Settings**. In the **Category** list, select **Design Assistant** and turn on **Run Design Assistant during compilation** (Figure 3–11) or by entering the following Tcl command in the Tcl Console:

set global assignment -name ENABLE DRC SETTINGS ON



Figure 3-11. Enabling Design Assistant

# **Timing Settings**

In the **More Timing Settings** dialog box, you can specify optional timing settings, some of which are crucial to HardCopy II development. To specify these options, on the Assignments menu, click **Settings**. In the **Category** list, select **Timing Requirements & Options** and click **More Settings**. In the More Settings dialog box, set the desired timing settings (Figure 3–12).



For Stratix II and HardCopy II co-development, Altera recommends that you turn on the following settings:

- Enable Clock Latency
- Enable Recovery/Removal analysis
- Enable Timing Constraint Check
- Report Combined Fast/Slow Timing
- Report IO Paths Separately



Figure 3–12. More Timing Settings

#### Enable Clock Latency

Turning on the **Enable Clock Latency** option enables support for clock latency in the Timing Analyzer. Latency on a clock is a delay on the clock path and affects clock skew. This is different from an offset, which instead alters the setup relationship between two clocks.

When you enable clock latency, the design adjusts for early and late clock latency assignments. The phase-locked loop (PLL) compensation delay is analyzed as latency and does not affect the offset. For clock settings where you have not specified an offset, the design automatically treats computed offset as latency. By using latency for these automatically calculated clock offsets, the setup relationship for registers driven by these clocks does not vary with routing. This can potentially remove the need for multicycle assignments, as well as improve results by ensuring that timing results are more consistent for each Fitter iteration.

Once enabled, you might need to add, modify, or remove multicycle assignments for the PLL output clocks because of the potential change in the setup relationship for these clocks.

Use the following Tcl command to enable clock latency:

```
set_global_assignment -name ENABLE_CLOCK_LATENCY ON
```

#### Enable Recovery/Removal Analysis

This setting allows the Quartus II Timing Analysis tool to calculate recovery and removal times on control and reset signals. The recovery time is the minimum length of time that an asynchronous control input pin must be stable before the clock active edge. The removal time is the minimum length of time that an asynchronous control input pin must be stable after the clock active edge.



Altera recommends that you turn on register recovery/removal analysis in the Timing Analysis tool during development for more complete recovery/removal analysis of all logic paths in your design. However, if your design does not have a timing requirement for reset logic this option may be turned off.

Use the following Tcl command to enable recovery and removal analysis:

```
set_global_assignment -name \
ENABLE_RECOVERY_REMOVAL_ANALYSIS ON
```

#### Enable Timing Constraint Check

The Enable Timing Constraint Check setting enables the Timing Analysis tool to review your timing constraints for complete minimum and maximum timing coverage for all inputs, outputs, and bidirectional pins, as well as clock settings for all clock sources. Asynchronous pins such as resets and static control signals are also checked for minimum and maximum delay constraints. You must perform this check and review the results before handoff of the design to the HardCopy Design Center.

Use the following Tcl command to enable Timing Constraint Check:

```
set_global_assignment -name \
FLOW_ENABLE_TIMING_CONSTRAINT_CHECK ON
```

#### Report Combined Fast/Slow Timing

The Quartus II software can perform a separate timing analysis for worst-case and best-case conditions as independent reports. The **Report Combined Fast/Slow Timing** setting allows the Quartus II software to report slow corner delay case and fast corner delay case timing in one combined report. This setting provides a better timing report for your design by allowing you to see all hold-time issues as well as setup issues in one report. This report is required for HardCopy II device

development. Turning on the **Report Combined Fast/Slow Timing** setting requires the Quartus II software to run the Timing Analyzer twice, once for the fast corner delay model and once for the slow corner delay model.

Use the following Tcl command to enable the **Report Combined Fast/Slow Timing** setting:

```
set_global_assignment -name DO_COMBINED_ANALYSIS ON
```

#### Report 10 Paths Separately

Turn on the **Report IO Paths Separately** setting to create separate report panels for I/O paths constrained by the INPUT\_MAX\_DELAY, INPUT\_MIN\_DELAY, OUTPUT\_MAX\_DELAY, or OUTPUT\_MIN\_DELAY parameters. To specify these constraints, on the Assignments menu, click **Assignment Editor**. By default, I/O paths are reported in the **Clock Setup** and **Clock Hold** sections of the **Timing Analyzer** compilation report.



Altera recommends that you turn on the **Report IO Paths Separately** setting to make it easier to view the I/O timing analysis reports for each device pin. This is optional in FPGA designs, but is helpful for HardCopy II development because the I/O timing requirements you specify must be met in both Stratix II I/O timing and HardCopy II I/O timing results. This setting helps to guarantee drop-in compatibility between your Stratix II FPGA prototype and your HardCopy II structured ASIC.

Use the following Tcl command to enable the **Report IO Paths Separately** setting:

```
set_global_assignment -name \
REPORT_IO_PATHS_SEPARATELY ON
```

## Quartus II Software Version 6.0 Features Supported for HardCopy II Designs

The Quartus II software supports optimization features for HardCopy II prototype development including:

- Physical Synthesis Optimization
- LogicLock Regions
- PowerPlay Power Analyzer

#### Physical Synthesis Optimization

To enable the Physical Synthesis Optimizations for the Stratix II FPGA revision of the design, on the Assignments menu, click **Settings**. In the **Settings** dialog box, in the **Category** list, select **Fitter Settings**. These optimizations get migrated into the HardCopy II companion revision for placement and timing closure. When designing with a HardCopy II device first, physical synthesis optimizations can be enabled for the HardCopy II device, and these post-fit optimizations get migrated to the Stratix II FPGA revision.

#### LogicLock Regions

The use of LogicLock Regions in the Stratix II FPGA are supported for designs migrating to HardCopy II. However, the LogicLock Regions are not passed into the HardCopy II Companion Revision. You can use LogicLock in the HardCopy II design but you must create new LogicLock Regions in the HardCopy II companion revision. In addition, LogicLock Regions in HardCopy II devices can not have their properties set to Auto Size or Floating Location. HardCopy II LogicLock Regions must be manually sized and placed in the floorplan. When LogicLock Regions are created in a HardCopy II device, they start with width and height dimensions set to (1,1), and the origin coordinates for placement are at X1\_Y1 in the lower left corner of the floorplan. You must adjust the size and location of your LogicLock Regions created in the HardCopy II device before compiling the design.



For information about using LogicLock Regions, refer to the *LogicLock Design Methodology*, chapter in volume 2 of the *Quartus II Handbook* on the Altera web site at www.altera.com.

#### PowerPlay Power Analyzer

You can perform power estimation and analysis of your HardCopy II and Stratix II devices using the PowerPlay Early Power Estimator and PowerPlay Power Analyzer for more accurate estimation of your device's power consumption. The PowerPlay Early Power Estimation is available in the Quartus II software version 5.1 and later. The PowerPlay Power Analyzer supports HardCopy II devices in version 6.0 and later of the Quartus II software.



For more information about using the PowerPlay Power Analyzer, refer to the *PowerPlay Power Analysis* chapter in volume 3 of the *Ouartus II Handbook*.

# Quartus II Features Not Presently Supported for HardCopy II Designs

The Quartus II software version 6.0 does not support HardCopy II devices with all of the advanced design features available for other Altera devices. Many of these features are scheduled for subsequent releases of the Quartus II software.

The Quartus II software version 6.0 does not support the following features for HardCopy II prototype development using the Stratix II FPGA:

- Incremental compilation (Synthesis and Fitter)
- Maximum fan-out assignments

# Chip Editor for HardCopy II Devices

When using the Quartus II Chip Editor for your HardCopy II design, the Chip Editor changes are done in the following two ways:

- A Chip Editor change is applied to a compiled Stratix II design revision and a new HardCopy II Companion Revision is created afterwards, incorporating the Chip Editor modifications.
- A Chip Editor change is performed separately on compiled, existing Stratix II and HardCopy II design revisions. No new companion revisions are created.

If you want to use the Quartus II Chip Editor on a Stratix II design you want to migrate to a HardCopy II device, it is best if you start with a compiled Stratix II project and a new HardCopy II Companion Revision created or overwritten using the HardCopy II Utilities.

Using the Chip Editor on a compiled HardCopy II design revision, requires that you manually complete the changes in both HardCopy II and Stratix II revisions, and then use the HardCopy II Companion Comparison Utility and third-party formal verification software to determine if they are equivalent.

The Chip Editor for HardCopy II has the following enabled features:

- Add/Modify/Remove an HCell Macro of a Combinational Function, Register, or Adder/Subtractor and connect wires to them
- Create new wires in the design
- Edit IO Cell properties such as drive strength or programmable delay values
- Edit PLL settings such as M/N counter settings or phase shift of derived clocks



For more information about using the Quartus II Chip Editor, refer to the *Engineering Change Management* chapter in volume 1 of the *Quartus II Handbook*.

# Formal Verification of Stratix II & HardCopy II Revisions

Third party formal verification software is available for your HardCopy II design. Cadence Encounter Conformal verification software is used for Stratix II and HardCopy II families, as well as several other Altera product families.

In order to use the Conformal software with the Quartus II software project for your Stratix II and HardCopy II design revisions, you must enable the **EDA Netlist Writer**. It is necessary to turn on the EDA Netlist Writer so it can generate the necessary netlists and command files needed to run the Conformal software. To automatically run the EDA Netlist Writer during the compile of your Stratix II and HardCopy II design revisions, perform the following steps:

- 1. On the Assignment menu, click **EDA Tool Settings**. The **Settings** dialog box displays.
- 2. In the **EDA Tool Settings** list, select **Formal Verification**, and in the **Tool name** list, select **Conformal LEC**.
- 3. Compile your Stratix II and Hardcopy II design revisions, with both the EDA Tool Settings and the Conformal LEC turned on so the EDA Netlist Writer automatically runs.

The Quartus II EDA Netlist Writer produces one netlist for Stratix II when it is run on that revision, and generates a second netlist when it runs on the HardCopy II revision. You can compare your Stratix II post-compile netlist to your RTL source code using the scripts generated by the EDA Netlist Writer. Similarly, you can compare your HardCopy II post-compile netlist to your RTL source code with scripts provided by the EDA Netlist Writer.



For more information about using the Cadence Encounter Conformal verification software, refer to the *Cadence Encounter Conformal Support* chapter in volume 3 of the *Quartus II Handbook*.

# HardCopy II Utilities Menu

The **HardCopy II Utilities** menu is shown in the Quartus II software (Figure 3–13). To access this menu, on the Project menu, click **HardCopy II Utilities**. This menu contains the main functions you use to develop your HardCopy II design and Stratix II FPGA prototype companion revision. From the HardCopy II Utilities menu, you can:

- Create or update HardCopy II companion revisions
- Set which HardCopy II companion revision is the current revision
- Generate HardCopy II Handoff Report for design reviews
- Archive HardCopy II Handoff Files for submission to the HardCopy Design Center
- Compare the companion revisions for functional equivalence
- Track your design progress using the HardCopy II Advisor

Add Current File to Project Add/Remove Files in Project... Revisions... Copy Project... Archive Project... Restore Archived Project... Import Database... Export Database... Import Design Partition... Export Project as Design Partition... Generate Tcl File for Project... Generate PowerPlay Early Power Estimator File Hard⊆opy Utilities Create/Overwrite HardCopy II Companion Revision... Set Current HardCopy II Companion Revision... Compare HardCopy II Companion Revisions Ctrl+Shift+3 Set as Top-Level Entity Generate HardCopy II Handoff Report Archive HardCopy II Handoff Files... Hierarchy

HardCopy II Advisor

Figure 3–13. HardCopy II Utilities Menu

Each of the features within the **HardCopy II Utilities** is summarized in Table 3–2. The process for using each of these features is explained in the following sections.

| Menu                                                  | Description                                                                                                                                                                                 | Applicable Design<br>Revision                                        | Restrictions                                                                                                                                                             |
|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Create/Overwrite<br>HardCopy II<br>Companion Revision | Create a new companion revision or update an existing companion revision for your Stratix II and HardCopy II design.                                                                        | Stratix II prototype<br>design and HardCopy II<br>Companion Revision | <ul> <li>Must disable Auto Device<br/>selection</li> <li>Must set a Stratix II device<br/>and a HardCopy II<br/>companion device</li> </ul>                              |
| Set Current<br>HardCopy II<br>Companion Revision      | Specify which companion revision to associate with current design revision.                                                                                                                 | Stratix II prototype<br>design and HardCopy II<br>Companion Revision | Companion Revision must already exist                                                                                                                                    |
| Compare<br>HardCopy II<br>Companion<br>Revisions      | Compares the Stratix II design<br>revision with the HardCopy II<br>companion design revision<br>and generates a report.                                                                     | Stratix II prototype<br>design and HardCopy II<br>Companion Revision | Compilation of both revisions must be complete                                                                                                                           |
| Generate<br>HardCopy II Handoff<br>Report             | Generate a report containing important design information files and messages generated by the Quartus II compile                                                                            | Stratix II prototype<br>design and HardCopy II<br>Companion Revision | Compilation of both revisions must be complete     Compare HardCopy II Companion Revisions must have been executed                                                       |
| Archive HardCopy II<br>Handoff Files                  | Generate a Quartus II Archive<br>File specifically for submitting<br>the design to the HardCopy<br>Design Center. Similar to the<br>HardCopy Files Wizard for<br>HardCopy Stratix and APEX. | HardCopy II<br>Companion Revision                                    | Compilation of both revisions must be completed Compare HardCopy II Companion Revisions must have been executed Generate HardCopy Handoff Report must have been executed |
| HardCopy II Advisor                                   | Open an Advisor, similar to the<br>Resource Optimization<br>Advisor, helping you through<br>the steps of creating a<br>HardCopy II project.                                                 | Stratix II prototype<br>design and HardCopy II<br>Companion Revision | None                                                                                                                                                                     |

# **Companion Revisions**

HardCopy II designs follow a different development flow in the Quartus II software compared with previous HardCopy families. You can create multiple revisions of your Stratix II prototype design, but you can also create separate revisions of your design for a HardCopy II device.

The Quartus II software creates specific HardCopy II design revisions of the project in conjunction to the regular project revisions. These parallel design revisions for HardCopy II devices are called companion revisions.



Although you can create multiple project revisions, Altera recommends that you maintain only one Stratix II FPGA revision once you have created the HardCopy II *companion revision*.

When you have successfully compiled your Stratix II prototype FPGA, you can create a HardCopy II companion revision of your design and proceed with compiling the HardCopy II companion revision. To create a companion revision, on the Project menu, point to HardCopy II Utilities and click **Create/Overwrite HardCopy II Companion Revision**. Use the dialog box to create a new companion revision or overwrite an existing companion revision (Figure 3–14).

Figure 3–14. Create or Overwrite HardCopy II Companion Revision



You can associate only one Stratix II revision to one HardCopy II companion revision. If you created more than one revision or more than one companion revision, set the current companion for the revision you are working on. On the Project menu, point to HardCopy II Utilities and click **Set Current HardCopy II Companion Revision** (Figure 3–15).

Figure 3–15. Set Current HardCopy II Companion Revision



#### Compiling the HardCopy II Companion Revision

The Quartus II software enables you to compile your HardCopy II design with preliminary timing information. The timing constraints for the HardCopy II companion revision can be the same as the Stratix II design used to create the revision. The Quartus II software contains preliminary timing models for HardCopy II devices and you can gauge how much performance improvement you can achieve in the HardCopy II device compared to the Stratix II FPGA. Altera verifies that the HardCopy II Companion Device timing requirements are met in the HardCopy Design Center.

After you create your HardCopy II companion revision from your compiled Stratix II design, select the companion revision in the Quartus II software design revision drop-down box (Figure 3–16) or from the **Revisions** list. Compile the HardCopy II companion revision. After the Quartus II software compiles your design, you can perform a comparison check of the HardCopy II companion revision to the Stratix II prototype revision.

Figure 3-16. Changing Current Revision



# Comparing HardCopy II & Stratix II Companion Revisions

Altera uses the companion revisions in a single Quartus II project to maintain the seamless migration of your design from a Stratix II FPGA to a HardCopy II structured ASIC. This methodology allows you to design with one set of Register Transfer Level (RTL) code to be used in both Stratix II FPGA and HardCopy II structured ASIC, guaranteeing functional equivalency.

When making changes to companion revisions, use the Compare HardCopy II Companion Revisions feature to ensure that your Stratix II design matches your HardCopy II design functionality and compilation settings. To compare companion revisions, on the Project menu, point to HardCopy II Utilities and click Compare HardCopy II Companion Revisions.



You must perform this comparison after both Stratix II and HardCopy II designs are compiled in order to hand off the design to Altera's HardCopy Design Center.

The Comparison Revision Summary is found in the Compilation Report and identifies where assignments were changed between revisions or if there is a change in the logic resource count due to different compilation settings.

#### Generate HardCopy II Handoff Report

In order to submit a design to the HardCopy Design Center, you must generate a HardCopy II Handoff Report providing important information about the design that you want the HardCopy Design Center to review. To generate the HardCopy II Handoff Report, you must:

- Successfully compile both Stratix II and HardCopy II revisions of your design
- Successfully run the Compare HardCopy II Companion Revisions utility

Once you generate the HardCopy II Handoff Report, you can archive the design using the Archive HardCopy II Handoff Files utility described in "Archive HardCopy II Handoff Files" on page 3–26.

#### Archive HardCopy II Handoff Files

The last step in the HardCopy II design methodology is to archive the HardCopy II project for submission to the HardCopy Design Center for back-end migration. The HardCopy II archive utility creates a different Quartus II Archive File than the standard Quartus II project archive utility generates. This archive contains only the necessary data from the Quartus II project needed to implement the design in the HardCopy Design Center.

In order to use the **Archive HardCopy II Handoff Files** utility, you must complete the following:

- Compile both the Stratix II and HardCopy II revisions of your design
- Run the Compare HardCopy II Revisions utility
- Generate the HardCopy II Handoff Report

To select this option, on the Project menu point to HardCopy II Utilities and click **Archive HardCopy II Handoff File** utility.

# HardCopy II Advisor

The HardCopy II Advisor provides the list of tasks you should follow to develop your Stratix II prototype and your HardCopy II design. To run the HardCopy II Advisor, on the Project menu, point to HardCopy II Utilities and click **HardCopy II Advisor**. The following list highlights the

checkpoints that the HardCopy II Advisor reviews. This list includes the major check points in the design process; it does not show every step in the process for completing your Stratix II and HardCopy II designs:

- 1. Select a Stratix II device.
- 2. Select a HardCopy II device.
- 3. Turn on the **Design Assistant**.
- 4. Set up timing constraints.
- 5. Check for incompatible assignments.
- 6. Compile and check Stratix II design.
- 7. Create or overwrite companion revision.
- 8. Compile and check HardCopy II companion results.
- 9. Compare companion revisions.
- 10. Generate Handoff Report.
- 11. Archive Handoff Files and send to Altera.

The HardCopy II Advisor shows the necessary steps that pertain to your current selected device. The Advisor shows a slightly different view for a design with Stratix II selected as compared to a design with HardCopy II selected.

In the Quartus II software, you can start designing with the HardCopy II device selected first, and build a Stratix II companion revision second. When you use this approach, the HardCopy II Advisor task list adjusts automatically to guide you from HardCopy II development through Stratix II FPGA prototyping, it then completes the comparison archiving and handoff to Altera.

When your design uses the Stratix II FPGA as your starting point, Altera recommends following the Advisor guidelines for your Stratix II FPGA until you complete the prototype revision.

When the Stratix II FPGA design is complete, create and switch to your HardCopy II companion revision and follow the Advisor steps shown in that revision until you are finished with the HardCopy II revision and are ready to submit the design to Altera for back-end migration.

Each category in the HardCopy II Advisor list has an explanation of the recommended settings and constraints, as well as quick links to the features in the Quartus II software that are needed for each section. The HardCopy II Advisor displays:

- A green check box when you have successfully completed one of the steps
- A yellow caution sign for steps that must be completed before submitting your design to Altera for HardCopy development
- An information callout for items you must verify



Selecting an item within the HardCopy II flow menu provides a description of the task and recommended action. The view in the HardCopy II Advisor differs depending on the device you select.

Figure 3–17 shows the HardCopy II Advisor with the Stratix II device selected.



Figure 3-17. HardCopy II Advisor with Stratix II Selected

Figure 3–18 shows the HardCopy II Advisor with the HardCopy II device selected.

P HardCopy II Advisor HardCopy II Advisor ompile and check HardCopy II revision Getting more information Recommendation Compile and check HardCopy II revision Choose a HardCopy II device Choose a Stratix II companion device Compile the design and verify the specified companion ✓ Setup HardCopy II revision HardCopy II device is compatible with the design. Design Assistant passes with no errors, timing requirements were successfully met and all paths were timing constrained, and I/O types are fully defined for all the I/O pins. Turn on the Design Assistant Turn on the Assembler Press the button below to verify the compilation was successful for HardCopy II development. Action Create a Stratix II companion revision Compile and Check Results Nerify Stratix II revision Compile and check Stratix II companion revision Open Device Resource Guide (Compilation Report)
Open Design Assistant Summary (Compilation Report) Compare companion revisions Generate Handoff Report Open Timing Constraint Check Summary (Compilation Archive Handoff Files and Send to Altera

Figure 3–18. HardCopy II Advisor with HardCopy II Device Selected

# HardCopy II Floorplan View

The Quartus II software displays the preliminary timing closure floorplan and placement of your HardCopy II companion revision. This floorplan shows the preliminary placement and connectivity of all I/O pins, PLLs, memory blocks, HCell macros, and DSP HCell macros. Congestion mapping of routing connections can be viewed using the Bird's Eye viewer settings. This is useful in analyzing densely packed areas of your floorplan that could be reducing the peak performance of your design. The HardCopy Design Center verifies final HCell macro timing and placement to guarantee timing closure is achieved.

Figure 3–19 shows an example of the HC230F1020 device floorplan.



Figure 3-19. HC230F1020 Device Floorplan

In this small example design, the logic is placed near the bottom edge. You can see the placement of a DSP block constructed of HCell Macros, various logic HCell Macros, and an M4K memory block. A labeled close-up view of this region is shown in Figure 3–20.



Figure 3-20. Close-Up View of Floorplan

The HardCopy Design Center performs final placement and timing closure on your HardCopy II design based on the timing constraints provided in the Stratix II design.



For more information about the HardCopy Design Center's process, refer to the *Back-End Design Flow for HardCopy Series Devices* chapter in volume 1 of the *HardCopy Series Device Handbook*.

#### Conclusion

You can use the Quartus II software to design HardCopy II devices and to develop prototypes using Stratix II FPGAs. This is done using the standard FPGA development process with the addition of the HardCopy II Device Resource Guide, HardCopy II Companion Devices assignment HardCopy II Utilities, and the HardCopy II Advisor.

The addition of the HardCopy II Advisor to the Quartus II software provides an instrumental development guide for you to complete your HardCopy II and Stratix II device designs. The HardCopy II Utilities included in the Quartus II software provide you with the tools necessary to complete your Stratix II FPGA prototype and HardCopy II structured ASIC design. The addition of the HardCopy II companion revisions feature to the process allows for rapid development and verification that your HardCopy II design is functionally equivalent to your Stratix II FPGA prototype.

## HardCopy Stratix Device Support

The Altera HardCopy devices provide a comprehensive alternative to ASICs. HardCopy structured ASICs offer a complete solution from prototype to high-volume production, and maintain the powerful features and high-performance architecture of their equivalent FPGAs with the programmability removed. You can use the Quartus II design software to design HardCopy devices in a manner similar to the traditional ASIC design flow and you can prototype with Altera's high density Stratix, APEX 20KC, and APEX 20KE FPGAs before seamlessly migrating to the corresponding HardCopy device for high-volume production.

HardCopy structured ASICs provide the following key benefits:

- Improves performance, on the average, by 40% over the corresponding -6 speed grade FPGA device
- Lowers power consumption, on the average, by 40% over the corresponding FPGA
- Preserves the FPGA architecture and features, and minimizes risk
- Guarantees first-silicon success through a proven, seamless migration process from the FPGA to the equivalent HardCopy device
- Offers a quick turnaround of the FPGA design to a structured ASIC device—samples are available in about eight weeks

Altera's Quartus II software has built-in support for HardCopy Stratix devices. The HardCopy design flow in Quartus II software offers the following advantages:

- Unified design flow from prototype to production
- Performance estimation of the HardCopy Stratix device allows you to design systems for maximum throughput
- Easy-to-use and inexpensive design tools from a single vendor
- An integrated design methodology that enables system-on-a-chip designs

This section discusses the following areas:

- How to design HardCopy Stratix and HardCopy APEX structured ASICs using the Quartus II software
- An explanation of what the HARDCOPY\_FPGA\_PROTOTYPE devices are and how to target designs to these devices
- Performance and power estimation of HardCopy Stratix devices
- How to generate the HardCopy design database for submitting HardCopy Stratix and HardCopy APEX designs to the HardCopy Design Center

#### **Features**

Beginning with version 4.2, the Quartus II software contains several powerful features that facilitate design of HardCopy Stratix and HardCopy APEX devices:

#### HARDCOPY\_FPGA\_PROTOTYPE Devices

These are virtual Stratix FPGA devices with features identical to HardCopy Stratix devices. You must use these FPGA devices to prototype your designs and verify the functionality in silicon.

#### HardCopy Timing Optimization Wizard

Using this feature, you can target your design to HardCopy Stratix devices, providing an estimate of the design's performance in a HardCopy Stratix device.

#### ■ HardCopy Stratix Floorplans and Timing Models

The Quartus II software supports post-migration HardCopy Stratix device floorplans and timing models and facilitates design optimization for design performance.

#### Placement Constraints

Location and LogicLock<sup>™</sup> constraints are supported at the HardCopy Stratix floorplan level to improve overall performance.

#### Improved Timing Estimation

Beginning with version 4.2, the Quartus II software determines routing and associated buffer insertion for HardCopy Stratix designs, and provides the Timing Analyzer with more accurate information about the delays than was possible in previous versions of the Quartus II software. The Quartus II Archive File automatically receives buffer insertion information, which greatly enhances the timing closure process in the back-end migration of your HardCopy Stratix device.

#### Design Assistant

This feature checks your design for compliance with all HardCopy device design rules and establishes a seamless migration path in the quickest time.

#### HardCopy Files Wizard

This wizard enables you to deliver to Altera the design database and all the deliverables required for migration. This feature is used for HardCopy Stratix and HardCopy APEX devices.



The HardCopy Stratix and HardCopy APEX PowerPlay Early Power Estimator is available on the Altera web site at www.altera.com.

## HARDCOPY\_FPGA \_PROTOTYPE, HardCopy Stratix & Stratix Devices

You must use the HARDCOPY\_FPGA\_PROTOTYPE virtual devices available in the Quartus II software to target your designs to the actual resources and package options available in the equivalent post-migration HardCopy Stratix device. The programming file generated for the HARDCOPY\_FPGA\_PROTOTYPE can be used in the corresponding Stratix FPGA device.

The purpose of the HARDCOPY\_FPGA\_PROTOTYPE is to guarantee seamless migration to HardCopy by making sure that your design only uses resources in the FPGA that can be used in the HardCopy device after migration. You can use the equivalent Stratix FPGAs to verify the design's functionality in-system, then generate the design database necessary to migrate to a HardCopy device. This process ensures the seamless migration of the design from a prototyping device to a production device in high volume. It also minimizes risk, assures samples in about eight weeks, and guarantees first-silicon success.



HARDCOPY\_FPGA\_PROTOTYPE devices are only available for HardCopy Stratix devices and are not available for the HardCopy II or HardCopy APEX device families.

Table 3–3 compares HARDCOPY\_FPGA\_PROTOTYPE devices, Stratix devices, and HardCopy Stratix devices.

| Table 3–3. Qualitative Comparison of HARDCOPY_FPGA_PROTOTYPE to Stratix & HardCopy Stratix Devices |                                                            |                                                                |  |  |  |  |
|----------------------------------------------------------------------------------------------------|------------------------------------------------------------|----------------------------------------------------------------|--|--|--|--|
| Stratix Device                                                                                     | HARDCOPY_FPGA_PROTOTYPE Device                             | HardCopy Stratix Device                                        |  |  |  |  |
| FPGA                                                                                               | Virtual FPGA                                               | Structured ASIC                                                |  |  |  |  |
| FPGA                                                                                               | Architecture identical to Stratix FPGA                     | Architecture identical to Stratix FPGA                         |  |  |  |  |
| FPGA                                                                                               | Resources identical to HardCopy Stratix device             | M-RAM resources different than<br>Stratix FPGA in some devices |  |  |  |  |
| Ordered through<br>Altera part number                                                              | Cannot be ordered, use the Altera Stratix FPGA part number | Ordered by Altera part number                                  |  |  |  |  |

Table 3–4 lists the resources available in each of the HardCopy Stratix devices.

| Table 3–4. HardCopy Stratix Device Physical Resources |        |                                  |                |               |                 |               |      |                          |
|-------------------------------------------------------|--------|----------------------------------|----------------|---------------|-----------------|---------------|------|--------------------------|
| Device                                                | LEs    | ASIC Equivalent<br>Gates (K) (1) | M512<br>Blocks | M4K<br>Blocks | M-RAM<br>Blocks | DSP<br>Blocks | PLLs | Maximum<br>User I/O Pins |
| HC1S25F672                                            | 25,660 | 250                              | 224            | 138           | 2               | 10            | 6    | 473                      |
| HC1S30F780                                            | 32,470 | 325                              | 295            | 171           | 2 (2)           | 12            | 6    | 597                      |
| HC1S40F780                                            | 41,250 | 410                              | 384            | 183           | 2 (2)           | 14            | 6    | 615                      |
| HC1S60F1020                                           | 57,120 | 570                              | 574            | 292           | 6               | 18            | 12   | 773                      |
| HC1S80F1020                                           | 79,040 | 800                              | 767            | 364           | 6 (2)           | 22            | 12   | 773                      |

#### Notes to Table 3-4:

- (1) Combinational and registered logic do not include DSP blocks, on-chip RAM, or PLLs.
- (2) The M-RAM resources for these HardCopy devices differ from the corresponding Stratix FPGA.

For a given device, the number of available M-RAM blocks in HardCopy Stratix devices is identical with the corresponding HARDCOPY\_FPGA\_PROTOTYPE devices, but may be different from the corresponding Stratix devices. Maintaining the identical resources between HARDCOPY\_FPGA\_PROTOTYPE and HardCopy Stratix devices facilitates seamless migration from the FPGA to the structured ASIC device.



For more information about HardCopy Stratix devices, refer to the *HardCopy Stratix Device Family Data Sheet* section in volume 1 of the *HardCopy Series Handbook*.

The three devices, Stratix FPGA, HARDCOPY\_FPGA\_PROTOTYPE, and HardCopy device, are distinct devices in the Quartus II software. The HARDCOPY\_FPGA\_PROTOTYPE programming files are used in the Stratix FPGA for your design. The three devices are tied together with the same netlist, thus a single SRAM Object File (.sof) can be used to achieve the various goals at each stage. The same SRAM Object File is generated in the HARDCOPY\_FPGA\_PROTOTYPE design, and is used to program the Stratix FPGA device, the same way that it is used to generate the HardCopy Stratix device, guaranteeing a seamless migration.



For more information about the SRAM Object File and programming Stratix FPGA devices, refer to the *Programming and Configuration* chapter of the *Introduction to Quartus II Manual*.

## HardCopy Design Flow

Figure 3–21 shows a HardCopy design flow diagram. The design steps are explained in detail in the following sections of this chapter. The HardCopy Stratix design flow utilizes the HardCopy Timing Optimization Wizard to automate the migration process into a one-step process. The remainder of this section explains the tasks performed by this automated process.

For a detailed description of the HardCopy Timing Optimization Wizard and HardCopy Files Wizard, refer to "HardCopy Timing Optimization Wizard" on page 3–39 and "Generating the HardCopy Design Database" on page 3–50.

Start Quartus HardCopy Flow **APEX** Stratix Select FPGA Family Select Stratix Select APEX FPGA HARDCOPY FPGA PROTOTYPE Device Supported by Device HardCopy APEX One Step Process (3) Compile Compile Compile Two Step Process (2) Mirgrate the Migrate the Migrate the Compiled Project Compiled Project Compiled Project Migrate Only (1) Close the Quartus II Close the Quartus II Close the Quartus II **FPGA Project FPGA Project FPGA Project** Open the Quartus II Open the Quartus II Open the Quartus II HardCopy Project HardCopy Project HardCopy Project Compile to HardCopy Compile to HardCopy Compile to HardCopy Stratix Device (Actual Stratix Device (Actual Stratix Device (Actual HardCopy Floorplan) HardCopy Floorplan) HardCopy Floorplan) Run HardCopy Files Placement Wizard (Quartus II Info for Archive File for HardCopy delivery to Altera)

Figure 3-21. HardCopy Stratix & HardCopy APEX Design Flow Diagram

Notes for Figure 3-21:

- Migrate-Only Process: The displayed flow is completed manually.
- Two-Step Process: Migration and Compilation are done automatically (shaded area).
- (3) One-Step Process: Full HardCopy Compilation. The entire process is completed automatically (shaded area).

#### The Design Flow Steps of the One Step Process

The following sections describe each step of the full HardCopy compilation (the One Step Process), as shown in Figure 3–21.

#### Compile the Design for an FPGA

This step compiles the design for a HARDCOPY\_FPGA\_PROTOTYPE device and gives you the resource utilization and performance of the FPGA.

#### Migrate the Compiled Project

This step generates the Quartus II Project File (.qpf) and the other files required for HardCopy implementation. The Quartus II software also assigns the appropriate HardCopy Stratix device for the design migration.

#### Close the Quartus FPGA Project

Because you must compile the project for a HardCopy Stratix device, you must close the existing project which you have targeted your design to a HARDCOPY\_FPGA\_PROTOTYPE device.

#### Open the Quartus HardCopy Project

Open the Quartus II project that you created in the "Migrate the Compiled Project" step. The selected device is one of the devices from the HardCopy Stratix family that was assigned during that step.

#### Compile for HardCopy Stratix Device

Compile the design for a HardCopy Stratix device. After successful compilation, the Timing Analysis section of the compilation report shows the performance of the design implemented in the HardCopy device.

## How to Design HardCopy Stratix Devices

This section describes the process for designing for a HardCopy Stratix device using the HARDCOPY\_FPGA\_PROTOTYPE as your initial selected device. In order to use the HardCopy Timing Optimization Wizard, you must first design with the HARDCOPY\_FPGA\_PROTOTYPE in order for the design to migrate to a HardCopy Stratix device.

To target a design to a HardCopy Stratix device in the Quartus II software, follow these steps:

- 1. If you have not yet done so, create a new project or open an existing project.
- 2. On the Assignments menu, click **Settings**. In the **Category** list, select **Device**.
- 3. On the **Device** page, in the **Family** list, select **Stratix**. Select the desired HARDCOPY\_FPGA\_PROTOTYPE device in the **Available Devices** list (Figure 3–22).



Figure 3–22. Selecting a HARDCOPY\_FPGA\_PROTOTYPE Device

By choosing the HARDCOPY\_FPGA\_PROTOTYPE device, all the design information, available resources, package option, and pin assignments are constrained to guarantee a seamless migration of your project to the HardCopy Stratix device. The netlist resulting from the HARDCOPY\_FPGA\_PROTOTYPE device compilation contains information about the electrical connectivity, resources used, I/O placements, and the unused resources in the FPGA device.

- 4. On the Assignments menu, click Settings. In the Category list, select HardCopy Settings and specify the input transition timing to be modeled for both clock and data input pins. These transition times are used in static timing analysis during back-end timing closure of the HardCopy device.
- Add constraints to your HARDCOPY\_FPGA\_PROTOTYPE device, and on the Processing menu, click Start Compilation to compile the design.

#### HardCopy Timing Optimization Wizard

After you have successfully compiled your design in the HARDCOPY\_FPGA\_PROTOTYPE, you must migrate the design to the HardCopy Stratix device to get a performance estimation of the HardCopy Stratix device. This migration is required before submitting the design to Altera for the HardCopy Stratix device implementation. To perform the required migration, on the Project menu, point to HardCopy Utilities and click HardCopy Timing Optimization Wizard.

At this point, you are presented with the following three choices to target the designs to HardCopy Stratix devices (Figure 3–23):

Migration Only: You can select this option after compiling the HARDCOPY\_FPGA\_PROTOTYPE project to migrate the project to a HardCopy Stratix project.

You can now perform the following tasks manually to target the design to a HardCopy Stratix device. Refer to "Performance Estimation" on page 3–42 for additional information about how to perform these tasks.

- Close the existing project
- Open the migrated HardCopy Stratix project
- Compile the HardCopy Stratix project for a HardCopy Stratix device

- Migration and Compilation: You can select this option after compiling the project. This option results in the following actions:
  - Migrating the project to a HardCopy Stratix project
  - Opening the migrated HardCopy Stratix project and compiling the project for a HardCopy Stratix device
- Full HardCopy Compilation: Selecting this option results in the following actions:
  - Compiling the existing HARDCOPY\_FPGA\_PROTOTYPE project
  - Migrating the project to a HardCopy Stratix project
  - Opening the migrated HardCopy Stratix project and compiling it for a HardCopy Stratix device

Figure 3–23. HardCopy Timing Optimization Wizard Options



The main benefit of the HardCopy Timing Wizard's three options is flexibility of the conversion process automation. The first time you migrate your HARDCOPY\_FPGA\_PROTOTYPE project to a HardCopy Stratix device, you may want to use Migration Only, and then work on the HardCopy Stratix project in the Quartus II software. As your prototype FPGA project and HardCopy Stratix project constraints stabilize and you have fewer changes, the Full HardCopy Compilation is ideal for one-click compiling of your HARDCOPY\_FPGA\_PROTOTYPE and HardCopy Stratix projects.

After selecting the wizard you want to run, the "HardCopy Timing Optimization Wizard: Summary" page shows you details about the settings you made in the Wizard, as shown in Figure 3–24.

Figure 3-24. HardCopy Timing Optimization Wizard Summary Page



When either of the second two options in Figure 3–23 are selected (**Migration and Compilation** or **Full HardCopy Compilation**), designs are targeted to HardCopy Stratix devices and optimized using the HardCopy Stratix placement and timing analysis to estimate performance. For details on the performance optimization and estimation steps, refer to "Performance Estimation" on page 3–42. If the performance requirement is not met, you can modify your RTL source, optimize the FPGA design, and estimate timing until you reach timing closure.

#### Tcl Support for HardCopy Migration

To complement the GUI features for HardCopy migration, the Quartus II software provides the following command-line executables (which provide the tool command language (Tcl) shell to run the --flow Tcl command) to migrate the HARDCOPY\_FPGA\_PROTOTYPE project to HardCopy Stratix devices:

```
quartus_sh --flow migrate_to_hardcopy project_name> [-c <revision>] +-
```

This command migrates the project compiled for the HARDCOPY\_FPGA\_PROTOTYPE device to a HardCopy Stratix device.

```
quartus sh --flow hardcopy full compile cproject_name> [-c <revision>] ←
```

This command performs the following tasks:

- Compiles the exsisting project for a HARDCOPY FPGA PROTOTYPE device.
- Migrates the project to a HardCopy Stratix project.
- Opens the migrated HardCopy Stratix project and compiles it for a HardCopy Stratix device.

# Design Optimization & Performance Estimation

The HardCopy Timing Optimization Wizard creates the HardCopy Stratix project in the Quartus II software, where you can perform design optimization and performance estimation of your HardCopy Stratix device.

#### **Design Optimization**

Beginning with version 4.2, the Quartus II software supports HardCopy Stratix design optimization by providing floorplans for placement optimization and HardCopy Stratix timing models. These features enable you to refine placement of logic array blocks (LAB) and optimize the HardCopy design further than the FPGA performance. Customized routing and buffer insertion done in the Quartus II software are then used to estimate the design's performance in the migrated device. The HardCopy device floorplan, routing, and timing estimates in the Quartus II software reflect the actual placement of the design in the HardCopy Stratix device, and can be used to see the available resources, and the location of the resources in the actual device.

#### Performance Estimation

Figure 3–25 illustrates the design flow for estimating performance and optimizing your design. You can target your designs to HARDCOPY\_FPGA\_PROTOTYPE devices, migrate the design to the HardCopy Stratix device, and get placement optimization and timing estimation of your HardCopy Stratix device.

In the event that the required performance is not met, you can:

Work to improve LAB placement in the HardCopy Stratix project.

or

Go back to the HARDCOPY\_FPGA\_PROTOTYPE project and optimize that design, modify your RTL source code, repeat the migration to the HardCopy Stratix device, and perform the optimization and timing estimation steps.



On average, HardCopy Stratix devices are 40% faster than the equivalent -6 speed grade Stratix FPGA device. These performance numbers are highly design dependent, and you must obtain final performance numbers from Altera.

Figure 3–25. Obtaining a HardCopy Performance Estimation



To perform Timing Analysis for a HardCopy Stratix device, follow these steps:

- Open an existing project compiled for a HARDCOPY FPGA PROTOYPE device.
- On the Project menu, point to HardCopy Utilities and click HardCopy Timing Optimization Wizard.
- Select a destination directory for the migrated project and complete the HardCopy Timing Optimization Wizard process.

On completion of the HardCopy Timing Optimization Wizard, the destination directory created contains the Quartus II project file, and all files required for HardCopy Stratix implementation. At this stage, the design is copied from the HARDCOPY\_FPGA\_PROTOTYPE project directory to a new directory to perform the timing analysis. This two-project directory structure enables you to move back and forth between the HARDCOPY\_FPGA\_PROTOTYPE design database and the HardCopy Stratix design database. The Quartus II software creates the *project name*>\_hardcopy\_optimization directory.

You do not have to select the HardCopy Stratix device while performing performance estimation. When you run the HardCopy Timing Optimization Wizard, the Quartus II software selects the HardCopy Stratix device corresponding to the specified HARDCOPY\_FPGA\_PROTOTYPE FPGA. Thus, the information necessary for the HardCopy Stratix device is available from the earlier HARDCOPY\_FPGA\_PROTOTYPE device selection.

All constraints related to the design are also transferred to the new project directory. You can modify these constraints, if necessary, in your optimized design environment to achieve the necessary timing closure. However, if the design is optimized at the HARDCOPY\_FPGA\_PROTOTYPE device level by modifying the RTL code or the device constraints, you must migrate the project with the HardCopy Timing Optimization Wizard.



If an existing project directory is selected when the HardCopy Timing Optimization Wizard is run, the existing information is overwritten with the new compile results.

The project directory is the directory that you chose for the migrated project. A snapshot of the files inside the roject name>\_hardcopy\_optimization directory is shown in Table 3–5.

## Table 3–5. Directory Structure Generated by the HardCopy Timing Optimization Wizard

```
cproject name>_hardcopy_optimization\
     cproject name>.qsf
     cproject name>.qpf
     ct name>.sof
     cproject name>.macr
     cproject name>.gclk
     db\
     hardcopy_fpga_prototype\
      fpga_project name>_violations.datasheet
      fpga_<project name>_target.datasheet
      fpga_<project name>_rba_pt_hcpy_v.tcl
      fpga_<project name>_pt_hcpy_v.tcl
      fpga_project name>_hcpy_v.sdo
      fpga_project name>_hcpy.vo
      fpga_project name>_cpld.datasheet
      fpga_cksum.datasheet
      fpga_<project name>.tan.rpt
      fpga_<project name>.map.rpt
      fpga_<project name>.map.atm
      fpga_project name>.fit.rpt
      fpga_<project name>.db_info
      fpga_project name>.cmp.xml
      fpga_project name>.cmp.rcf
      fpga_<project name>.cmp.atm
      fpga_<project name>.asm.rpt
      fpga_project name>.qarlog
      fpga_<project name>.qar
      fpga_project name>.qsf
      fpga_<project name>.pin
      fpga_project name>.qpf
     db_export\
      cproject name>.map.atm
      cproject name>.map.hdbx
      project name>.db_info
```

4. Open the migrated Quartus II project created in Step 3.

5. Perform a full compilation.

After successful compilation, the Timing Analysis section of the Compilation Report shows the performance of the design.



Performance estimation is not supported for HardCopy APEX devices in the Quartus II software. Your design can be optimized by modifying the RTL code or the FPGA design and the constraints. You should contact Altera to discuss any desired performance improvements with HardCopy APEX devices.

#### **Buffer Insertion**

Beginning with version 4.2, the Quartus II software provides improved HardCopy Stratix device timing closure and estimation, to more accurately reflect the results expected after back-end migration. The Quartus II software performs the necessary buffer insertion in your HardCopy Stratix device during the Fitter process, and stores the location of these buffers and necessary routing information in the Quartus II Archive File. This buffer insertion improves the estimation of the Quartus II Timing Analyzer for the HardCopy Stratix device.

#### **Placement Constraints**

Beginning with version 4.2, the Quartus II software supports placement constraints and LogicLock regions for HardCopy Stratix devices. Figure 3–26 shows an iterative process to modify the placement constraints until the best placement for the HardCopy Stratix device is achieved.



Figure 3–26. Placement Constraints Flow for HardCopy Stratix Devices

## Location Constraints

This section provides information about HardCopy Stratix logic location constraints.

#### **LAB Assignments**

Logic placement in HardCopy Stratix is limited to LAB placement and optimization of the interconnecting signals between them. In a Stratix FPGA, individual logic elements (LE) are placed by the Quartus II Fitter into LABs. The HardCopy Stratix migration process requires that LAB contents cannot change after the Timing Optimization Wizard task is done. Therefore you can only make LAB-level placement optimization and location assignments after migrating the HARDCOPY\_FPGA\_PROTOTYPE project to the HardCopy Stratix device.

The Quartus II software supports these LAB location constraints for HardCopy Stratix devices. The entire contents of a LAB is moved to an empty LAB when using LAB location assignments. If you want to move the logic contents of LAB A to LAB B, the entire contents of LAB A are moved to an empty LAB B. For example, the logic contents of LAB\_X33\_Y65 can be moved to an empty LAB at LAB\_X43\_Y56 but individual logic cell LC\_X33\_Y65\_N1 can not be moved by itself in the HardCopy Stratix Timing Closure Floorplan.

#### **LogicLock Assignments**

The LogicLock feature of the Quartus II software provides a block-based design approach. Using this technique you can partition your design and create each block of logic independently, optimize placement and area, and integrate all blocks into the top level design.



To learn more about this methodology, refer to the *LogicLock Design Methodology* chapter in volume 2 of the *Quartus II Handbook*.

LogicLock constraints are supported when you migrate the project from a HARDCOPY\_FPGA\_PROTOTYPE project to a HardCopy Stratix project. If the LogicLock region was specified as "Size=Fixed" and "Location=Locked" in the HARDCOPY\_FPGA\_PROTOTYPE project, it is converted to have "Size=Auto" and "Location=Floating" as shown in the following LogicLock examples. This modification is necessary because the floorplan of a HardCopy Stratix device is different from that of the Stratix device, and the assigned coordinates in the HARDCOPY\_FPGA\_PROTOTYPE do not match the HardCopy Stratix floorplan. If this modification did not occur, LogicLock assignments would lead to incorrect placement in the Quartus II Fitter. Making the regions auto-size and floating, maintains your LogicLock assignments, allowing you to easily adjust the LogicLock regions as required and lock their locations again after HardCopy Stratix placement.

Example 3–1 and Example 3–2 show two examples of LogicLock assignments.

#### Example 3–1. LogicLock Region Definition in the HARDCOPY\_FPGA\_PROTOTYPE Quartus II Settings File

```
set_global_assignment -name LL_HEIGHT 15 -entity risc8 -section_id test set_global_assignment -name LL_WIDTH 15 -entity risc8 -section_id test set_global_assignment -name LL_STATE LOCKED -entity risc8 -section_id test set_global_assignment -name LL_AUTO_SIZE OFF -entity risc8 -section_id test
```

#### Example 3–2. LogicLock Region Definition in the Migrated HardCopy Stratix Quartus II Settings File

```
set_global_assignment -name LL_HEIGHT 15 -entity risc8 -section_id test
set_global_assignment -name LL_WIDTH 15 -entity risc8 -section_id test
set_global_assignment -name LL_STATE FLOATING -entity risc8 -section_id
test
set_global_assignment -name LL_AUTO_SIZE ON -entity risc8 -section_id test
```

# Checking Designs for HardCopy Design Guidelines

When you develop a design with HardCopy migration in mind, you must follow Altera recommended design practices that ensure a straightforward migration process or the design will not be able to be implemented in a HardCopy device. Prior to starting migration of the design to a HardCopy device, you must review the design and identify and address all the design issues. Any design issues that have not been addressed can jeopardize silicon success.

#### **Altera-Recommended HDL Coding Guidelines**

Designing for Altera PLD, FPGA, and HardCopy structured ASIC devices requires certain specific design guidelines and hardware description language (HDL) coding style recommendations be followed.



For more information about design recommendations and HDL coding styles, refer to the *Design Guidelines* Section in volume 1 of the *Quartus II Handbook*.

#### **Design Assistant**

The Quartus II software includes the Design Assistant feature to check your design against the HardCopy design guidelines. Some of the design rule checks performed by the Design Assistant include the following rules:

- Design should not contain combinational loops
- Design should not contain delay chains
- Design should not contain latches

To use the Design Assistant, you must have at least run Analysis and Synthesis on the design in the Quartus II software. Altera recommends that you run the Design Assistant to check for compliance with the HardCopy design guidelines early in the design process and after every compilation.

#### Design Assistant Settings

You must select the design rules in the **Design Assistant** page prior to running the design. On the Assignments menu, click **Settings**. In the **Settings** dialog box, in the Category list, select **Design Assistant** and turn on **Run Design Assistant during compilation**. Altera recommends enabling this feature to run the Design Assistant automatically during compilation of your design.

#### Running Design Assistant

To run Design Assistant independently of other Quartus II features, on the Processing menu, point to Start and click **Start Design Assistant**.

The Design Assistant automatically runs in the background of the Quartus II software when the HardCopy Timing Optimization Wizard is launched, and does not display the Design Assistant results immediately to the display. The design is checked before the Quartus II software migrates the design and creates a new project directory for performing timing analysis.

Also, the Design Assistant runs automatically whenever you generate the HardCopy design database with the HardCopy Files Wizard. The Design Assistant report generated is used by the Altera HardCopy Design Center to review your design.

#### **Reports & Summary**

The results of running the Design Assistant on your design are available in the Design Assistant Results section of the Compilation Report. The Design Assistant also generates the summary report in the report name \hardcopy subdirectory of the project directory. This report file is titled /roject name \_violations.datasheet. Reports include the settings, run summary, results summary, and details of the results and messages. The Design Assistant report indicates the rule name, severity of the violation and the circuit path where any violation occurred.



To learn about the design rules and standard design practices to comply with HardCopy design rules, refer to the Quartus II Help and the *HardCopy Series Design Guidelines* chapter in volume 1 of the *HardCopy Series Handbook*.

## Generating the HardCopy Design Database

You can use the HardCopy Files Wizard to generate the complete set of deliverables required for migrating the design to a HardCopy device in a single click. The HardCopy Files Wizard asks questions related to the design and archives your design, settings, results, and database files for delivery to Altera. Your responses to the design details are stored in rproject name>\_hardcopy\_optimization\cproject name>\_hps.txt.

You can generate the archive of the HardCopy design database only after compiling the design to a HardCopy Stratix device. The Quartus II Archive File is generated at the same directory level as the targeted project, either before or after optimization.



The Design Assistant automatically runs when the HardCopy Files Wizard is started.

Table 3–6 shows the archive directory structure and files collected by the HardCopy Files Wizard.

Table 3–6. HardCopy Stratix Design Files Collected by the HardCopy Files Wizard

```
cproject name>_hardcopy_optimization\
    cproject name>.flow.rpt
    project name>.qpf
    project name>.asm.rpt
    ct name>.blf
    cproject name>.fit.rpt
    ct name>.gclk
    project name>.hps.txt
    ct name>.macr
    cproject name>.pin
    project name>.qsf
    ct name>.sof
    ct name>.tan.rpt
    hardcopy\
          project name>.apc
          project name>_cksum.datasheet
          cpiect name>_cpld.datasheet
          project name>_hcpy.vo
          project name>_hcpy_v.sdo
          project name>_pt_hcpy_v.tcl
          cproject name>_rba_pt_hcpy_v.tcl
          project name>_target.datasheet
          cproject name>_violations.datasheet
    hardcopy_fpga_prototype\
          fpga_project name>.asm.rpt
          fpga_<project name>.cmp.rcf
          fpga_<project name>.cmp.xml
          fpga_<project name>.db_info
          fpga_<project name>.fit.rpt
          fpga_project name>.map.atm
          fpga_project name>.map.rpt
          fpga_<project name>.pin
          fpga_project name>.qsf
          fpga_<project name>.tan.rpt
          fpga_project name>_cksum.datasheet
          fpga_<project name>_cpld.datasheet
          fpga_<project name>_hcpy.vo
          fpga_fpga_project name>_hcpy_v.sdo
          fpga_project name>_pt_hcpy_v.tcl
          fpga_project name>_rba_pt_hcpy_v.tcl
          fpga_project name>_target.datasheet
          fpga_<project name>_violations.datasheet
    db_export\
          project name>.db_info
          vroiect name>.map.atm
          cproject name>.map.hdbx
```

After creating the migration database with the HardCopy Timing Optimization Wizard, you must compile the design before generating the project archive. You will receive an error if you create the archive before compiling the design.

## Static Timing Analysis

In addition to performing timing analysis, the Quartus II software also provides all of the requisite netlists and Tcl scripts to perform static timing analysis (STA) using the Synopsys STA tool, PrimeTime. The following files, necessary for timing analysis with the PrimeTime tool, are generated by the HardCopy Files Wizard:

- project name>\_hcpy.vo—Verilog HDL output format
- project name>\_hpcy\_v.sdo—Standard Delay Format Output File
- cproject name>\_pt\_hcpy\_v.tcl—Tcl script

These files are available in the *<project name*>\hardcopy directory. PrimeTime libraries for the HardCopy Stratix and Stratix devices are included with the Quartus II software.



Use the HardCopy Stratix libraries for PrimeTime to perform STA during timing analysis of designs targeted to HARDCOPY\_FPGA\_PROTOTYPE device.



For more information about static timing analysis, refer to the *Classic Timing Analyzer* and the *Synopsys PrimeTime Support* chapters in volume 3 of the *Quartus II Handbook*.

## Early Power Estimation

You can use PowerPlay Early Power Estimation to estimate the amount of power your HardCopy Stratix or HardCopy APEX device will consume. This tool is available on the Altera web site. Using the Early Power Estimator requires some knowledge of your design resources and specifications, including:

- Target device and package
- Clock networks used in the design
- Resource usage for LEs, DSP blocks, PLL, and RAM blocks
- High speed differential interfaces (HSDI), general I/O power consumption requirements, and pin counts
- Environmental and thermal conditions

#### HardCopy Stratix Early Power Estimation

The PowerPlay Early Power Estimator provides an initial estimate of  $I_{CC}$  for any HardCopy Stratix device based on typical conditions. This calculation saves significant time and effort in gaining a quick understanding of the power requirements for the device. No stimulus vectors are necessary for power estimation, which is established by the clock frequency and toggle rate in each clock domain.

This calculation should only be used as an estimation of power, not as a specification. The actual  $I_{CC}$  should be verified during operation because this estimate is sensitive to the actual logic in the device and the environmental operating conditions.



For more information about simulation-based power estimation, refer to the *Power Estimation & Analysis* Section in volume 3 of the *Quartus II Handbook*.



On average, HardCopy Stratix devices are expected to consume 40% less power than the equivalent FPGA.

#### HardCopy APEX Early Power Estimation

The PowerPlay Early Power Estimator can be run from the Altera web site in the device support section

(http://www.altera.com/support/devices/dvs-index.html). You cannot open this feature in the Quartus II software.

With the HardCopy APEX PowerPlay Early Power Estimator, you can estimate the power consumed by HardCopy APEX devices and design systems with the appropriate power budget. Refer to the web page for instructions on using the HardCopy APEX PowerPlay Early Power Estimator.



HardCopy APEX devices are generally expected to consume about 40% less power than the equivalent APEX 20KE or APEX 20KC FPGA devices.

## Tcl Support for HardCopy Stratix

The Quartus II software also supports the HardCopy Stratix design flow at the command prompt using Tcl scripts.



For details on Quartus II support for Tcl scripting, refer to the *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*.

# Targeting Designs to HardCopy APEX Devices

Beginning with version 4.2, the Quartus II software supports targeting designs to HardCopy APEX device families. After compiling your design for one of the APEX 20KC or APEX 20KE FPGA devices supported by a HardCopy APEX device, run the HardCopy Files Wizard to generate the necessary set of files for HardCopy migration.

The HardCopy APEX device requires a different set of design files for migration than HardCopy Stratix. Table 3–7 shows the files collected for HardCopy APEX by the HardCopy Files Wizard.

#### Table 3–7. HardCopy APEX Files Collected by the HardCopy Files Wizard

project name>.tan.rpt cproject name>.asm.rpt cproject name>.fit.rpt ct name>.hps.txt cproject name>.map.rpt project name>.pin cproject name>.sof ct name>.qsf cksum.datasheet cpld.datasheet project name>\_hcpy.vo cproject name>\_hcpy\_v.sdo project name>\_pt\_hcpy\_v.tcl project name>\_rba\_pt\_hcpy\_v.tcl cproject name>\_target.datasheet cproject name>\_violations.datasheet

Refer to "Generating the HardCopy Design Database" on page 3–50 for information about generating the complete set of deliverables required for migrating the design to a HardCopy APEX device. After you have successfully run the HardCopy Files Wizard, you can submit your design archive to Altera to implement of your design in a HardCopy device. You should contact Altera for more information about this process.

#### Conclusion

The methodology for designing HardCopy Stratix devices using the Quartus II software is the same as that for designing the Stratix FPGA equivalent. You can use the familiar Quartus II software tools and design flow, target designs to HardCopy Stratix devices, optimize designs for higher performance and lower power consumption than the Stratix FPGAs, and deliver the design database for migration to a HardCopy Stratix device. Compatible APEX FPGA designs can migrate to HardCopy APEX after compilation using the HardCopy Files Wizard to archive the design files. Submit the files to the HardCopy Design Center to complete the back-end migration.

## Related Documents

For more information, refer to the following documentation:

- The *HardCopy Series Design Guidelines* chapter in volume 1 of the *HardCopy Series Handbook*
- The HardCopy Series Back-End Timing Closure chapter in volume 1 of the HardCopy Series Handbook



## 4. Engineering Change Management

QII51005-6.0.0

#### Introduction

A major benefit of programmable logic is that it accommodates changes to the system specification late in the design cycle. In a typical engineering project development cycle, the specification for the programmable logic portion is likely to change when engineering development begins or when integrating all system elements.

Last-minute design changes, commonly referred to as engineering change orders (ECOs), are defined as small changes to the functionality of a design, after the design has been fully compiled; that is, when synthesis and place-and-route are completed.

ECOs are usually intended to correct errors found in the programmable logic design during debugging, or to facilitate changes that are made to the design specification to compensate for design problems that are introduced while integrating components of your system design. As a project nears completion, a significant amount of time has been invested in maximizing performance and design verification; therefore, it is important that your ECO changes affect specific parts of your design and have minimal impact on unrelated parts of your design.

This chapter addresses the impact that ECOs have, and explains how to resolve these issues using the Quartus<sup>®</sup> II software.

## Impact of Last Minute Design Changes

ECOs have an impact on the following areas of a system design:

- Performance
- Compile time
- Verification
- Documentation

#### **Performance**

When making a small change to the design functionality, the result can be a loss of previous design optimizations. Typical examples of design optimizations are floorplan optimizations and physical synthesis. Ideally, there should be a means to preserve previous design optimizations. This would focus future optimizations only to design areas where ECO changes occurred.

#### **Compilation Time**

In the traditional programmable logic design flow, a small change in the design necessarily results in a complete recompilation of the design; that is, synthesis and place-and-route. Making small changes to the design to reach the final implementation on a board can be a very long process. Ideally, to reach the desired functionality and to reach timing closure, a small change in functionality should result in reduced compilation time. You can achieve this by the incremental compilation feature, which uses the previous fit information on unchanged areas of the design.

#### Verification

After a design change, you must verify the impact of the change on your design. You can verify your design by performing timing analysis and simulation. You can choose to limit the verification to the area of the design impacted by the ECOs. To do this, run timing analysis on select paths and perform the simulation on gate level and timing simulation netlists.

#### **Documentation**

You must track changes to your project files. Tracking changes provides the ability to reproduce your results. Ideally, you can have multiple compilation revisions so that others can try the changes without corrupting the previous results.

### **ECO Support**

You can apply ECOs at two stages in a typical design flow:

- HDL level
- Netlist level

Historically, in programmable logic designs, you would apply ECOs at the HDL level. The reason for this was the lack of tools for PLDs that could easily create ECOs and enable design sign-off at the netlist level.

#### **ECO Support at the HDL Level**

An ECO at the HDL level is a change to the design's Verilog HDL or VHDL source. This change may range from a single line to several lines of code modified within a module or entity. Typical examples of such modifications include:

- Changing the state encoding of a finite state machine
- Adding pipeline registers to improve design performance

- Duplicating the signal to reduce fan-out
- Adding a term to a conditional expression
- Changing the polarity of a register control signal

A few changes to the source code can produce many changes to the netlist produced by other EDA synthesis or tools such as the Quartus II software's integrated synthesis. During the synthesis process, the synthesis tools generally preserve the names of registers from the HDL source code, but automatically generate names for the combinational (look-up table level, or LUT level) nodes. This automatic name generation is necessary to accommodate the synthesis optimization performed on the HDL source to use the target device resources more efficiently.

A minor source code change can result in many changes to the names in the synthesis netlist. The changes in the synthesis netlist can be caused by the node names in the new netlist implementing a different functionality than in the previous netlist, or by implementing the same functionality as in the previous netlist, but have different names.

To leverage previous design optimizations and to reduce compilation time, there must be a way to perform incremental compilation on the modules with the new functionality to preserve the previous optimizations. The incremental compilation feature available in the Quartus II software provides a solution to this problem.

With Quartus II incremental compilation, you can preserve results and performance of unchanged logic in your design as you make ECOs elsewhere. The incremental compilation feature enables you to reduce design iteration time up to 70%, and reach timing closure more efficiently. Incremental compilation facilitates block-based design, and allows you to preserve performance for unchanged blocks of the design. You can also target optimization techniques, such as physical synthesis, to specific design blocks while leaving other blocks untouched.

A hierarchical design is flattened into a single netlist before logic synthesis and fitting; therefore, the entire design is recompiled every time the design changes. However, the incremental compilation feature allows you to partition a design along any of its hierarchical boundaries. The Quartus II software separately synthesizes and fits each individual hierarchical design partition. The Quartus II software combines or merges the design partitions to form a netlist for subsequent stages of the Quartus II compilation flow.

Figure 4–1 details the recommended design flow to support ECO changes at the HDL level.

Verilog Block **EDIF** VQM VHDL **AHDL** Design File HDL Netlist Netlist (.vhd) (.tdf) (.bdf) (.edf) (.v) (.vqm) Partition Top Design Partition Partition 1 Assignments Partition 2 Analysis & **Analysis & Synthesis** Synthesis Settings **Partition Merge** Create Complete Netlist Using Appropriate Source Netlists for Each Partition (Post-Fit or Post-Synthesis) Floorplan Location Assignments Fitter & Fitter Settings Assembler **Timing Analyzer** Make ECO Chip Editor Changes No No Make ECO HDL Changes Requirements Satisfied? Yes Program/Configure Device

Figure 4-1. Design Flow to Support ECO Changes

#### **ECO Support at the Netlist Level**

For some ECO changes, making changes at the netlist level can be faster than at the HDL level. This happens when you are debugging the design on silicon and need a very fast turnaround to generate a programming file for debugging the system.

A typical application occurs when you uncover a problem on the board and isolate the problem to the appropriate nodes or I/O cells on the PLD. You then need to be able to quickly correct the functionality of the offending logic cell or the properties of the I/O cell and generate a new programming file. In doing this, you can verify the operation of the change without having to modify the HDL and perform a synthesis and place-and-route operation. This minimizes the disruption to the board verification procedure.

If this quick fix works, you do not need to change the HDL source code and rerun place-and-route. You should have the option to:

- Document the change that has been made
- Easily recreate the steps taken to produce the changes to the design
- Generate EDA simulation netlists for verification of the design
- Perform timing analysis on the design

The Chip Editor feature of the Quartus II software provides these capabilities.

The Quartus II Chip Editor allows you to make functional changes to individual logic cells and to the I/O cell and phase-locked loop (PLL) parameters. These changes are stored in the Quartus II Change Manager log. This allows you to control the application of the changes, and generate a tool command language (Tcl) file.

The Tcl commands file recreates the changes on the original netlist and documents the project changes. This provides the ability to recreate the changes on the original design files without having to change the HDL source. You can regenerate an EDA simulation netlist for the modified design if it is necessary to perform a gate-level simulation of the modified design. If you should rerun timing analysis to sign-off the design, you can rerun timing analysis on the netlist containing the ECO changes.



For more information, refer to the *Design Analysis and Engineering Change Management with Chip Editor* chapter in volume 3 of the *Quartus II Handbook*.



Figure 4–2 shows the flow for ECO changes at the netlist level.

### **Conclusion**

Support for ECOs requires a combination of a modular design methodology and the appropriate software design tools.

The Quartus II software provides you with the software tools and the design methodology to perform successful ECOs at both the HDL and netlist level for programmable logic designs. This reduces the design cycle time and provides faster timing closure on designs that require last-minute changes.



## Section II. Design Guidelines

Today's programmable logic device (PLD) applications have reached the complexity and performance requirements of ASICs. In the development of such complex system designs, good design practices have an enormous impact on your device's timing performance, logic utilization, and system reliability. Designs coded optimally will behave in a predictable and reliable manner, even when re-targeted to different device families or speed grades. This section presents design and coding style recommendations for Altera® devices.

This section includes the following chapters:

- Chapter 5, Design Recommendations for Altera Devices
- Chapter 6, Recommended HDL Coding Styles
- Chapter 7 moved to Volume 2

Altera Corporation Section II-1

## $\textbf{Revision History} \qquad \text{The following table shows the revision history for Chapters 5 to 6}.$

| Chapter(s) | Date / Version      | Changes Made                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 5          | May 2006 v6.0.0     | Minor updates for the Quartus II version 6.0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|            | October 2005 v5.1.0 | Updated for the Quartus II software version 5.1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|            | May 2005 v.5.0.0    | Chapter 5 was formerly Chapter 4 in version 4.2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|            | Dec. 2004 v2.1      | Updated for Quartus II software version 4.2: Chapter 5 was formerly Chapter 6 in version 4.1. General formatting and editing updates. Updated hardware requirements for the Quartus II Timing Analyzer. Added timing requirements and analysis details. Updated Design Guidelines. Added information about performing timing analysis on asynchronous ports. Added inferred latches information. Updated Delay Chains description. Updated figures, tables. Added Clocking Schemes information. Added details to Multiplexed Clocks details. Added clock gating details. Updated Hierarchical Design Partitioning to include synthesis and incremental synthesis. Added global routing information. |  |  |
|            | June 2004 v.2.0     | <ul> <li>Updates to tables, figures, coding examples.</li> <li>New functionality for Quartus II software 4.1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|            | Feb. 2004 v1.0      | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| 6          | May 2006 v6.0.0     | Updated for the Quartus II version 6.0:  Added inferring Altera Megafunctions from HDL code information.  Added coding guidelines for other logic structures.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|            | October 2005 v5.1.0 | Updated for the Quartus II software version 5.1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|            | May 2005 v.5.0.0    | Chapter 6 was formerly Chapter 5 in version 4.2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|            | Dec. 2004 v2.1      | <ul> <li>Chapter 6 was formerly Chapter 7 in version 4.1.</li> <li>Updates to tables, figures.</li> <li>New functionality for Quartus II software 4.2.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|            | June 2004 v2.0      | <ul> <li>Updates to tables, figures.</li> <li>Added and updated State Machines.</li> <li>Update to Verilog HDL for State Machines.</li> <li>New functionality for Quartus II software 4.1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|            | Feb. 2004 v1.0      | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |

Section II-2 Altera Corporation

| Chapter(s) | Date / Version      | Changes Made                                                                                                                 |
|------------|---------------------|------------------------------------------------------------------------------------------------------------------------------|
| 7          | October 2005 v5.1.0 | Chapter now resides in Volume 2, Section III, Chapter 9: Power Optimization                                                  |
|            | August 2005 v.5.0.1 | <ul><li>Updates to tables, figures.</li><li>Added Standard Fir-Fitter Effort section.</li><li>Updated information.</li></ul> |
|            | May 2005 v.5.0.0    | Initial release.                                                                                                             |

Altera Corporation 4–3

4–4 Altera Corporation



# 5. Design Recommendations for Altera Devices

QII51006-6.0.0

## Introduction

Today's FPGA applications have reached the complexity and performance requirements of ASICs. In the development of such complex system designs, good design practices have an enormous impact on your device's timing performance, logic utilization, and system reliability. Well-coded designs behave in a predictable and reliable manner even when re-targeted to different families or speed grades. Good design practices also aid in successful design migration between FPGA and HardCopy® or ASIC implementations for prototyping and production.

For optimal performance and reliability and faster time-to-market when designing with Altera® devices, you should:

- Understand the impact of synchronous design practices
- Follow recommended design techniques including hierarchical design partitioning
- Take advantage of the architectural features in the targeted device



For specific HDL coding examples and recommendations, including coding guidelines for targeting dedicated device hardware, such as memory and DSP blocks, refer to the *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook*. For information about migrating designs to HardCopy devices, refer to the *HardCopy Series Design Guidelines* chapter in the *HardCopy Series Handbook*.

## Synchronous FPGA Design Practices

The first step in a good design methodology is to understand the implications of your design practices and techniques. This section outlines some of the benefits of optimal synchronous design practices and the hazards involved in other techniques. Good synchronous design practices can help you consistently meet your design goals. Problems with other design techniques can include reliance on propagation delays in a device, incomplete timing analysis, and possible glitches.

In a synchronous design, a clock signal triggers all events. As long as all of the registers' timing requirements are met, a synchronous design behaves in a predictable and reliable manner for all process, voltage, and temperature (PVT) conditions. You can easily target synchronous designs to different device families or speed grades. In addition, if you plan to migrate your design to a high-volume solution such as Altera HardCopy devices, or if you are prototyping an ASIC, then synchronous design practices help ensure successful migration.

## **Fundamentals of Synchronous Design**

In a synchronous design, everything is related to the clock signal. On every active edge of the clock (usually the rising edge), the data inputs of registers are sampled and transferred to outputs. Following an active clock edge, the outputs of combinational logic feeding the data inputs of registers change values. This change triggers a period of instability due to propagation delays through the logic as the signals go through a number of transitions and finally settle to new values. Changes happening on data inputs of registers do not affect the values of their outputs until the next active clock edge.

Because the internal circuitry of registers isolates data outputs from inputs, instability in the combinational logic does not affect the operation of the design as long as the following timing requirements are met:

- Before an active clock edge, the data input has been stable for at least the setup time of the register
- After an active clock edge, the data input remains stable for at least the hold time of the register

When you specify all your clock frequencies and other timing requirements, the Quartus  $^{\otimes}$  II Timing Analyzer issues actual hardware requirements for the setup times ( $t_{SU}$ ) and hold times ( $t_{H}$ ) for every pin of your design. By meeting these external pin requirements and following synchronous design techniques, you ensure that you satisfy the setup and hold times for all registers within the Altera device.



To meet setup and hold time requirements on all input pins, any inputs to combinational logic that feeds a register should have a synchronous relationship with the clock of the register. If signals are asynchronous, you can register the signals at the input of the Altera device to help prevent a violation of the required setup and hold times.

When the setup or hold time of a register is violated, the output can be set to an intermediate voltage level between the high and low levels, called a metastable state. In this unstable state, small perturbations like noise in power rails can cause the register to assume either the high or low voltage level resulting in an unpredictable valid state. Various undesirable effects can occur, including increased propagation delays and incorrect output states. In some cases, the output can even oscillate between the two valid states for a relatively long time.



For details about timing requirements and analysis in the Quartus II software, refer to the *Classic Timing Analysis* or the *TimeQuest Timing Analysis* chapters in volume 3 of the *Quartus II Handbook*.

## **Hazards of Asynchronous Design**

In the past, designers have often used asynchronous techniques such as ripple counters or pulse generators in programmable logic device (PLD) designs, enabling them to take "short cuts" to save device resources. Asynchronous design techniques have inherent problems such as relying on propagation delays in a device, which can result in incomplete timing constraints and possible glitches and spikes. Because today's FPGAs provide many high-performance logic gates, registers, and memory, resource and performance trade-offs have changed. Now it is more important to focus on design practices that help you meet design goals consistently than to save device resources using problematic asynchronous techniques.

Some asynchronous design structures rely on the relative propagation delays of signals to function correctly. In these cases, race conditions can arise where the order of signal changes can affect the output of the logic. PLD designs can have varying timing delays, depending on how the design is placed and routed in the device with each compilation. Therefore, it is almost impossible to determine the timing delay associated with a particular block of logic ahead of time. As devices become faster because of device process improvements, the delays in an asynchronous design may decrease, resulting in a design that does not function as expected. Specific examples are provided in "Design Guidelines" on page 5–4. Relying on a particular delay also makes asynchronous designs very difficult to migrate to different architectures, devices, or speed grades.

The timing of asynchronous design structures is often difficult or impossible to model with timing assignments and constraints. If you do not have complete or accurate timing constraints, the timing-driven algorithms used by your synthesis and place-and-route tools may not be able to perform the best optimizations, and reported results may not be complete.

Some asynchronous design structures can generate harmful glitches, which are pulses that are very short compared with clock periods. Most glitches are generated by combinational logic. When the inputs of combinational logic change, the outputs exhibit a number of glitches before they settle to their new values. These glitches can propagate through the combinational logic, leading to incorrect values on the outputs in asynchronous designs. In a synchronous design, glitches on the data inputs of registers are normal events that have no negative consequences because the data is not processed until the clock edge.

## Design Guidelines

When designing with hardware description language (HDL) code, understanding how a synthesis tool interprets different HDL design techniques and what results to expect are important. Your design techniques can affect logic utilization and timing performance, as well as the design's reliability. This section discusses some basic design techniques that ensure optimal synthesis results for designs targeted to Altera devices while avoiding several common causes of unreliability and instability. Design your combinational logic carefully to avoid potential problems and pay attention to your clocking schemes so you can maintain synchronous functionality and avoid timing problems.

## **Combinational Logic Structures**

Combinational logic structures consist of logic functions that depend only on the current state of the inputs. In Altera FPGAs, these functions are implemented in the look-up tables (LUTs) of the device's architecture, using either logic elements (LE) or adaptive logic modules (ALM). In some cases when combinational logic feeds registers, the register control signals can also be used to implement part of the logic function to save LUT resources. By following the recommendations in this section, you can improve the reliability of your combinational design.

## Combinational Loops

Combinational loops are among the most common causes of instability and unreliability in digital designs, and should be avoided whenever possible. In a synchronous design, feedback loops should include registers. Combinational loops generally violate synchronous design principles by establishing a direct feedback loop that contains no registers. For example, a combinational loop occurs when the left-hand side of an arithmetic expression also appears on the right-hand side in HDL code. A combinational loop also occurs when you feed back the output of a register to an asynchronous pin of the same register through combinational logic, as shown in Figure 5–1.

Figure 5–1. Combinational Loop through Asynchronous Control Pin





To perform timing analysis in the Quartus II software on asynchronous ports such as the clear or reset, on the Assignments menu, click **Settings**. In the Settings dialog box, select **Timing Requirements & Option** and click **More Settings**. Turn on **Enable Recovery/Removal Analysis**.

Combinational loops are inherently high-risk design structures for the following reasons:

- Combinational loop behavior generally depends on the relative propagation delays through the logic involved in the loop. As discussed, propagation delays can change which means the behavior of the loop is unpredictable.
- Combinational loops can cause endless computation loops in many design tools. Most tools break open combinational loops to process the design. The various tools used in the design flow may open a given loop in a different manner, processing it in a way that is inconsistent with the original design intent.

#### Latches

A latch is a small combinational loop that holds the value of a signal until a new value is assigned. Latches can also be inferred from HDL code when you did not intend to use a latch. FPGA architectures are based on registers. In FPGA devices, latches actually use more logic resources and lead to lower performance than registers. This is different from other device architectures where latches may add less delay and can be implemented with less silicon area than registers.

Latches can cause various difficulties in the design. Although latches are memory elements, they are fundamentally different from registers. When a latch is in feed-through or transparent mode, there is a direct path between the data input and the output. Glitches on the data input can pass through the output. The timing for latches is also inherently ambiguous. For example, when analyzing a design with a D-latch, the software cannot determine whether you intended to transfer data to the output on the leading edge of the clock or on the trailing edge. In many cases, only the original designer knows the full intent of the design; therefore, another designer cannot easily modify the design or reuse the code.

In some cases, your synthesis tool can infer a latch that does not exhibit problems with glitches. Inferring the Altera lpm\_latch function ensures that the implementation will be glitch-free in Altera architectures. Some third-party synthesis tools list the number of lpm\_latch functions that are inferred. When using Quartus II integrated synthesis, these latches are reported in a section of the Compilation Report called **User-Specified** 

and Inferred Latches. If a latch or combinational loop in your design is not listed in this report, it means that it was not inferred as a "safe" latch by the software and is not considered glitch-free.

However, even glitch-free latches may not be analyzed completely during timing analysis. The Quartus II software provides an option called **Analyze latches as synchronous elements** that allows you to treat latches as start and end points for timing analysis (a typical analysis performed in FPGA design tools). With this option turned on, latches are analyzed as registers (with an inverted clock). The Quartus II software does not perform cycle-borrowing analysis, such as that performed by third-party timing analysis tools like Synopsys PrimeTime.

In addition, latches have a limited support in formal verification tools. Therefore, it is especially important to ensure that you do not use latches when using formal verification.

Altera recommends avoiding using latches to ensure that you can completely analyze and verify the timing performance and reliability of your design.

## Delay Chains

Delay chains occur when two or more consecutive nodes with a single fan-in and a single fan-out are used to cause delay. Inverters are often chained together to add delay. Delay chains are sometimes used to resolve race conditions created by other asynchronous design practices.

As described above, delays in PLD designs can change with each place-and-route cycle. Effects such as rise/fall time differences and on-chip variation mean that delay chains, especially those placed on clock paths, can cause significant problems in your design. See "Hazards of Asynchronous Design" on page 5–3 for examples of the kinds of problems that delay chains can cause. Avoid using delay chains to prevent these kind of problems.

In some ASIC designs, delays are used for buffering signals as they are routed around the device. This functionality is not needed in FPGA devices because the routing structure provides buffers throughout the device.

## Pulse Generators & Multivibrators

Delay chains are sometimes used to generate either one pulse (pulse generators) or a series of pulses (multivibrators). There are two common methods for pulse generation, as shown in Figure 5–2. These techniques are purely asynchronous and therefore should be avoided.

Figure 5–2. Asynchronous Pulse Generators

#### Using an AND Gate



#### Using a Register



In "Using an AND Gate" (Figure 5–2), a trigger signal feeds both inputs of a 2-input AND gate, but the design inverts or adds a delay chain to one of the inputs. The width of the pulse depends on the relative delays of the path that feeds the gate directly and the one that goes through the delay. This is the same mechanism responsible for the generation of glitches in combinational logic following a change of input values. This technique artificially increases the width of the glitch by using a delay chain.

In "Using a Register" (Figure 5–2), a register's output drives the same register's asynchronous reset signal through a delay chain. The register resets itself asynchronously after a certain delay.

The width of pulses generated in this way are difficult for synthesis and place-and-route software to determine, set, or verify. The actual pulse width can only be determined after placement and routing, when routing and propagation delays are known. You cannot reliably determine the width of the pulse when creating HDL code, and it cannot be set by EDA tools. The pulse may not be wide enough for the application under all PVT conditions, and the pulse width changes if you change to a different device. In addition, static timing analysis cannot be used to verify the pulse width, so verification is very difficult.

Multivibrators use a "glitch generator" to create pulses, together with a combinational loop that turns the circuit into an oscillator. This creates additional problems because of the number of pulses involved. In addition, when the structures generate multiple pulses, they also create a new artificial clock in the design that has to be analyzed by the design tools.

When you need to use a pulse generator, use synchronous techniques, as shown in Figure 5–3.

Trigger Signal D Q D Q
Clock

Figure 5-3. Recommended Pulse-Generation Technique

In this design, the pulse width is always equal to the clock period. This pulse generator is predictable, can be verified with timing analysis, and is easily moved to other architectures, devices, or speed grades.

## **Clocking Schemes**

Like combinational logic, clocking schemes have a large effect on your design's performance and reliability. Avoid using internally generated clocks where possible because they can cause functional and timing problems in the design. Clocks generated with combinational logic can introduce glitches that create functional problems, and the delay inherent in combinational logic can lead to timing problems. The following sections provide some specific examples and recommendations for avoiding these problems.



Specify all clock relationships in the Quartus II software to allow for the best timing-driven optimizations during fitting and to allow correct timing analysis. Use clock setting assignments on any derived or internal clocks to specify their relationship to the base clock.

Altera recommends using global device-wide, low-skew dedicated routing for all internally-generated clocks, instead of routing clocks on regular routing lines. See "Clock Network Resources" on page 5–16 for a detailed explanation.

Avoid data transfers between different clocks wherever possible. If a data transfer between different clocks is needed, use FIFO circuitry. You can use the clock uncertainty features in the Quartus II software to compensate for the variable delays between clock domains. Consider setting a Clock Setup Uncertainty and Clock Hold Uncertainty value of 10% to 15% of the clock delay.

## Internally Generated Clocks

If you use the output from combinational logic as a clock signal or as an asynchronous reset signal, you should expect to see glitches in your design. In a synchronous design, glitches on data inputs of registers are normal events that have no consequences. However, a glitch or a spike on the clock input (or an asynchronous input) to a register can have significant consequences. Narrow glitches can violate the register's minimum pulse width requirements. Setup and hold times may also be violated if the data input of the register is changing when a glitch reaches the clock input. Even if the design does not violate timing requirements, the register output can change value unexpectedly and cause functional hazards elsewhere in the design.

Because of these problems, always register the output of combinational logic before you use it as a clock signal. See Figure 5–4.

Figure 5-4. Recommended Clock-Generation Technique



Registering the output of combinational logic ensures that the glitches generated by the combinational logic are blocked at the data input of the register.

#### Divided Clocks

Designs often require clocks created by dividing a master clock. Most Altera FPGAs provide dedicated phase-locked loop (PLL) circuitry for clock division. Using dedicated PLL circuitry can help you to avoid many of the problems that can be introduced by asynchronous clock division logic.

When you need to use logic to divide a master clock, always use synchronous counters or state machines. In addition, create your design so that registers always directly generate divided clock signals, as described in "Internally Generated Clocks" on page 5–9, and route the clock on global clock resources. To avoid glitches, you should not decode the outputs of a counter or a state machine to generate clock signals.

## Ripple Counters

Altera recommends avoiding ripple counters in your design to simplify verification. In the past, FPGA designers implemented ripple counters to divide clocks by a power of two because the counters are easy to design and may use fewer gates than their synchronous counterparts. Ripple counters use cascaded registers, in which the output pin of each register feeds the clock pin of the register in the next stage. This cascading can cause problems because the counter creates a ripple clock at each stage. These ripple clocks have to be handled properly during timing analysis, which can be difficult and may require you to make complicated timing assignments in your synthesis and place-and-route tools.

## Multiplexed Clocks

Clock multiplexing can be used to operate the same logic function with different clock sources. In these designs, multiplexing selects a clock source, as in Figure 5–5. For example, telecommunications applications that deal with multiple frequency standards often use multiplexed clocks.

Figure 5-5. Multiplexing Logic & Clock Sources



Adding multiplexing logic to the clock signal can create the problems addressed in the previous sections, but requirements for multiplexed clocks vary widely depending on the application. Clock multiplexing is acceptable when the clock signal uses global clock routing resources, if the following criteria are met:

- The clock multiplexing logic does not change after initial configuration
- The design uses multiplexing logic to select a clock for testing purposes
- Registers are always reset when the clock switches
- A temporarily incorrect response following clock switching has no negative consequences

If the design switches clocks in real time with no reset signal, and your design cannot tolerate a temporarily incorrect response, then you must use a synchronous design so that there are no timing violations on the registers, no glitches on clock signals, and no race conditions or other logical problems. By default, the Quartus II software optimizes and analyses all possible paths through the multiplexer and between both internal clocks that may come from the multiplexer. This may lead to more restrictive analysis than required if the multiplexer is always selecting one particular clock. If you do not need the more complete analysis, you can assign the output of the multiplexer as a base clock in the Quartus II software, so that all register-register paths are analyzed using that clock.

Altera recommends using dedicated hardware to perform clock multiplexing when it is available, instead of using multiplexing logic. For example, you can use the Clock Switchover feature of the PLL in the Stratix<sup>®</sup> series of devices, or the Clock Control Block in Stratix II and Cyclone™ II devices. These dedicated hardware blocks ensure that you use global low-skew routing lines and avoid any possible hold time problems on the device due to logic delay on the clock line.



Refer to the appropriate device data sheet or handbook for device-specific information about clocking structures.

## Gated Clocks

Gated clocks turn a clock signal on and off using an enable signal that controls some sort of gating circuitry, as shown in Figure 5–6. When a clock is turned off, the corresponding clock domain is shut down and becomes functionally inactive.

Figure 5-6. Gated Clock



You can use gated clocks to reduce power consumption in some device architectures. When a clock is gated, both the clock network and the registers driven by it stop toggling, thereby eliminating their contributions to power consumption. However, gated clocks are not part of a synchronous scheme and therefore can significantly increase the effort required for design implementation and verification. Gated clocks contribute to clock skew and make device migration difficult. These clocks are also sensitive to glitches, which can cause design failure.

Altera recommends using dedicated hardware to perform clock gating rather than using multiplexing logic, if it is available in your target device. For example, you can use the clock control block in Stratix II and Cyclone II devices to shut down an entire clock network. Dedicated hardware blocks ensure that you use global routing with low skew and avoid any possible hold time problems on the device due to logic delay on the clock line.



Refer to the appropriate device data sheet or handbook for device-specific information about clocking structures.

From a functional point of view, you can shut down a clock domain in a purely synchronous manner using a synchronous clock enable signal. However, when using a synchronous clock enable scheme, the clock network continues toggling. This practice does not reduce power consumption as much as gating the clock at the source does. In most cases, you should use a synchronous scheme such as those described in the "Synchronous Clock Enables" section. For improved power reduction when gating clocks with logic, refer to "Recommended Clock-Gating Method" on page 5–13.

## Synchronous Clock Enables

To turn off a clock domain in a synchronous manner, use a synchronous clock enable signal. FPGAs efficiently support clock enable signals because there is a dedicated clock enable signal available on all device registers. This scheme does not reduce power consumption as much as gating the clock at the source because the clock network keeps toggling, but it will perform the same function as a gated clock by disabling a set of registers. Insert a multiplexer in front of the data input of every register to either load new data or copy the output of the register (Figure 5–7).

Figure 5-7. Synchronous Clock Enable



## Recommended Clock-Gating Method

Only use gated clocks when your target application requires power reduction and when gated clocks are able to provide the required reduction in your device architecture. If you must use clocks gated by logic, implement these clocks using the robust clock-gating technique shown in Figure 5–8 and ensure that the gated clock signal uses dedicated global clock routing.

You can gate a clock signal at the source of the clock network, at each register, or somewhere in between. Because the clock network contributes to switching power consumption, gate the clock at the source whenever possible, so you can shut down the entire clock network instead of gating it further along the clock network at the registers.

Figure 5-8. Recommended Clock Gating Technique



In the technique shown in Figure 5–8, a register generates the enable signal to ensure that the signal is free of glitches and spikes. The register that generates the enable signal is triggered on the inactive edge of the clock to be gated (use the falling edge when gating a clock that is active on the rising edge, as shown in Figure 5–8). Using this technique, only one input of the gate that turns the clock on and off changes at a time that prevents any glitches or spikes on the output. Use an AND gate to gate a clock that is active on the rising edge. For a clock that is active on the falling edge, use an OR gate to gate the clock and register the enable command with a positive edge-triggered register.

When using this technique, pay attention to the duty cycle of the clock and the delay through the logic that generates the enable signal, because the enable signal must be generated in half the clock cycle. This situation might cause problems if the logic that generates the enable command is particularly complex, or if the duty cycle of the clock is severely unbalanced. However, careful management of the duty cycle and logic delay may be an acceptable solution when compared with problems created by other methods of gating clocks.

Ensure that you apply a clock setting to the gated clock in the Quartus II software. As shown in Figure 5–8, apply a clock setting to the output of the AND gate. Otherwise, the Timing Analyzer may analyze the circuit using the clock path through the register as the longest clock path and the path that skips the register as the shortest clock path, resulting in artificial clock skew.

## Hierarchical Design Partitioning

A hierarchical design consists of multiple design blocks linked together in a hierarchy. When a design is partitioned hierarchically, you can compile, optimize and simulate the individual design blocks separately. You can use the incremental compilation or LogicLock™ design flows to follow a block-based design methodology where each block is placed and routed independently, then all blocks in the hierarchy are combined at the top level. Some synthesis tools have features to help you create separate netlist files or maintain separate parts of a netlist file for different parts of your design, to support block-based design techniques or incremental compilation.



For 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*. For more information about the LogicLock design methodology, refer to the *LogicLock Design Methodology* chapter in volume 2 of the *Quartus II Handbook*. For more information about incremental synthesis flows in your synthesis tool, refer to the appropriate chapter in the *Synthesis* section in volume 1 of the *Quartus II handbook*.

When using a hierarchical or incremental design methodology, consider how the design is partitioned to achieve good results.

Altera recommends the following practices for partitioning designs:

- Partition the design at functional boundaries.
- Minimize the I/O connections between different partitions.
- Register all inputs and outputs of each block. This makes logic synchronous and avoids glitches and avoids any delay penalty on signals that cross between partitions. Registering I/Os typically eliminates the need to specify timing requirements for signals that connect between different blocks.
- Do not use "glue logic" or connection logic between hierarchical blocks. When you preserve hierarchy boundaries, glue logic is not merged with hierarchical blocks. Your synthesis software may optimize glue logic separately, which can degrade synthesis results and is not efficient when used with the LogicLock design methodology.
- Remember that logic is not synthesized or optimized across partition boundaries, which means any constant values (signals set to GND, for example) will not be propagated across partitions.

- Do not use tri-state signals or bidirectional ports on hierarchical boundaries. If you use boundary tri-states in a lower-level block, synthesis pushes the tri-states through the hierarchy to the top-level to take advantage of the tri-state drivers on the output pins of Altera device. Because this requires optimizing through hierarchies, lower-level boundary tri-state signals have restrictions with block-level design methodologies.
- Limit clocks to one per block. Partitioning the design into clock domains makes synthesis and timing analysis easier.
- Place state machines in separate blocks to speed optimization and provide greater encoding control.
- Separate timing-critical functions from non-timing-critical functions.
- Limit the critical timing path to one hierarchical block. You can group the logic from several design blocks to ensure the critical path resides in one block.



For more guidelines for creating design partitions for Quartus II incremental compilation, refer to the *Quartus II Incremental Compilation* for Hierarchical & Team-Based Design chapter in volume 1 of the *Quartus II Handbook*.

# Targeting Clock & Register-Control Architectural Features

In addition to following general design guidelines, it is important to code your design with the device architecture in mind. FPGAs provide device-wide clocks and register control signals that can improve performance.

## **Clock Network Resources**

Altera FPGAs provide device-wide global clock routing resources and dedicated inputs. You should use the FPGA's low-skew, high-fan-out, dedicated routing where available. By assigning a clock input to one of these dedicated clock pins or using a Quartus II logic option to assign global routing, you can take advantage of the dedicated routing available for clock signals.

In ASIC design, balancing the clock delay as it is distributed across the device can be important. Because Altera FPGAs provides device-wide global clock routing resources and dedicated inputs, there is no need to manually balance delays on the clock network.

Altera recommends limiting the number of clocks in your design to the number of dedicated global clock resources available in your FPGA. Clocks feeding multiple locations that do not use global routing may exhibit clock skew across the device that could lead to timing problems. In addition, when you use combinational logic to generate an internal clock, it adds delays on the clock line. In some cases, delay on a clock line

can result in a clock skew greater than the data path length between two registers. If the clock skew is greater than the data delay, the timing parameters of the register (such as hold time requirements) are violated and the design will not function correctly.

Today's FPGAs offer increasing numbers of global clocks to address large designs with many clock domains. Many large FPGA devices provide dedicated global clock networks, regional clock networks, and dedicated fast regional clock networks. These clocks are typically organized into a hierarchical clock structure that allows many clocks in each device region with low skew and delay. There are typically a number of dedicated clock pins to drive either the global or regional clock networks and both PLL outputs and internal clocks can drive various clock networks.

To reduce the clock skew within a given clock domain and ensure that hold times are met within that clock domain, assign each clock signal to one of the global high-fan-out and low-skew clock networks in the FPGA device. Quartus II automatically uses global routing for high-fanout control signals, PLL outputs, and signals feeding the global clock pins on the device. You can make explicit **Global Signal** logic option settings. To make explicit **Global Signal** logic option settings, on the Assignment menu, click **Assignment Editor**. Use this option when it is necessary to force the software to use the global routing for particular signals.

To take full advantage of these routing resources, the sources of clock signals in a design (input clock pins or internally-generated clocks) should drive only the clock input ports of registers. In older Altera device families (such as FLEX® 10K and ACEX® 1K), if a clock signal feeds the data ports of a register, the signal may not be able to use the dedicated routing, which can lead to decreased performance and clock skew problems. In general, allowing clock signals to drive the data ports of registers is not considered synchronous design, and it can complicate timing analysis. It is not a recommended practice.

#### **Reset Resources**

ASIC designs may use local resets to avoid long routing delays on the signal. You should take advantage of the device-wide asynchronous reset pin available on most FPGAs to eliminate these problems. This reset signal provides low-skew routing across the device.

## **Register Control Signals**

Avoid using an asynchronous load signal if the design's target device architecture does not include registers with dedicated circuitry for asynchronous loads. Also, avoid using both asynchronous clear and preset if the architecture provides only one of those control signals.

APEX<sup>TM</sup> devices, for example, directly support an asynchronous clear function, but not a preset or load function. When the target device does not directly support the signals, the place-and-route software must use combinational logic to implement the same functionality. In addition, if you use signals in a priority other than the inherent priority in the device architecture, combinational logic may be required to implement the desired control signals. The combinational logic is less efficient and can cause glitches and other problems; it is best to avoid these implementations.



For Verilog HDL and VHDL examples of registers with various control signals, and information on the inherent priority order of register control signals in Altera device architecture, refer to the *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook*.

## Conclusion

Following the design practices outlined in this chapter can help you meet your design goals consistently. Asynchronous design techniques may result in incomplete timing analysis, may clause glitches on data signals, and may rely on propagation delays in a device leading to race conditions and unpredictable results. Taking advantage of the architectural features in your FPGA device can also improve your quality of results.



# 6. Recommended HDL Coding Styles

QII51007-6.0.0

## Introduction

HDL coding style can have a significant effect on the quality of results that you achieve for programmable logic designs. Synthesis tools optimize HDL code for both logic utilization and performance. However, sometimes the best optimizations require human understanding of the design, and synthesis tools have no information about the purpose or intent of the design. You are often in the best position to improve your quality of results.

This chapter addresses HDL coding style recommendations to ensure optimal synthesis results when targeting Altera® devices, including the following sections:

- Using Altera Megafunctions
- Instantiating Altera Megafunctions in HDL Code
- Inferring Altera Megafunctions from HDL Code
- Device-Specific Coding Guidelines
- Coding Guidelines for Other Logic Structures



For additional guidelines on structuring your design, refer to the *Design Recommendations for Altera Devices* chapter in volume 1 of the *Quartus II Handbook*.

For style recommendations, options, or HDL attributes specific to your synthesis tool (including Quartus<sup>®</sup> II integrated synthesis and other third-party EDA tools), refer to the tool vendor's documentation or the appropriate chapter in the *Synthesis* section in volume 1 of the *Quartus II Handbook*.

## Using Altera Megafunctions

Altera provides parameterizable megafunctions that are optimized for Altera device architectures. Using megafunctions instead of coding your own logic saves valuable design time. Additionally, the Altera-provided megafunctions may offer more efficient logic synthesis and device implementation. You can scale the megafunction's size and set various options by setting parameters. Megafunctions include the library of parameterized modules (LPM) and Altera device-specific megafunctions.



You must use megafunctions to access some Altera device-specific features, such as memory, DSP blocks, LVDS drivers, phase-locked loops (PLLs), transceivers, and double data rate input/output (DDIO) circuitry.

To use megafunctions in your HDL code, you can instantiate them as described in "Instantiating Altera Megafunctions in HDL Code" on page 6–3. Sometimes it is preferable to make your code independent of device family or vendor, and you do not want to instantiate megafunctions directly. In cases where you do not want to instantiate a megafunction, follow the guidelines and coding examples in "Inferring Altera Megafunctions from HDL Code" on page 6–6 to ensure your generic HDL code infers the appropriate Altera megafunction.

For some designs, generic HDL code can provide better results than instantiating a megafunction. Refer to the following general guidelines and examples that describe when to use standard HDL code and when to use megafunctions:

- For simple addition or subtraction functions, use the + or symbol instead of an LPM function. Instantiating an LPM function for simple arithmetic operations can result in a less efficient result because the function is hard coded and the synthesis algorithms cannot take advantage of basic logic optimizations. For more complicated arithmetic logic such as synchronous loadable counters, LPM functions give you access to detailed architecture-specific functionality that is difficult to infer from HDL code.
- For simple multiplexers and decoders, use array notation (such as out = data[sel]) instead of an LPM function. Array notation works very well and has simple syntax. You can use the LPM\_MUX function to take advantage of architectural features such as cascade chains in APEX<sup>™</sup> series devices, but use the LPM function only if you want to force a specific implementation.
- Avoid division operations where possible. Division is an inherently slow operation. Many designers use multiplication creatively to produce division results. If you must divide, the LPM\_DIVIDE function provides the best possible results.

## Instantiating Altera Megafunctions in HDL Code

The following sections describe how to use megafunctions by instantiating them in your HDL code with the following methods:

- Instantiating Megafunctions Using the MegaWizard® Plug-In Manager—You can use the MegaWizard Plug-In Manager to parameterize the function and create a wrapper file.
- Creating a Clear Box Netlist File for Third-Party Synthesis Tools— You can optionally create a clear box body instead of a wrapper file.
- Instantiating Megafunctions Using the Port & Parameter Definition—You can instantiate the function directly in your HDL code.

# Instantiating Megafunctions Using the MegaWizard Plug-In Manager

Use the MegaWizard Plug-In Manager as described in this section to create megafunctions in the Quartus II GUI that you can instantiate in your HDL code. The MegaWizard Plug-In Manager provides a graphical user interface to customize and parameterize megafunctions, and ensures that you set all megafunction parameters properly. When you finish setting parameters, you can specify which files you want to be generated. Depending on which language you choose, the MegaWizard Plug-In Manager instantiates the megafunction with the correct parameters and generates one of the following sets of files:

- AHDL Text Design File (.tdf) wrapper file and a sample instantiation template Text Design File (\_inst.tdf).
- Verilog HDL (.v) wrapper file a sample instantiation template Verilog HDL file (\_inst.v), and a black-box Verilog HDL module declaration.
- VHDL (.vhd) wrapper file and a sample instantiation template VHDL file (\_inst.vhd).

You can instantiate the megafunction wrapper file in your design using the corresponding sample instantiation file. In addition, the MegaWizard Plug-In Manager also creates the following default files by default:

- Component Declaration File (.cmp) that can be used in VHDL Design Files
- ADHL Include File (.inc) that can be used in Text Design Files (.tdf) and as a reference for Verilog HDL design files

Refer to Table 6–1 for a list and description of files generated by the MegaWizard Plug-In Manager.

| Table 6–1. MegaWizard Plug-In Manager Generated Files |                                                                                                                                                                                                      |
|-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| File                                                  | Description                                                                                                                                                                                          |
| <output file="">.bsf</output>                         | Block Symbol File—Used in the Quartus II Block Design Files (.bdf).                                                                                                                                  |
| <output file="">.cmp</output>                         | Component Declaration File—Used in VHDL designs.                                                                                                                                                     |
| <output file="">.inc</output>                         | ADHL Include File—Used in AHDL designs.                                                                                                                                                              |
| <output file="">.tdf (1)</output>                     | AHDL Wrapper File—Megafunction wrapper file for instantiation in an AHDL design.                                                                                                                     |
| <output file="">.vhd (2) (4)</output>                 | VHDL Wrapper File—Megafunction wrapper file, or clear box netlist file, for instantiation in a VHDL design.                                                                                          |
| <output file="">.v (3) (4)</output>                   | Verilog HDL Wrapper File—Megafunction wrapper file, or clear box netlist file, for instantiation in a Verilog HDL design.                                                                            |
| <output file="">_bb.v (3)</output>                    | Black box Verilog HDL Module Declaration—Hollow-body module declaration that can be used in Verilog HDL designs to specify port directions when creating black boxes in third-party synthesis tools. |
| <output file="">_inst.tdf (1)</output>                | Text Design File Instantiation Template—Sample AHDL instantiation of the subdesign in the megafunction wrapper file.                                                                                 |
| <output file="">_inst.vhd (2)</output>                | VHDL Instantiation Template—Sample VHDL instantiation of the entity in the megafunction wrapper file.                                                                                                |
| <output file="">_inst.v (3)</output>                  | Verilog HDL Instantiation Template—Sample Verilog HDL instantiation of the module in the megafunction wrapper file.                                                                                  |

#### Notes to Table 6-1:

- (1) The MegaWizard Plug-In Manager generates this file only if you select AHDL output files.
- (2) The MegaWizard Plug-In Manager generates this file only if you select VHDL output files.
- (3) The MegaWizard Plug-In Manager generates this file only if you select Verilog HDL output files.
- (4) A megafunction wrapper file is created by default for most megafunctions. To take advantage of the clear box feature, on the Tools menu, click MegaWizard Plug-In Manager and turn on Generate clear box netlist file instead of a default wrapper file (for use with supported EDA synthesis tools only). For additional information about how to use the MegaWizard Plug-In Manager, refer to the Quartus II Help.

## Creating a Clear Box Netlist File for Third-Party Synthesis Tools

When you use certain megafunctions with third-party synthesis tools, you can optionally create a clear box body instead of a wrapper file. The clear box body is a fully synthesized megafunction that you can use with certain third-party EDA synthesis tools. The netlist file that contains the megafunction clear box body provides your third-party synthesis tool with information about the architectural details used in the Quartus II software. This information enables certain synthesis tools to better report timing and resource utilization estimates. In addition, synthesis tools can use the timing information to focus timing-driven optimizations and improve the quality of results.



For information about clear box support in your synthesis tool, refer to the tool vendor's documentation or the appropriate chapter in the *Synthesis* section in volume 1 of the *Quartus II Handbook*.

To generate a clear box netlist, turn on **Generate clear box netlist file instead of a default wrapper file (for use with supported EDA synthesis tools only)** on the megafunction selection page 2a of the MegaWizard Plug-In Manager.



Note that not all megafunctions support clear box netlists. If you cannot create a clear box netlist for a particular megafunction, the option to generate the netlist is not shown on page 2a of the MegaWizard Plug-In Manager. Some megafunctions always use a clear box netlist file, in which case the option on page 2a cannot be turned off.

# Instantiating Megafunctions Using the Port & Parameter Definition

You can instantiate the megafunction directly in your AHDL, Verilog HDL, or VHDL code by calling the megafunction and setting its parameters as you would any other subdesign, module, or component.



Refer to the specific megafunction in the Quartus II Help for a list of the megafunction ports and parameters. Quartus II Help also provides a sample VHDL component declaration and AHDL function prototype for each megafunction.



Altera strongly recommends that you use the MegaWizard Plug-In Manager for complex megafunctions such as PLLs, transceivers, and LVDS drivers. For details on using the MegaWizard Plug-In Manager, refer to "Instantiating Megafunctions Using the MegaWizard Plug-In Manager" on page 6–3.

## Inferring Altera Megafunctions from HDL Code

Synthesis tools, including Quartus II integrated synthesis, recognize certain types of HDL code and automatically infer the appropriate megafunction. The synthesis tool uses the Altera megafunction code when compiling your design—even when you do not specifically instantiate the megafunction. Synthesis tools infer megafunctions to take advantage of logic that is optimized for Altera devices. The area and performance of such logic may be better than the results obtained by inferring generic logic from the same HDL code.

The following sections describe the types of logic that standard synthesis tools recognize and map to megafunctions. Synthesis software infers only the specific functions listed here. The software cannot infer other functions, such as PLLs, LVDS drivers, transceivers, or DDIO circuitry from HDL code because these functions cannot be fully or efficiently described in HDL code. In some cases, you can use synthesis tool options to turn off inference of certain megafunctions. The following sections describe how to infer the following megafunctions from generic HDL code:

- 1pm mult—Inferring Multipliers from HDL Code
- altmult\_accum & altmult\_add—Inferring Multiply-Accumulators & Multiply-Adders from HDL Code
- altsyncram & lpm\_ram\_dp—Inferring RAM Functions from HDL Code
- 1pm rom—Inferring ROM from HDL Code
- altshift taps—Inferring Shift Registers from HDL Code



For synthesis tool features and options, refer to your synthesis tool documentation or the appropriate chapter in the *Synthesis* section in volume 1 of the *Quartus II Handbook*.

## Ipm\_mult—Inferring Multipliers from HDL Code

To infer multiplier functions, synthesis tools look for multipliers and convert them to <code>lpm\_mult</code> or <code>altmult\_add</code> megafunctions, or may map them directly to multiplier device atoms. For devices with DSP blocks, the software can implement the function in a DSP block instead of logic, depending on device utilization. The Quartus II Fitter can also place input and output registers in DSP blocks (that is, perform register packing) to improve performance and area utilization.



For additional information about the DSP block and which functions it can implement, refer to the appropriate Altera device family handbook and The DSP Solution Center of the Altera web site at www.altera.com.

The following four code samples show Verilog HDL and VHDL examples for unsigned and signed multipliers that synthesis tools can infer as an lpm\_mult or altmult\_add megafunction. Each example fits into one DSP block 9-bit element. In addition, when register packing occurs, no extra logic cells for registers are required.



The signed declaration in Verilog HDL is a feature of the Verilog 2001 Standard.

## Example 6-1. Verilog HDL Unsigned Multiplier

```
module unsigned_mult (out, a, b);
  output [15:0] out;
  input [7:0] a;
  input [7:0] b;
  assign out = a * b;
endmodule
```

## Example 6-2. Verilog HDL Signed Multiplier with Input & Output Registers (Pipelining = 2)

```
module signed mult (out, clk, a, b);
  output [15:0] out;
   input clk;
   input signed [7:0] a;
  input signed [7:0] b;
  req signed [7:0] a req;
  reg signed [7:0] b reg;
  reg signed [15:0] out;
  wire signed [15:0] mult out;
  assign mult out = a reg * b reg;
  always @ (posedge clk)
  begin
     a reg <= a;
     b req <= b;
     out <= mult out;
   end
endmodule
```

## Example 6-3. VHDL Unsigned Multiplier with Input & Output Registers (Pipelining = 2)

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
USE ieee.numeric_std.all;
ENTITY unsigned mult IS
   PORT (
      a: IN UNSIGNED (7 DOWNTO 0);
      b: IN UNSIGNED (7 DOWNTO 0);
     clk: IN STD LOGIC;
     aclr: IN STD LOGIC;
     result: OUT UNSIGNED (15 DOWNTO 0)
  );
END unsigned mult;
ARCHITECTURE rtl OF unsigned mult IS
   SIGNAL a_reg, b_reg: UNSIGNED (7 DOWNTO 0);
BEGIN
   PROCESS (clk, aclr)
   BEGIN
      IF (aclr ='1') THEN
         a reg <= (OTHERS => '0');
         b_reg <= (OTHERS => '0');
         result <= (OTHERS => '0');
      ELSIF (clk'event AND clk = '1') THEN
         a reg <= a;
         b reg <= b;
        result <= a_reg * b_reg;
      END IF;
   END PROCESS;
END rtl;
```

## Example 6-4. VHDL Signed Multiplier

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
USE ieee.numeric std.all;
ENTITY signed_mult IS
   PORT (
      a: IN SIGNED (7 DOWNTO 0);
      b: IN SIGNED (7 DOWNTO 0);
     result: OUT SIGNED (15 DOWNTO 0)
  );
END signed_mult;
ARCHITECTURE rtl OF signed mult IS
   SIGNAL a int, b int: SIGNED (7 downto 0);
   SIGNAL pdt int: SIGNED (15 downto 0);
BEGIN
  a_int <= (a);
  b_int <= (b);
  pdt int <= a int * b int;
  result <= pdt int;
END rtl;
```

# altmult\_accum & altmult\_add—Inferring Multiply-Accumulators & Multiply-Adders from HDL Code

Synthesis tools detect multiply-accumulators or multiply-adders and convert them to altmult\_accum or altmult\_add megafunctions, respectively. The Quartus II software then places these functions in DSP blocks during placement and routing.



Synthesis tools infer multiply-accumulator and multiply-adder functions only if the Altera device family has dedicated DSP blocks.

A multiply-accumulator consists of a multiplier feeding an addition operator. The addition operator feeds a set of registers that then feeds the second input to the addition operator. A multiply-adder consists of two to four multipliers feeding one or two levels of addition, subtraction, or addition/subtraction operators. Addition is always the second-level operator, if it is used. In addition to the multiply-accumulator and multiply-adder, the Quartus II Fitter also places input and output registers into the DSP blocks to pack registers and improve performance and area utilization.

The Verilog HDL and VHDL code samples shown in Examples 6–5 through 6–8 infer specific multiply-accumulators and multiply-adders.

## Example 6–5. Verilog HDL Unsigned Multiply-Accumulator with Input, Output & Pipeline Registers (Latency = 3)

```
module unsig altmult accum (dataout, dataa, datab, clk, aclr, clken);
   input [7:0] dataa;
   input [7:0] datab;
   input clk;
   input aclr;
   input clken;
   output [31:0] dataout;
   reg [31:0] dataout;
   reg [7:0] dataa_reg;
   reg [7:0] datab reg;
   reg [15:0] multa reg;
   wire [15:0] multa;
   wire [31:0] adder out;
   assign multa = dataa_reg * datab_reg;
   assign adder_out = multa_reg + dataout;
   always @ (posedge clk or posedge aclr)
   begin
      if (aclr)
      begin
         dataa_reg <= 0;
         datab reg <= 0;
         multa reg <= 0;
         dataout <= 0;</pre>
      end
      else if (clken)
      begin
         dataa_reg <= dataa;</pre>
         datab reg <= datab;
         multa_reg <= multa;</pre>
         dataout <= adder out;
      end
   end
endmodule
```

## Example 6-6. Verilog HDL Signed Multiply-Adder (Latency = 0)

```
module sig_altmult_add (dataa, datab, datac, datad, result);
  input signed [15:0] dataa;
  input signed [15:0] datab;
  input signed [15:0] datac;
  input signed [15:0] datad;
  output [32:0] result;

  wire signed [31:0] mult0_result;
  wire signed [31:0] mult1_result;

  assign mult0_result = dataa * datab;
  assign mult1_result = datac * datad;
  assign result = (mult0_result + mult1_result);
endmodule
```

## Example 6-7. VHDL Unsigned Multiply-Adder with Input, Output & Pipeline Registers (Latency = 3)

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
USE ieee.numeric std.all;
ENTITY unsignedmult_add IS
   PORT (
     a: IN UNSIGNED (7 DOWNTO 0);
     b: IN UNSIGNED (7 DOWNTO 0);
     c: IN UNSIGNED (7 DOWNTO 0);
     d: IN UNSIGNED (7 DOWNTO 0);
     clk: IN STD LOGIC;
     aclr: IN STD LOGIC;
     result: OUT UNSIGNED (15 DOWNTO 0)
   );
END unsignedmult add;
ARCHITECTURE rtl OF unsignedmult add IS
   SIGNAL a_int, b_int, c_int, d_int: UNSIGNED (7 DOWNTO 0);
   SIGNAL pdt int, pdt2 int: UNSIGNED (15 DOWNTO 0);
   SIGNAL result int: UNSIGNED (15 DOWNTO 0);
BEGIN
   PROCESS (clk, aclr)
   BEGIN
      IF (aclr = '1') THEN
         a int <= (OTHERS => '0');
         b int <= (OTHERS => '0');
         c int <= (OTHERS => '0');
         d int <= (OTHERS => '0');
         pdt int <= (OTHERS => '0');
         pdt2 int <= (OTHERS => '0');
         result int <= (OTHERS => '0');
      ELSIF (clk'event AND clk = '1') THEN
         a int <= a;
         b int <= b;
         c_int <= c;
         d int <= d;
         pdt int <= a int * b int;
         pdt2 int <= c int * d int;
        result_int <= pdt_int + pdt2_int;
      END IF;
      END PROCESS;
   result <= result int;
END rtl;
```

## Example 6-8. VHDL Signed Multiply-Accumulator with Input, Output & Pipeline Registers (Latency = 3)

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
USE ieee.numeric std.all;
ENTITY sig altmult accum IS
  PORT (
     a: IN SIGNED (7 DOWNTO 0);
     b: IN SIGNED (7 DOWNTO 0);
     clk: IN STD LOGIC;
     accum_out: OUT SIGNED (15 DOWNTO 0)
  ) ;
END sig_altmult_accum;
ARCHITECTURE rtl OF sig altmult accum IS
  SIGNAL a reg, b reg: SIGNED (7 DOWNTO 0);
  SIGNAL pdt_reg: SIGNED (15 DOWNTO 0);
  SIGNAL adder out: SIGNED (15 DOWNTO 0);
BEGIN
   PROCESS (clk)
  BEGIN
      IF (clk'event and clk = '1') THEN
         a reg <= (a);
         b reg <= (b);
           pdt_reg <= a_reg * b_reg;</pre>
        adder out <= adder out + pdt reg;
     END IF;
    END process;
  accum out <= (adder out);</pre>
END rtl;
```

# altsyncram & Ipm\_ram\_dp—Inferring RAM Functions from HDL Code

To infer RAM functions, synthesis tools detect sets of registers and logic that can be replaced with the altsyncram or lpm\_ram\_dp megafunctions for device families that have dedicated RAM blocks.

Synthesis tools recognize single-port and simple dual-port (one read port and one write port) RAM blocks. Tools usually do not infer small RAM blocks because small RAM blocks typically can be implemented more efficiently by using the registers in regular logic.



If you are using Quartus II integrated synthesis, you can direct the software to infer RAM blocks for all sizes. On the Assignments menu, click **Settings**. In the **Category** list, click **Analysis & Synthesis Settings**. Click **More Settings**. Under **Existing Options Settings**, select the option **Allow Any RAM Size for Recognition**. Click the **Setting** arrow and select **ON**.

If your design contains a RAM block that your synthesis tool does not recognize and infer, the design might require a large amount of system memory that potentially can cause compilation problems.

Some synthesis tools provide options to control the implementation of inferred RAM blocks for Altera devices with TriMatrix<sup>TM</sup> memory blocks. For example, Quartus II integrated synthesis provides the ramstyle synthesis attribute to specify the type of memory block using the value "M512," "M4K," or "M-RAM," or to specify the use of regular logic instead of a dedicated memory block using the value "logic."



For information on synthesis attributes, refer to the appropriate chapter in the *Synthesis* section in volume 1 of the *Quartus II Handbook*.

When you are using a formal verification flow, Altera recommends that you create RAM blocks in separate entities or modules that only contain the RAM logic. In certain formal verification flows, for example, when using Quartus II integrated synthesis, the entity or module containing the inferred RAM is put into a black box automatically because formal verification tools do not support RAM blocks. The Quartus II software issues a warning message when this occurs. If the entity or module contains any additional logic outside the RAM block, this logic also must be treated as a black box for formal verification and therefore cannot be verified.

## Dual-Clock Synchronous RAM

Altera's TriMatrix memory blocks are synchronous, so RAM designs that target architectures that contain these dedicated memory blocks must be synchronous to be mapped directly into the device architecture. Synchronous memories are supported in all Altera device families.

When simultaneous reading and writing to the same RAM address occurs, the TriMatrix memory blocks in Altera devices return undefined data values. This usually differs from the functionality of the original HDL design. If your design requires a given output when reading and writing to the same RAM address, direct your synthesis tool not to infer RAM blocks for dual-clock memories by disabling RAM inference for these memories.



For specific options to disable RAM inference in your synthesis tool, refer to your synthesis tool documentation or the appropriate chapter in the *Synthesis* section in volume 1 of the *Quartus II Handbook*.

The code samples shown in Examples 6–9 and 6–10 show Verilog HDL and VHDL code that infers dual-clock synchronous RAM.

## Example 6-9. Verilog HDL Dual-Clock Synchronous RAM

```
module ram_dual (q, addr_in, addr_out, d, we, clk1, clk2);
   output [7:0] q;
   input [7:0] d;
   input [6:0] addr_in;
   input [6:0] addr_out;
   input we, clk1, clk2;
   reg [6:0] addr out reg;
   reg [7:0] q;
   reg [7:0] mem [127:0];
  always @ (posedge clk1)
  begin
      if (we)
         mem[addr_in] <= d;</pre>
   end
   always @ (posedge clk2) begin
      q <= mem[addr out reg];</pre>
      addr out reg <= addr out;
   end
endmodule
```

## Example 6-10. VHDL Dual-Clock Synchronous RAM

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
ENTITY ram dual IS
    PORT (
        clock1, clock2: IN STD LOGIC;
        data: IN STD LOGIC VECTOR (3 DOWNTO 0);
        write address: IN INTEGER RANGE 0 to 31;
        read address: IN INTEGER RANGE 0 to 31;
        we: IN STD LOGIC;
        q: OUT STD LOGIC VECTOR (3 DOWNTO 0)
    );
END ram dual;
ARCHITECTURE rtl OF ram dual IS
   TYPE MEM IS ARRAY(0 TO 31) OF STD LOGIC VECTOR(3 DOWNTO 0);
    SIGNAL ram block: MEM;
    SIGNAL read address reg : INTEGER RANGE 0 to 31;
BEGIN
    PROCESS (clock1)
    BEGIN
        IF (clock1'event AND clock1 = '1') THEN
            IF (we = '1') THEN
                ram block(write address) <= data;</pre>
            END IF;
        END IF;
    END PROCESS;
    PROCESS (clock2)
    BEGIN
        IF (clock2'event AND clock2 = '1') THEN
            q <= ram block(read address reg);</pre>
            read address reg <= read address;
        END IF;
    END PROCESS;
END rtl;
```

## Single-Clock Synchronous RAM without Read-Through-Write Behavior

The code examples in this section show Verilog HDL and VHDL code that infers single-clock synchronous RAM. Altera's TriMatrix memory blocks are synchronous, so RAM designs targeting to architectures that contain these dedicated memory blocks must be synchronous to be mapped directly into the device architecture.

These examples also avoid read-through-write behavior, which is not directly supported in TriMatrix memory blocks. Altera recommends that you use this coding style as long as your design does not require RAM with read-through-write behavior, meaning your design does not require that a simultaneous read and write to the same RAM location read the new value that is currently being written to that RAM location.



In TriMatrix memory blocks, if you attempt to read and write from the same address in the same clock cycle, the read returns either the old data at the address or unknown data, depending on the memory mode and block type.

If you require RAM with read-through-write behavior, refer to the section "Single-Clock Synchronous RAM with Read-Through-Write Behavior" on page 6–17.



For additional information about the dedicated memory blocks in your specific device, refer to the appropriate Altera device family data sheet on the Altera web site at www.altera.com.

The RAM code samples shown in Examples 6–11 and 6–12 map directly into Altera TriMatrix memory.

## Example 6-11. Verilog HDL Single-Clock Synchronous RAM Without Read-Through-Write Behavior

```
module ram_infer (q, a, d, we, clk);
  output reg [7:0] q;
  input [7:0] d;
  input [6:0] a;
  input we, clk;

  reg [7:0] mem [127:0];

  always @ (posedge clk) begin
    if (we)
        mem[a] <= d;
    q <= mem[a]; // q doesn't get d in this clock cycle end
endmodule</pre>
```

## Example 6-12. VHDL Single-Clock Synchronous RAM Without Read-Through-Write Behavior

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
ENTITY ram IS
   PORT (
     clock: IN STD LOGIC;
      data: IN STD LOGIC VECTOR (2 DOWNTO 0);
      write address: IN INTEGER RANGE 0 to 31;
      read address: IN INTEGER RANGE 0 to 31;
     we: IN STD LOGIC;
     q: OUT STD LOGIC VECTOR (2 DOWNTO 0)
  );
END ram;
ARCHITECTURE rtl OF ram IS
  TYPE MEM IS ARRAY(0 TO 31) OF STD LOGIC VECTOR(2 DOWNTO 0);
  SIGNAL ram block: MEM;
BEGIN
   PROCESS (clock)
   BEGIN
      IF (clock'event AND clock = '1') THEN
         IF (we = '1') THEN
            ram_block(write_address) <= data;</pre>
         END IF;
         q <= ram block(read address);</pre>
            -- VHDL semantics imply that q doesn't get data
            -- in this clock cycle
      END IF;
  END PROCESS;
END rtl;
```

## Single-Clock Synchronous RAM with Read-Through-Write Behavior

TriMatrix memory blocks do not support mixed-port read-through-write behavior. This means if you attempt to read and write from the same address in the same clock cycle, the read returns either the old data at the address or unknown data, depending on the memory mode and block type. However, you can describe a RAM block in HDL code in which a simultaneous read and write to the same location reads the new value that is currently being written to that RAM location. The following examples show code that infers this type of RAM logic. To implement this behavior in the target device, synthesis software adds bypass logic around the RAM block. This bypass logic increases the area utilization of the design and decreases the performance if the RAM block is part of the design's critical path.

The RAM examples shown in Examples 6–13 and 6–14 require bypass logic around the RAM block.

## Example 6-13. Verilog HDL Single-Clock Synchronous RAM with Read-Through-Write Behavior

```
module ram_infer (q, a, d, we, clk);
  output [7:0] q;
  input [7:0] d;
  input [6:0] a;
  input we, clk;
reg [6:0] read_add;
  reg [7:0] mem [127:0];
always @ (posedge clk) begin
  if (we)
        mem[a] <= d;
  read_add <= a;
  end
assign q = mem[read_add];
endmodule</pre>
```

## Example 6-14. VHDL Single-Clock Synchronous RAM with Read-Through-Write Behavior

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
ENTITY ram IS
    PORT (
        clock: IN STD LOGIC;
        data: IN STD LOGIC VECTOR (2 DOWNTO 0);
        write address: IN INTEGER RANGE 0 to 31;
        read address: IN INTEGER RANGE 0 to 31;
        we: IN STD LOGIC;
        q: OUT STD LOGIC VECTOR (2 DOWNTO 0)
    );
END ram;
ARCHITECTURE rtl OF ram IS
    TYPE MEM IS ARRAY(0 TO 31) OF STD LOGIC VECTOR(2 DOWNTO 0);
    SIGNAL ram block: MEM;
   SIGNAL read address_reg: INTEGER RANGE 0 to 31;
BEGIN
   PROCESS (clock)
    REGIN
        IF (clock'event AND clock = '1') THEN
            IF (we = '1') THEN
                ram block(write address) <= data;</pre>
            END IF:
            read address reg <= read address;
        END IF;
    END PROCESS;
    q <= ram block(read address reg);</pre>
END rtl;
```

### Synchronous RAM with Two Read Addresses

Quartus II integrated synthesis can infer RAM blocks from RAM descriptions that have two read addresses and one write address. This type of RAM blocks can be implemented by duplicating the RAM block as shown in Figure 6–1. All inputs are duplicated for both RAM blocks except for the read address, which is individual for each block.



Figure 6-1. Block Diagram Showing Synchronous RAM with Two Read Addresses

The RAM code samples with two read addresses shown in Examples 6–15 and 6–16 are inferred by duplicating the RAM block.

### Example 6-15. Verilog HDL Single-Clock Synchronous RAM with Two Read Addresses

```
module dual ram infer (q, q2, write address, read address, read address2, d, we, clk);
      output reg [7:0] q;
      output reg [7:0] q2;
      input [7:0] d;
      input [6:0] write address;
      input [6:0] read_address;
      input [6:0] read address2;
      input we, clk;
      reg [7:0] mem [127:0];
      always @ (posedge clk) begin
            if (we)
                   mem[write address] <= d;</pre>
            q <= mem[read address];</pre>
            q2 <= mem[read address2];</pre>
      end
endmodule
```

### Example 6-16. VHDL Single-Clock Synchronous RAM with Two Read Addresses

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
ENTITY dual ram infer IS
  PORT (
    clock: IN STD LOGIC;
    data: IN STD LOGIC VECTOR (2 DOWNTO 0);
    write address: IN INTEGER RANGE 0 to 31;
    read address: IN INTEGER RANGE 0 to 31;
    read address2: IN INTEGER RANGE 0 to 31;
    we: IN STD LOGIC;
    q: OUT STD LOGIC VECTOR (2 DOWNTO 0);
    q2: OUT STD LOGIC VECTOR (2 DOWNTO 0)
    );
END dual ram infer;
ARCHITECTURE rtl OF dual ram infer IS
 TYPE MEM IS ARRAY(0 TO 31) OF STD LOGIC VECTOR(2 DOWNTO 0);
 SIGNAL ram block: MEM;
BEGIN
  PROCESS (clock)
  BEGIN
    IF (clock'event AND clock = '1') THEN
      IF (we = '1') THEN
       ram block(write address) <= data;</pre>
     END IF;
      q <= ram block(read address);</pre>
      q2 <= ram block(read address2);</pre>
   END IF;
  END PROCESS;
END rtl;
```

### Single-Clock Synchronous RAM with Asynchronous Read Address

The code samples shown in Examples 6–17 and 6–18 show Verilog HDL and VHDL code for RAM with asynchronous read addresses and registered outputs.

The implementation of the RAM code in the following examples varies depending on the dedicated RAM architecture of the device family. For example, implementing asynchronous read addresses in the APEX device series is straightforward because the RAM architecture in the APEX series supports asynchronous read addresses. However, read addresses in Stratix<sup>®</sup> devices and most newer device families must be registered. Therefore, you cannot directly implement the asynchronous RAM code in the following examples. To implement the asynchronous RAM in the Stratix series devices, for example, synthesis tools may move the output registers to the inputs of the RAM block so that the logic can be implemented using an altsyncram megafunction. If the read and write clocks are not the same, moving the output registers to the inputs of the RAM block can slightly change the functionality. Under these circumstances, the synthesis software issues a warning. If you are using Quartus II integrated synthesis, Quartus II Help explains the differences. These RAM examples may not map directly to the RAM block, depending on the device architecture.

### Example 6–17. Verilog HDL Single-Clock Synchronous RAM with Asynchronous Read Address

```
module ram (clock, data, write address, read address, we, q);
    parameter ADDRESS WIDTH = 4;
    parameter DATA WIDTH
    input clock;
    input [DATA WIDTH-1:0] data;
    input [ADDRESS WIDTH-1:0] write address;
    input [ADDRESS WIDTH-1:0] read address;
    input we;
    output [DATA WIDTH-1:0] q;
    reg [DATA WIDTH-1:0] g;
    reg [DATA WIDTH-1:0] ram block [2**ADDRESS WIDTH-1:0];
    always @ (posedge clock)
    begin
            ram block[write address] <= data;</pre>
        q <= ram block[read address];</pre>
    end
endmodule
```

### Example 6–18. VHDL Single-Clock Synchronous RAM with Asynchronous Read Address

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
USE ieee.numeric std.ALL;
ENTITY ram IS
   GENERIC (
       ADDRESS WIDTH: integer := 4;
       DATA WIDTH: integer := 8
   );
    PORT (
       clock: IN std logic;
       data: IN STD LOGIC VECTOR(DATA WIDTH - 1 DOWNTO 0);
       write address IN STD LOGIC VECTOR (ADDRESS WIDTH - 1 DOWNTO 0);
       read address IN STD LOGIC VECTOR (ADDRESS WIDTH - 1 DOWNTO 0);
        we: IN STD LOGIC;
        q: OUT STD LOGIC VECTOR (DATA WIDTH - 1 DOWNTO 0)
   );
END ram;
ARCHITECTURE rtl OF ram IS
   TYPE RAM IS ARRAY(0 TO 2 ** ADDRESS WIDTH - 1) OF std logic vector(DATA WIDTH - 1
DOWNTO 0);
   SIGNAL ram block: RAM;
BEGIN
   PROCESS (clock)
        IF (clock'event AND clock = '1') THEN
            IF (we = '1') THEN
               ram block(TO INTEGER(UNSIGNED(write address))) <= data;</pre>
            q <= ram block(TO INTEGER(UNSIGNED(read address)));</pre>
        END IF;
   END PROCESS;
END rtl;
```

### Specifying Initial Memory Contents

Your synthesis tool may offer a way to specify the initial contents of an inferred memory. For example, Quartus II integrated synthesis supports a synthesis attribute called ram\_init\_file that allows you to specify a Memory Initialization File (.mif) for an inferred RAM block. In VHDL, you can also initialize the contents of an inferred memory by specifying a default value for the corresponding signal. Quartus II integrated synthesis automatically converts the default value into a MIF for the inferred RAM.



For information about the ram\_init\_file attribute, refer to the *Quartus II Integrated Synthesis* chapter in volume 1 of the *Quartus II Handbook*. For information about synthesis attributes in other synthesis tools, refer to the tool vendor's documentation.

### Ipm\_rom—Inferring ROM from HDL Code

To infer ROM functions, synthesis tools detect sets of registers and logic that can be replaced with the altsyncram or lpm\_rom megafunctions, depending on the target device family, only for device families that have dedicated memory blocks.



Because formal verification tools do not support ROM megafunctions, Quartus II integrated synthesis does not infer ROM megafunctions when a third-party formal verification tool is selected.

ROMs are inferred when a case statement exists in which a value is set to a constant for every choice in the case statement. Because small ROMs typically achieve the best performance when they are implemented using the registers in regular logic, each ROM function must meet a minimum size requirement to be inferred and placed into memory.



If you are using the Quartus II integrated synthesis, you can direct the software to infer ROM blocks for all sizes. On the Assignments menu, click **Settings**. In the **Category** list, click **Analysis & Synthesis Settings**. Click **More Settings**. Under **Existing Options Settings**, select the option **Allow Any ROM Size for Recognition**. Click the **Setting** arrow and select **ON**.

Some synthesis tools provide options to control the implementation of inferred ROM blocks for Altera devices with TriMatrix memory blocks. For example, Quartus II integrated synthesis provides the romstyle synthesis attribute to specify the type of memory block using the value "M512," "M4K," or "M-RAM," or to specify the use of regular logic instead of a dedicated memory block using the value "logic."



For information about synthesis attributes, refer to the appropriate chapter in the *Synthesis* section in volume 1 of the *Quartus II Handbook*. When you are using a formal verification flow, Altera recommends that you create ROM blocks in separate entities or modules that contain only the ROM logic because you may need to treat the entity and module as a black box during formal verification.

The Verilog HDL and VHDL code samples shown in Examples 6–19 and 6–20 infer synchronous ROM blocks. Depending on the device family's dedicated RAM architecture, the ROM logic may have to be synchronous; consult the device family handbook for details.

For device architectures with synchronous RAM blocks, such as the Stratix series devices and newer device families, either the address or the output has to be registered for ROM code to be inferred. When output registers are used, the registers are implemented using the input registers of the Stratix RAM block, but the functionality of the ROM is not changed. If you register the address, the power-up state of the inferred ROM can be different from the HDL design. In this scenario, the synthesis software generally issues a warning. The Quartus II Help explains the condition under which the functionality changes when you are using Quartus II integrated synthesis. These ROM code samples map directly to the Altera TriMatrix memory architecture.

### Example 6-19. Verilog HDL Synchronous ROM

### Example 6-20. VHDL Synchronous ROM

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
ENTITY sync rom IS
   PORT (
       clock: IN STD LOGIC;
        address: IN STD LOGIC VECTOR(7 downto 0);
        data_out: OUT STD_LOGIC_VECTOR(5 downto 0)
    );
END sync_rom;
ARCHITECTURE rtl OF sync rom IS
BEGIN
PROCESS (clock)
   BEGIN
   IF rising edge (clock) THEN
        CASE address IS
            WHEN "00000000" => data out <= "101111";
            WHEN "00000001" => data out <= "110110";
            WHEN "11111110" => data out <= "000001";
            WHEN "11111111" => data out <= "101010";
            WHEN OTHERS => data out <= "101111";
        END CASE;
   END IF;
   END PROCESS;
END rtl;
```

### altshift taps-Inferring Shift Registers from HDL Code

To infer shift registers, synthesis tools detect a group of shift registers of the same length and convert them to an altshift\_taps megafunction. To be detected, all the shift registers must have the following characteristics:

- Use the same clock and clock enable
- Do not have any other secondary signals
- Have equally spaced taps that are at least three registers apart



Because formal verification tools do not support shift register megafunctions, the Quartus II integrated synthesis does not infer the altshift\_taps megafunction when a third-party formal verification tool is selected. You can select EDA tools for use with your Quartus II project on the EDA Tool Settings page of the Settings dialog box.

When you are using a formal verification flow, Altera recommends that you create shift register blocks in separate entities or modules containing only the shift register logic, because you may need to treat the entity or module as a black box during formal verification.

Synthesis software recognizes shift registers only for device families that have dedicated RAM blocks and the software uses certain guidelines to determine the best implementation. The following guidelines are followed in Quartus II integrated synthesis and also are generally followed by third-party EDA tools:

- For FLEX<sup>®</sup> 10K and ACEX<sup>®</sup> 1K devices, the software does not infer altshift\_taps megafunctions because FLEX 10K and ACEX 1K devices have a relatively small amount of dedicated memory.
- For APEX 20K and APEX II devices, the software infers the altshift\_taps megafunction only if the shift register has more than a total of 128 bits. Smaller shift registers typically do not benefit from implementation in dedicated memory.
- For Stratix and Cyclone<sup>™</sup> series devices, the software determines whether to infer the altshift\_taps megafunction based on the width of the registered bus (W), the length between each tap (L), and the number of taps (N).
  - If the registered bus width is one (W = 1), the software infers altshift\_taps if the number of taps times the length between each tap is greater than or equal to 64 (N × L ≥ 64).
  - If the registered bus width is greater than one (W > 1), the software infers altshift\_taps if the registered bus width times the number of taps times the length between each tap is greater than or equal to  $32 (W \times N \times L \ge 32)$ .

If the length between each tap (L) is not a power of two, the software uses more logic to decode the read and write counters. This situation occurs because for different sizes of shift registers, external decode logic that uses logic elements (LEs) or Adaptive Logic Modules (ALMs) is required to implement the function. This decode logic eliminates the performance and utilization advantages of implementing shift registers in memory.

The registers that the software maps to the altshift\_taps megafunction and places in RAM are not available in a Verilog HDL or VHDL output file for simulation tools because their node names do not exist after synthesis.

The following examples infer shift registers:

- Verilog HDL Single-Bit Wide, 64-Bit Long Shift Register
- Verilog HDL 8-Bit Wide, 64-Bit Long Shift Register with Evenly Spaced Taps
- VHDL 8-Bit Wide, 64-Bit Long Shift Register with Evenly Spaced Taps

### Verilog HDL Single-Bit Wide, 64-Bit Long Shift Register

The Verilog HDL code sample shown in Example 6–21 shows a simple, single-bit wide, 64-bit long shift register. The synthesis software implements the register (W=1 and M=64) in an altshift\_taps megafunction for supported devices. If the length of the register is less than 64 bits, the software implements the shift register in logic.

### Example 6-21. Verilog HDL Single-Bit Wide, 64-Bit Long Shift Register

```
module shift_1x64 (clk, shift, sr_in, sr_out);
  input clk, shift;
  input sr_in;
  output sr_out;

reg [63:0] sr;

always @ (posedge clk)
  begin
    if (shift == 1'b1)
    begin
        sr[63:1] <= sr[62:0];
        sr[0] <= sr_in;
    end
  end
  assign sr_out = sr[63];
endmodule</pre>
```

## Verilog HDL 8-Bit Wide, 64-Bit Long Shift Register with Evenly Spaced Taps

The code samples shown in Examples 6–22 and 6–23 show Verilog HDL and VHDL 8-bit wide, 64-bit long shift register (W > 1 and M = 64) with evenly spaced taps at 15, 31, and 47. The synthesis software implements this function in a single altshift\_taps megafunction and maps it to RAM in supported devices.

### Example 6-22. Verilog HDL 8-Bit Wide, 64-Bit Long Shift Register with Evenly Spaced Taps

```
module shift 8x64 taps (clk, shift, sr in, sr out, sr tap one, sr tap two, sr tap three);
    input clk, shift;
    input [7:0] sr_in;
   output [7:0] sr_tap_one, sr_tap_two, sr_tap_three, sr_out;
    reg [7:0] sr [63:0];
    integer n;
    always @ (posedge clk)
   begin
        if (shift == 1'b1)
        begin
            for (n = 63; n>0; n = n-1)
                sr[n] <= sr[n-1];
            sr[0] <= sr_in;
        end
    assign sr_tap_one = sr[15];
    assign sr_tap_two = sr[31];
   assign sr_tap_three = sr[47];
   assign sr_out = sr[63];
endmodule
```

### Example 6–23. VHDL 8-Bit Wide, 64-Bit Long Shift Register with Evenly Spaced Taps

```
LIBRARY IEEE;
USE IEEE.STD LOGIC 1164.ALL;
ENTITY shift 8x64 taps IS
    PORT (
        clk: IN STD LOGIC;
        shift: IN STD LOGIC;
        sr in: IN STD LOGIC VECTOR(7 DOWNTO 0);
        sr tap one: OUT STD LOGIC VECTOR(7 DOWNTO 0);
        sr_tap_two : OUT STD_LOGIC_VECTOR(7 DOWNTO 0);
        sr tap three: OUT STD_LOGIC_VECTOR(7 DOWNTO 0);
        sr out: OUT STD LOGIC VECTOR(7 DOWNTO 0)
    );
    END shift 8x64 taps;
ARCHITECTURE arch OF shift 8x64 taps IS
    SUBTYPE sr width IS STD LOGIC VECTOR(7 DOWNTO 0);
    TYPE sr length IS ARRAY (63 DOWNTO 0) OF sr width;
    SIGNAL sr: sr length;
BEGIN
    PROCESS (clk)
    BEGIN
        IF (clk'EVENT and clk = '1') THEN
            IF (shift = '1') THEN
                sr(63 DOWNTO 1) <= sr(62 DOWNTO 0);</pre>
                sr(0) <= sr in;
            END IF;
        END IF;
    END PROCESS;
    sr_tap_one <= sr(15);</pre>
    sr tap two <= sr(31);
    sr tap three <= sr(47);
    sr out <= sr(63);
END arch;
```

# Device-Specific Coding Guidelines

This section provides device-specific coding recommendations for Altera device architectures. It is important to understand how synthesis tools map your HDL code into the target Altera device. Designing registers and specific logic structures to match the appropriate Altera device architecture can provide significant quality improvements in your design results.

### Register Power-Up Values in Altera Devices

Registers in the device core always power up to a low (0) logic level on all Altera devices. However, there are ways to implement logic such that registers behave as if they were powering up to a high (1) logic level.

If you use a preset signal on a device that does not support presets in the register architecture, then your synthesis tool may convert the preset signal to a clear signal, which requires synthesis to perform an

optimization referred to as NOT gate push-back. NOT gate push-back adds an inverter to the input and the output of the register so that the reset and power-up conditions will appear to be high but the device operates as expected. In this case, your synthesis tool may issue a message informing you about the power-up condition. The register itself powers up low, but the register output is inverted so the signal that arrives at all destinations is high.

Due to these effects, if you specify a particular reset value (other than 0), you may cause your synthesis tool to use the asynchronous clear (aclr) signals available on the registers to implement the high bits with NOT gate push-back. In that case, the registers will look as though they power up to the specified reset value. You will see this behavior, for example, if your design targets FLEX 10KE or ACEX devices.

When a load signal is available in the device, your synthesis tools can implement a reset of 1 or 0 value by using an asynchronous load of 1 or 0. When the synthesis tool uses an asynchronous load signal, it is not performing NOT gate push-back, so the registers will power up to a 0 logic level.

For additional details, refer to the appropriate device family handbook or the appropriate handbook of the Altera web site at www.altera.com.

Designers typically use an explicit reset signal for the design, which forces all registers into their appropriate values after reset but not necessarily at power-up. You can create your design such that the asynchronous reset allows the board to operate in a safe condition and then you can bring up the design with the reset active. This is a good practice so you do not depend on the power-up conditions of the device.

You can make the your design more stable and avoid potential glitches by synchronizing external or combinational logic of the device architecture before you drive the asynchronous control ports of registers.

For additional information about good synchronous design practices, refer to the *Design Recommendations for Altera Devices* chapter in volume 1 of the *Quartus II Handbook*.

If you want to force a particular power-up condition for your design, use the synthesis options available in your synthesis tool. With Quartus II integrated synthesis, you can apply the **Power-Up Level** logic option. You can also apply the option with an altera\_attribute assignment in your source code. Using this option forces synthesis to perform NOT gate push-back because synthesis tools cannot actually change the power-up states of core registers.

You can apply the Quartus II integrated synthesis **Power-Up Level** assignment to a specific register or to a design entity, module or subdesign. If you do so, every register in that block receives the value. Registers power up to 0 by default; therefore you can use this assignment to force all registers to power up to 1 using NOT gate push-back.



Be aware that using NOT gate push-back as a global assignment could slightly degrade the quality of results due to the number of inverters that are needed. In some situations, issues are caused by enable or secondary control logic inference. It may also be more difficult to migrate such a design to an ASIC or a HardCopy<sup>®</sup> device. You can simulate the power-up behavior in a functional simulation if you use initialization.



The **Power-Up Level** option and the altera\_attribute are described in the *Quartus II Integrated Synthesis* chapter in volume 1 of the *Quartus II Handbook*.

In VHDL, some synthesis tools can also read the default values for registered signals and implement this behavior in the device. For example, Quartus II integrated synthesis converts VHDL default values for registered signals into Power-Up Level settings. That way, the synthesized behavior matches the power-up state of the HDL code during a functional simulation.

For example, the following code infers a register for q and sets its power-up level to high (while the reset value is 0):

```
SIGNAL q : STD_LOGIC := '1'; -- q has a default value of '1'
PROCESS (clk, reset)
BEGIN
   IF (reset = '1') THEN
        q <= '0';
   ELSIF (rising_edge(clk)) THEN
        q <= d;
   END IF;
END PROCESS;</pre>
```



Note that the Quartus II software, like most synthesis tools, does not synthesize Verilog HDL initial blocks. Therefore, the tool does not synthesize variables that are assigned values in initial blocks into power-up conditions.

### Secondary Register Control Signals Such as Clear & Clock Enable

FPGA device architectures are based on registers also known as flipflops. The registers in Altera FPGAs provide a number of secondary control signals (such as clear and enable signals) that you can use to implement control logic for each register without using extra logic cells. Device families vary in their support for secondary signals, so consult the device family data sheet to verify which signals are available in your target device.

To make the most efficient use of the signals in the device, your HDL code should match the device architecture as closely as possible. The control signals have a certain priority due to the nature of the architecture, so your HDL code should follow that priority where possible.

Your synthesis tool can emulate any control signals using regular logic, so getting functionally correct results is always possible. However, if your design requirements are flexible in terms of which control signals are used and in what priority, match your design to the target device architecture to achieve the most efficient results. If the priority of the signals in your design is not the same as that of the target architecture, then extra logic may be required to implement the control signals. This extra logic uses additional device resources, and can cause additional delays for the control signals.

In addition, there are certain cases where using logic other than the dedicated control logic in the device architecture can have a larger impact. For example, the clock enable signal has priority over the synchronous reset or clear signal in the device architecture. The clock enable turns off the clock line in the logic array block (LAB), and the clear signal is synchronous. So in the device architecture, the synchronous clear takes effect only when a clock edge occurs. If you code a register with a synchronous clear signal that has priority over the clock enable signal, the software must emulate the clock enable functionality using data inputs to the registers. Because the signal does not use the clock enable port of a register, you cannot apply a Clock Enable Multicycle constraint. In this case, following the priority of signals available in the device is clearly the best choice for the priority of these control signals, and using a different priority causes unexpected results with an assignment to the clock enable signal.



The priority order for secondary control signals in Altera devices differs from the order for other vendors' devices. If your design requirements are flexible regarding priority, verify that the secondary control signals meet design performance requirements when migrating designs between FPGA vendors and try to match your target device architecture to achieve the best results.

The signal order is the same for all Altera device families, although as noted previously, not all device families provide every signal. The following priority order is observed:

- 1. Asynchronous Clear, aclr—highest priority
- 2. Preset, pre
- 3. Asynchronous Load, aload
- 4. Enable, ena
- 5. Synchronous Clear, sclr
- 6. Synchronous Load, sload
- 7. Data In, data—lowest priority

The following examples provide Verilog HDL and VHDL code that create a register with the aclr, aload, and ena control signals listed previously.



The dff\_all.v does not have adata on the sensitivity list, but dff\_all.vhd does. This is a limitation of the Verilog HDL language—there is no way to describe an asynchronous load signal (in which q toggles if adata toggles while aload is high). All synthesis tools should infer an aload signal from this construct despite this limitation. When they perform such inference, you may see information or warning messages from the synthesis tool.

### Example 6–24. Verilog HDL D-Type Flipflop (Register) with ena, aclr & aload Control Signals

```
module dff_control(clk, aclr, aload, ena, data, adata, q);
  input clk, aclr, aload, ena, data, adata;
  output q;

reg q;

always @ (posedge clk or posedge aclr or posedge aload)
  begin
    if (aclr)
        q <= 1'b0;
    else if (aload)
        q <= adata;
    else
        if (ena)
        q <= data;
  end
endmodule</pre>
```

### Example 6-25. VHDL D-Type Flipflop (Register) with ena, aclr & aload Control Signals

```
LIBRARY ieee;
USE ieee.std logic 1164.all;
ENTITY dff control IS
    PORT (
     clk: IN STD LOGIC;
      aclr: IN STD LOGIC;
      aload: IN STD LOGIC;
      adata: IN STD LOGIC;
     ena: IN STD LOGIC;
      data: IN STD LOGIC;
     q: OUT STD LOGIC
    );
END dff control;
ARCHITECTURE rtl OF dff control IS
BEGIN
    PROCESS (clk, aclr, aload, adata)
   BEGIN
        IF (aclr = '1') THEN
         q <= '0';
        ELSIF (aload = '1') THEN
          q <= adata;
        ELSE
            IF (clk = '1' AND clk'event) THEN
                IF (ena ='1') THEN
                q <= data;
                END IF;
            END IF;
        END IF;
   END PROCESS;
END rtl;
```

The preset signal is not available in many device families, because it is replaced with the more flexible aload signal, so the preset signal is not included in the examples.

Creating many registers with different sload and sclr signals can make packing the registers into LABs difficult for the Quartus II Fitter because the sclr and sload signals are LAB-wide signals. In addition, using the LAB-wide sload signal prevents the Fitter from packing registers using the quick feedback path in the device architecture, which means that some registers can not be packed with other logic.

Therefore, synthesis tools typically avoid using the sload or sclear signal if there is space in the look-up table (LUT). Using the LUT to implement the signals is always more flexible if it is available. Synthesis tools also typically restrict use of sload and sclr signals to certain functions such as arithmetic chains (counters), or wide multiplexers in which there are enough registers with common signals to allow good LAB packing. Because different device families offer different numbers of control signals, inference of these signals is also device-specific. For example, Stratix II devices have more flexibility than Stratix devices with respect to secondary control signals, so synthesis tools might infer more sload and sclr signals for Stratix II devices.

If you use these additional control signals, use them in the priority order that matches the device architecture. To achieve the most efficient results, ensure the sclr signal has a higher priority than the sload signal in the same way that aclr has higher priority than aload in the previous examples. Remember that the register signals are not inferred unless the design meets the conditions described previously. However, if your HDL described the desired behavior, the software will always implement logic with the correct functionality.

In Verilog HDL, the following code for sload and sclr could replace the q <= data statement in the Verilog HDL example shown in Example 6–24 (after adding the control signals to the module declaration).

### Example 6-26. Verilog HDL sload & sclr

```
if (sclr)
    q <= 1'b0;
else if (sload)
    q <= sdata;
else
    q <= data;</pre>
```

In VHDL, the following code for sload and sclr could replace the q <= data; statement in the VHDL example shown in Example 6–25 (after adding the control signals to the entity declaration).

### Example 6-27. VHDL sload & scir

```
IF (sclr = '1') THEN
    q <= '0';
ELSIF (sload = '1') THEN
    q <= sdata;
ELSE
    q <= data;</pre>
```

### **Tri-State Signals**

When you are targeting Altera devices, you should use tri-state signals only when they are attached to top-level bidirectional or output pins. Avoid lower level bidirectional pins, and avoid using the Z logic value unless it is driving an output or bidirectional pin.

Synthesis tools implement designs with internal tri-state signals correctly in Altera devices using multiplexer logic, but Altera does not recommend this coding practice.



In hierarchical block-based or incremental design flows, a hierarchical boundary cannot contain any bidirectional ports, unless the lower level bidirectional port is connected directly through the hierarchy to a top-level output pin without connecting to any other design logic. If you use boundary tri-states in a lower level block, synthesis software must push the tri-states through the hierarchy to the top-level to make use of the tri-state drivers on output pins of Altera devices. Because pushing tri-states requires optimizing through hierarchies, lower level tri-states are restricted with block-based design methodologies.

The code examples shown in Examples 6–28 and 6–29 show Verilog HDL and VHDL code that creates tri-state bidirectional signals.

### Example 6-28. Verilog HDL Tri-State Signal

```
module tristate (myinput, myenable, mybidir);
  input myinput, myenable;
  inout mybidir;
  assign mybidir = (myenable ? myinput : 1'bZ);
endmodule
```

### Example 6-29. VHDL Tri-State Signal

```
LIBRARY ieee;
USE ieee.std_logic_1164.ALL;
USE ieee.std_logic_arith.ALL;

ENTITY tristate IS
PORT (
    mybidir : INOUT STD_LOGIC;
    myinput : IN STD_LOGIC;
    myenable : IN STD_LOGIC
    );
END tristate;

ARCHITECTURE rtl OF tristate IS
BEGIN
    mybidir <= 'Z' WHEN (myenable = '0') ELSE myinput;
END rtl;
```

### **Adder Trees**

Structuring adder trees appropriately to match your targeted Altera device architecture can result in significant performance and density improvements. A good example of an application using a large adder tree is a finite impulse response (FIR) correlator. Using a pipelined binary or ternary adder tree appropriately can greatly improve the quality of your results.

This section explains why coding recommendations are different for Altera 4-input LUT devices, and the 6-input LUT logic structures currently available only in Stratix II devices.

### Architectures with 4-Input LUTs in Logic Elements

Architectures such as the Stratix series, Cyclone series, APEX series, and FLEX series devices contain 4-input LUTs as the standard combinational structure in the LE.

If your design can tolerate pipelining, the fastest way to add three numbers A, B, and C in devices that use 4-input lookup tables is to add A + B, register the output, and then add the registered output to C. Adding A + B takes one level of logic (one bit is added in one LE), so this runs at full clock speed. This can be extended to as many numbers as desired.

In the code sample shown in Example 6–30, five numbers A, B, C, D, and E are added. Adding five numbers in devices that use 4-input lookup tables requires four adders and three levels of registers for a total of 64 LEs (for 16-bit numbers).

### Example 6-30. Verilog HDL Pipelined Binary Tree

```
module binary adder tree (A, B, C, D, E, CLK, OUT);
   parameter WIDTH = 16;
    input [WIDTH-1:0] A, B, C, D, E;
    input CLK;
    output [WIDTH-1:0] OUT;
    wire [WIDTH-1:0] sum1, sum2, sum3, sum4;
    reg [WIDTH-1:0] sumreg1, sumreg2, sumreg3, sumreg4;
    // Registers
    always @ (posedge CLK)
        begin
            sumreq1 <= sum1;</pre>
            sumreq2 <= sum2;</pre>
            sumreq3 <= sum3;</pre>
            sumreq4 <= sum4;</pre>
        end
    // 2-bit additions
    assign sum1 = A + B;
    assign sum2 = C + D;
    assign sum3 = sumreg1 + sumreg2;
    assign sum4 = sumreg3 + E;
    assign OUT = sumreg4;
endmodule
```

### Architectures with 6-Input LUTs in Adaptive Logic Modules

Because the Stratix II architecture uses a 6-input LUT in its basic logic structure, Stratix II devices benefit from a different coding style from the previous example presented for 4-input LUTs. Specifically, Stratix II device ALMs can simultaneously add three bits. Therefore, the tree in the previous example must be two levels deep and contain just two add-by-three inputs instead of four add-by-two inputs.

Although the code in the previous example compiles successfully for Stratix II devices, the code is inefficient and does not take advantage of the 6-input adaptive look-up table (ALUT). By restructuring the tree as a ternary tree, the design becomes much more efficient, significantly improving density utilization. Therefore, when you are targeting Stratix II devices, large pipelined binary adder trees designed for 4-input LUT architectures should be rewritten to take advantage of the Stratix II device architecture.

Example 6–31 uses just 32 ALUTs in a Stratix II device—more than a 4:1 advantage over the number of LUTs in the prior example implemented in a Stratix device.



You cannot pack a Stratix II LAB full when using this type of coding style because of the number of LAB inputs. However, in a typical design, the Quartus II Fitter can pack other logic into each LAB to take advantage of the unused ALMs.

### Example 6-31. Verilog HDL Pipelined Ternary Tree

```
module ternary adder tree (A, B, C, D, E, CLK, OUT);
    parameter WIDTH = 16;
    input [WIDTH-1:0] A, B, C, D, E;
    input CLK;
    output [WIDTH-1:0] OUT;
    wire [WIDTH-1:0] sum1, sum2;
    reg [WIDTH-1:0] sumreg1, sumreg2;
    // Registers
    always @ (posedge CLK)
        begin
            sumreg1 <= sum1;</pre>
            sumreg2 <= sum2;
        end
    // 3-bit additions
    assign sum1 = A + B + C;
    assign sum2 = sumreg1 + D + E;
    assign OUT = sumreg2;
endmodule
```

These examples show pipelined adders, but partitioning your addition operations can help you achieve better results in nonpipelined adders as well. If your design is not pipelined, a ternary tree provides much better performance than a binary tree. For example, depending on your synthesis tool, the HDL code sum = (A + B + C) + (D + E) is more likely to create the optimal implementation of a 3-input adder for A + B + C followed by a 3-input adder for sum1 + D + E than the code without the parenthesis. If you do not add the parenthesis, the synthesis tool may partition the addition in a way that is not optimal for the architecture.

### Coding Guidelines for Other Logic Structures

This section provides coding guidelines for the following logic structures.

- Latches—Altera recommends that you not use latches if possible, but this section also includes guidelines for using latches successfully if they are required.
- State Machines—This section helps you ensure the best results when you use state machines.
- Multiplexers—This section addresses common problems and provides design guidelines to achieve optimal resource utilization for multiplexer designs.
- Cyclic Redundancy Check Functions—This section provides guidelines for getting good results when designing CRC functions.

### Latches

A latch is a small combinational loop that holds the value of a signal until a new value is assigned.



Altera recommends that you design without the use of latches whenever possible.



For additional information about the issues involved in designing with latches and all combinational loops, refer to the *Design Recommendations* for Altera Devices chapter in volume 1 of the *Quartus II Handbook*.

Latches can be inferred from HDL code when you did not intend to use a latch as detailed in "Unintentional Latch Generation". If you do intend to infer a latch, it is important to infer it correctly to guarantee correct device operation as detailed in "Inferring Latches Correctly" on page 6–42.

### Unintentional Latch Generation

When you are designing combinational logic, certain coding styles can create an unintentional latch. For example, when CASE or IF statements do not cover all possible input conditions, latches may be required to hold the output if a new output value is not assigned. Check your synthesis tool messages for references to inferred latches. If your code unintentionally creates a latch, make code changes to remove the latch.



Latches have limited support in formal verification tools. Therefore, ensure that you do not infer latches unintentionally, for example, through an incomplete CASE statement, when you are using formal verification in your design flow.

The full\_case attribute can be used in Verilog HDL designs to treat unspecified cases as don't care values (X). However, using the full\_case attribute can cause simulation mismatches because this attribute is a synthesis-only attribute, so simulation tools still treat the unspecified cases as latches.



Refer to the appropriate chapter in the *Synthesis* section in volume 1 of the *Quartus II Handbook* for more information about using attributes in your synthesis tool. The *Quartus II Integrated Synthesis* chapter provides an example explaining possible simulation mismatches.

Omitting the final ELSE or WHEN OTHERS clause in an IF or CASE statement can also generate a latch. Don't care (X) assignments on the default conditions are useful in preventing latch generation. For the best logic optimization, assign the default CASE or final ELSE value to don't care (X) instead of a logic value.

The VHDL sample code shown in Example 6–32 prevents unintentional latches. Without the final ELSE clause, this code creates unintentional latches to cover the remaining combinations of the sel inputs. When you are targeting a Stratix device with this code, omitting the final ELSE condition can cause the synthesis software to use up to six LEs instead of the three it uses with the ELSE statement. Additionally, assigning the final ELSE value to 1 instead of assigning the ELSE statement to the value of X can result in slightly more LEs because the synthesis software cannot perform as much optimization when you specify a constant value compared to a don't care value.

### Example 6-32. VHDL Code Preventing Unintentional Latch Creation

```
LIBRARY ieee;
USE IEEE.std logic 1164.all;
ENTITY nolatch IS
   PORT (a,b,c: IN STD LOGIC;
       sel: IN STD_LOGIC_VECTOR (4 DOWNTO 0);
       oput: OUT STD LOGIC);
END nolatch;
ARCHITECTURE rtl OF nolatch IS
   PROCESS (a,b,c,sel) BEGIN
       IF sel = "00000" THEN
           oput <= a;
        ELSIF sel = "00001" THEN
           oput <= b;
        ELSIF sel = "00010" THEN
           oput <= c;
                         --- Prevents latch inference
           oput <= ''X'; --/
        END IF;
   END PROCESS;
END rtl;
```

### Inferring Latches Correctly

Synthesis tools can infer a latch that does not exhibit the problems typically associated with combinational loops.

When using Quartus II integrated synthesis, latches that are inferred by the software are reported in the **User-Specified and Inferred Latches** section of the Compilation Report. This report indicates whether the latch is safe and free of timing hazards.

If a latch or combinational loop in your design is not listed in the **User-Specified and Inferred Latches** report, it means that it was not inferred as a safe latch by the software and is not considered glitch-free.

All combinational loops listed in the Analysis & Synthesis Logic Cells Representing Combinational Loops table in the Compilation Report are at risk of timing hazards. These entries indicate possible problems with your design that you should investigate. However, it is possible to have a correct design that includes combinational loops. For example, it is possible that the combinational loop cannot be sensitized. This can occur in cases where there is an electrical path in the hardware, but either the designer knows that the circuit will never encounter data that causes that path to be activated, or the surrounding logic is set up in a mutually exclusive manner that prevents that path from ever being sensitized, independent of the data input.

For macrocell-based devices such as MAX® 7000AE and MAX 3000A, all data (D-type) latches and set-reset (S-R) latches listed in the **Analysis & Synthesis User-Specified and Inferred Latches** table have an implementation free of timing hazards such as glitches. The implementation includes a cover term to ensure there is no glitching, and includes a single macrocell in the feedback loop.

For 4-input LUT-based devices such as Stratix devices, the Cyclone series, and MAX II devices, all latches in the User-Specified and Inferred **Latches** table with a single LUT in the feedback loop are free of timing hazards when a single input changes. Because of the hardware behavior of the LUT, the output does not glitch when a single input toggles between two values that are supposed to produce the same output value. For example, a D-type input toggling when the enable input is inactive, or a set input toggling when a reset input with higher priority is active. This hardware behavior of the LUT means that no cover term is needed for a loop around a single LUT. The Quartus II software uses a single LUT in the feedback loop whenever possible. A latch that has data, enable, set, and reset inputs in addition to the output fed back to the input cannot be implemented in a single 4-input LUT. If the Quartus II software cannot implement the latch with a single-LUT loop because there are too many inputs, then the User-Specified and Inferred Latches table indicates that the latch is not free of timing hazards.

For 6-input LUT-based devices such as Stratix II, the software can implement all latch inputs with a single adaptive look-up table (ALUT) in the combinational loop. Therefore, all latches in the **User-Specified and Inferred Latches** table are free of timing hazards when a single input changes.

To ensure hazard-free behavior, only one control input may change simultaneously. Changing two inputs simultaneously, such as deasserting set and reset at the same time, or changing data and enable at the same time, can produce incorrect behavior in any latch.

Quartus II integrated synthesis infers latches from always blocks in Verilog HDL and process statements in VHDL, but not from continuous assignments in Verilog HDL or concurrent signal assignments in VHDL. These rules are the same as for register inference. The software infers registers or flipflops only from always blocks and process statements. The following examples infer latches.

### Verilog HDL Set-Reset Latch Example

The Verilog HDL code sample shown in Example 6–33 infers a S-R latch correctly in the Quartus II software.

### Example 6-33. Verilog HDL Set-Reset Latch

```
module simple_latch (
  input SetTerm,
  input ResetTerm,
  output reg LatchOut
);

always @ (SetTerm or ResetTerm) begin
  if (SetTerm)
    LatchOut = 1'b1;
  else if (ResetTerm)
    LatchOut = 1'b0;
  end
endmodule
```

### HDL Data Type Latch Example

The VHDL code sample shown in Example 6–34 infers a D-type latch correctly in the Quartus II software.

### Example 6-34. HDL Data Type Latch

```
LIBRARY IEEE;
USE IEEE.std logic 1164.all;
ENTITY simple latch IS
   PORT (
     enable, data : IN STD LOGIC;
                    : OUT STD LOGIC
   );
END simple_latch;
ARCHITECTURE rtl OF simple latch IS
BEGIN
latch : PROCESS (enable, data)
   BEGIN
      IF (enable = '1') THEN
        q <= data;
     END IF;
  END PROCESS latch;
END rtl;
```

The following example shows a Verilog HDL continuous assignment that does not infer a latch in the Quartus II software. The behavior is similar to a latch, but it may not function correctly as a latch and its timing is not analyzed as a latch.

```
assign latch out = en ? data : latch out;
```

The Quartus II integrated synthesis also creates safe latches when possible for instantiations of the lpm\_latch megafunction. Use this megafunction to create a latch with any combination of data, enable, set, and reset inputs. The same limitations apply for creating safe latches as for inferring latches from HDL code.

Inferring the Altera <code>lpm\_latch</code> function in another synthesis tool ensures that the implementation will also be recognized as a latch in the Quartus II software. If a third-party synthesis tool implements a latch using the <code>lpm\_latch</code> megafunction, then the Quartus II integrated synthesis lists the latch in the <code>User-Specified</code> and <code>Inferred Latches</code> table in the same way as it lists latches created in HDL source code. The coding style necessary to produce an <code>lpm\_latch</code> implementation may depend on your synthesis tool. Some third-party synthesis tools list the number of <code>lpm\_latch</code> functions that are inferred.

If a latch is listed by the Quartus II integrated synthesis in the **User-Specified and Inferred Latches** table, and is implemented by Analysis & Synthesis as a safe latch, then physical synthesis netlist optimizations in the Fitter maintain the hazard-free performance.

For LUT-based families, the Fitter uses global routing for control signals including signals that Analysis & Synthesis identifies as latch enables. In some cases the global insertion delay may decrease the timing performance. If necessary, you can turn off the Quartus II **Global Signal** logic option to manually prevent the use of global signals. Global latch enables are listed in the **Global & Other Fast Signals** table in the Compilation Report.

### State Machines

Synthesis tools can recognize and encode Verilog HDL and VHDL state machines during synthesis. This section presents guidelines to ensure the best results when you use state machines. Ensuring that your synthesis tool recognizes a piece of code as a state machine allows the tool to recode the state variables to improve the quality of results, and allows the tool to use the known properties of state machines to optimize other parts of the design. When synthesis recognizes a state machine it is often able to improve the design area and performance.

To achieve the best results, synthesis tools often use one-hot encoding for FPGA devices and minimal-bit encoding for CPLD devices, although the choice of implementation can vary for different state machines and different devices. Refer to your synthesis tool documentation for specific ways to control the manner in which state machines are encoded.



For information about state machine encoding in Quartus II integrated synthesis, refer to the *State Machine Processing* section in the *Quartus II Integrated Synthesis* chapter in volume 1 of the *Quartus II Handbook*.

To ensure proper recognition and inference of state machines and to improve the quality of results, Altera recommends that you observe the following guidelines, which apply to both Verilog HDL and VHDL:

- Assign default values to outputs derived from the state machine so that synthesis does not generate unwanted latches.
- Separate the state machine logic from all arithmetic functions and data paths, including assigning output values.
- If your design contains an operation that is used by more than one state, define the operation outside the state machine and cause the output logic of the state machine use this value.
- Use a simple asynchronous or synchronous reset to ensure a defined power-up state. If your state machine design contains more elaborate reset logic, such as both an asynchronous reset and an asynchronous load, the Quartus II software generates regular logic rather than inferring a state machine.

If a state machine enters an illegal state due to a problem with the device, the design will likely cease to function correctly until the next reset of the state machine. Synthesis tools do not provide for this situation by default. The same issue applies to any other registers if there is some kind of fault in the system. A default or when others clause does not affect this operation, assuming that your design never deliberately enters this state. Synthesis tools remove any logic generated by a default state if it is not reachable by normal state machine operation.

Some synthesis tools have an option to implement a safe state machine that inserts the default case if it does not exist and preserves the logic in the design to handle illegal states. If a state machine gets into an illegal state for any reason, it returns to the reset state on the next clock edge. Of course this option protects only state machines, and all other registers in the design are not protected this way.



For additional information about tool-specific options for implementing state machines, refer to the tool vendor's documentation or the appropriate chapter in the *Synthesis* section in volume 1 of the *Quartus II Handbook*.

The following two sections "Verilog HDL State Machines" and "VHDL State Machines" describe additional language-specific guidelines and coding examples.

### Verilog HDL State Machines

To ensure proper recognition and inference of Verilog HDL state machines, observe the following additional Verilog HDL guidelines. Some of these guidelines may be specific to Quartus II integrated synthesis. Refer to your synthesis tool documentation for specific coding recommendations.

- If you are using the SystemVerilog standard, use enumerated types to describe state machines (as shown in the "SystemVerilog State Machine Coding Example" on page 6–49).
- Represent the states in a state machine with the parameter data types in Verilog-1995 and -2001 and use the parameters to make state assignments (as shown below in the "Verilog HDL State Machine Coding Example"). This implementation makes the state machine easier to read and reduces the risk of errors during coding.



Altera recommends against the direct use of integer values for state variables such as next\_state < = 0. However, using an integer does not prevent inference in the Quartus II software.

No state machine is inferred in the Quartus II software if the state transition logic uses arithmetic similar to that shown in the following example:

```
case (state)
    0: begin
        if (ena) next_state <= state + 2;
        else next_state <= state + 1;
    end
    1: begin
    ...
endcase</pre>
```

No state machine is inferred in the Quartus II software if the state variable is an output.

### Verilog HDL State Machine Coding Example

The following module verilog\_fsm is an example of a typical Verilog HDL state machine implementation.

This state machine has five states. The asynchronous reset sets the variable state to state\_0. The sum of in1 and in2 is an output of the state machine in state\_1 and state\_2. The difference (in1 - in2) is

also used in state\_1 and state\_2. The temporary variables tmp\_out\_0 and tmp\_out\_1 store the sum and the difference of in1 and in2. Using these temporary variables in the various states of the state machine ensures proper resource sharing between the mutually exclusive states.

### Example 6-35. Verilog-2001 State Machine

```
module verilog_fsm (clk, reset, in_1, in_2, out);
    input clk;
    input reset;
    input [3:0] in 1;
    input [3:0] in 2; output [4:0] out;
    parameter state 0 = 3'b000;
   parameter state_1 = 3'b001;
   parameter state 2 = 3'b010;
    parameter state 3 = 3'b011;
    parameter state 4 = 3'b100;
    reg [4:0] tmp out 0, tmp out 1, tmp out 2;
    reg [2:0] state, next_state;
    always @ (posedge clk or posedge reset)
    begin
        if (reset)
           state <= state 0;
        else
           state <= next state;
    end
    always @ (state or in 1 or in 2)
    begin
        tmp_out_0 = in_1 + in_2;
        tmp_out_1 = in_1 - in_2;
        case (state)
            state_0: begin
               tmp out 2 \le in 1 + 5'b00001;
               next state <= state 1;
            state_1: begin
                if (in 1 < in 2) begin
                    next state <= state 2;
                    tmp out 2 <= tmp out 0;
                end
                else begin
                    next_state <= state_3;</pre>
                    tmp_out_2 <= tmp_out_1;</pre>
                end
            end
            state 2: begin
                tmp out 2 <= tmp out 0 - 5'b00001;
                next_state <= state_3;</pre>
            end
            state 3: begin
                tmp out 2 <= tmp out 1 + 5'b00001;
                next state <= state 0;</pre>
            end
            state_4:begin
```

```
tmp_out_2 <= in_2 + 5'b00001;
    next_state <= state_0;
end
    default:begin
        tmp_out_2 <= 5'b00000;
        next_state <= state_0;
end
    endcase
end
assign out = tmp_out_2;
endmodule</pre>
```

An equivalent implementation of this state machine can be achieved by using 'define instead of the parameter data type, as follows:

```
'define state_0 3'b000
'define state_1 3'b001
'define state_2 3'b010
'define state_3 3'b011
'define state 4 3'b100
```

In this case, the state and next\_state assignments are assigned a 'state\_x instead of a state\_x, as shown in the following example:

```
next_state <= 'state_3;</pre>
```



Although the 'define construct is supported, Altera strongly recommends the use of the parameter data type because doing so preserves the state names throughout synthesis.

### SystemVerilog State Machine Coding Example

The module <code>enum\_fsm</code> shown in Example 6–36 is an example of a SystemVerilog state machine implementation that makes use of enumerated types. Altera recommends using this coding style to describe state machines in SystemVerilog.



In Quartus II integrated synthesis, the enumerated type that defines the states for the state machine must be of an unsigned integer type as shown in Example 6–36. If you do not specify the enumerated type as int unsigned, a signed int type is used by default. In this case, the Quartus II integrated synthesis synthesizes the design, but does not recognize or infer a state machine.

### Example 6-36. SystemVerilog State Machine Using Enumerated Types

```
module enum fsm (input clk, reset, input int data[3:0], output int o);
   enum int unsigned \{ S0 = 0, S1 = 2, S2 = 4, S3 = 8 \} state, next state;
  always comb begin : next state logic
     next state = S0;
      case(state)
       S0: next state = S1;
       S1: next state = S2;
       S2: next state = S3;
       S3: next state = S3;
      endcase
   end
  always comb begin
      case(state)
        S0: o = data[3];
        S1: o = data[2];
        S2: o = data[1];
         S3: o = data[0];
      endcase
   end
   always_ff@(posedge clk or negedge reset) begin
      if(~reset)
         state <= S0;
      else
         state <= next state;
   end
endmodule
```

#### VHDI State Machines

To ensure proper recognition and inference of VHDL state machines, represent the states in a state machine with enumerated types and use the corresponding types to make state assignments. This implementation makes the state machine easier to read and reduces the risk of errors during coding. If the state is not represented by an enumerated type, synthesis software (such as Quartus II integrated synthesis) does not recognize the state machine. Instead, the state machine is implemented as regular logic gates and registers and the state machine is not listed as a state machine in the **Analysis & Synthesis** section of the Compilation Report.

### VHDL State Machine Coding Example

The following entity, vhd1\_fsm, is an example of a typical VHDL state machine implementation.

This state machine has five states. The asynchronous reset sets the variable state to state\_0. The sum of in1 and in2 is an output of the state machine in state\_1 and state\_2. The difference (in1 - in2) is also used in state\_1 and state\_2. The temporary variables tmp\_out\_0 and tmp\_out\_1 store the sum and the difference of in1 and in2. Using these temporary variables in the various states of the state machine ensures proper resource sharing between the mutually exclusive states.

### Example 6-37. VHDL State Machine

```
LIBRARY ieee;
USE ieee.std logic 1164.all;
USE ieee.numeric std.all;
ENTITY vhdl fsm IS
   PORT (
      clk: IN STD LOGIC;
      reset: IN STD LOGIC;
      in1: IN UNSIGNED (4 downto 0);
      in2: IN UNSIGNED (4 downto 0);
      out 1: OUT UNSIGNED (4 downto 0)
      );
END vhdl fsm;
ARCHITECTURE rtl OF vhdl fsm IS
  TYPE Tstate IS (state_0, state_1, state_2, state_3, state_4);
  SIGNAL state: Tstate;
  SIGNAL next state: Tstate;
BEGIN
   PROCESS(clk, reset)
   BEGIN
         IF reset = '1' THEN
           state <=state 0;
      ELSIF rising edge(clk) THEN
            state <= next state;
      END IF;
   END PROCESS;
   PROCESS (state, in1, in2)
      VARIABLE tmp out 0: UNSIGNED (4 downto 0);
      VARIABLE tmp out 1: UNSIGNED (4 downto 0);
   BEGIN
      tmp out 0 := in1 + in2;
      tmp out 1 := in1 - in2;
      CASE state IS
         WHEN state 0 =>
            out 1 <= in1;
            next state <= state 1;
         WHEN state 1 =>
            IF (in1 < in2) then
               next state <= state 2;
               out_1 <= tmp_out_0;</pre>
               next state <= state 3;
               out 1 <= tmp out 1;
            END IF;
```

```
WHEN state 2 =>
           IF (in1 < "0100") then
              out 1 <= tmp out 0;
           ELSE
              out_1 <= tmp_out_1;
           END IF;
              next state <= state 3;
        WHEN state_3 =>
              out 1 <= "11111";
              next state <= state 4;
        WHEN state 4 =>
              out_1 <= in2;
              next state <= state 0;
        WHEN OTHERS =>
              out 1 <= "00000";
              next state <= state 0;
     END CASE;
  END PROCESS;
END rtl:
```

### **Multiplexers**

Multiplexers form a large portion of the logic utilization in many FPGA designs. By optimizing your multiplexer logic, you ensure the most efficient implementation in your Altera device. This section addresses common problems and provides design guidelines to achieve optimal resource utilization for multiplexer designs. The section also describes various types of multiplexers, and how they are implemented in the 4-input LUT found in many FPGA architectures, such as Altera's Stratix devices.



Stratix II devices have 6-input LUTs and are not specifically addressed here. Although many of the principles and techniques for optimization are similar, device utilization differs in the Stratix II 6-input LUT devices, for example, Stratix II devices can implement wider multiplexers in one ALM than can be implemented in the 4-input LUT of an LE.

### Multiplexer Types

This first subsection addresses how multiplexers are created from various types of HDL code. CASE statements, IF statements, and state machines are all common sources of multiplexer logic in designs. These HDL structures create different types of multiplexers including binary multiplexers, selector multiplexers, and priority multiplexers. Understanding how multiplexers are created from HDL code and how they might be implemented during synthesis is the first step towards optimizing multiplexer structures for best results.

### **Binary Multiplexers**

Binary multiplexers select inputs based on binary-encoded selection bits. The following "Verilog HDL Binary-Encoded Case Statement" example shows Verilog HDL code describing a simple 4:1 binary multiplexer.

### Example 6-38. Verilog HDL Binary-Encoded Case Statement

```
case (sel)
  2'b00: z = a;
  2'b01: z = b;
  2'b10: z = c;
  2'b11: z = d;
endcase
```

A 4:1 binary multiplexer is efficiently implemented by using two 4-input LUTs. Larger binary multiplexers can be constructed that use the 4:1 multiplexer; constructing an N-input multiplexer (N:1 multiplexer) from a tree of 4:1 multiplexers can result in a structure using as few as 0.66\*(N-1) LUTs.

### **Selector Multiplexers**

Selector multiplexers have a separate select line for each data input. The select lines for the multiplexer are one-hot encoded. The following "Verilog HDL One-Hot-Encoded Case Statement" example shows a simple Verilog HDL code example describing a one-hot selector multiplexer.

### Example 6-39. Verilog HDL One-Hot-Encoded Case Statement

```
case (sel)
  4'b0001: z = a;
  4'b0010: z = b;
  4'b0100: z = c;
  4'b1000: z = d;
  default: z = 1'bx;
endcase
```

Selector multiplexers are commonly built as a tree of AND and OR gates. Using this scheme, two inputs can be selected using two select lines in a single 4-input LUT that uses two AND gates and an OR gate. The outputs of these LUTs can be combined with a wide OR gate. An *N*-input selector multiplexer of this structure requires at least 0.66\*(*N*-0.5) LUTs, which is just slightly worse than the best binary multiplexer.

### **Priority Multiplexers**

In priority multiplexers, the select logic implies a priority. The options to select the correct item must be checked in a specific order based on signal priority. These structures commonly are created from IF, ELSE, WHEN,

SELECT, or ?: statements in VHDL or Verilog HDL. The example VHDL code in the "VHDL IF Statement Implying Priority" section will probably result in the schematic implementation illustrated in Figure 6–2.

### Example 6-40. VHDL IF Statement Implying Priority

```
IF cond1 THEN z <= a;
ELSIF cond2 THEN z <= b;
ELSIF cond3 THEN z <= c;
ELSE z <= d;
END IF;</pre>
```

The multiplexers shown in Figure 6–2 form a chain, evaluating each condition or select bit, one at a time.

Figure 6-2. Priority Multiplexer Implementation of an IF Statement



An *N*-input priority multiplexer uses a LUT for every 2:1 multiplexer in the chain, requiring *N*-1 LUTs. This chain of multiplexers generally increases delay because the critical path through the logic traverses every multiplexer in the chain.

To improve the timing delay through the multiplexer, avoid priority multiplexers if priority is not required. If the order of the choices is not important to the design, use a CASE statement to implement a binary or selector multiplexer instead of a priority multiplexer. If delay through the structure is important in a multiplexed design requiring priority, consider recoding the design to reduce the number of logic levels to minimize delay, especially along your critical paths.

## Default or Others Case Assignment

To fully specify the cases in a CASE statement, include a DEFAULT (Verilog HDL) or OTHERS (VHDL) assignment. This assignment is especially important in one-hot encoding schemes where many combinations of the select lines are unused. Specifying a case for the unused select line combinations gives the synthesis tool information about how to synthesize these cases, and is required by the Verilog HDL and VHDL language specifications.

Some designs do not require that the outcome in the unused cases be considered, often because designers assume these cases will not occur. For these types of designs, you can choose any value for the DEFAULT or OTHERS assignment. However, be aware that the assignment value you choose can have a large effect on the logic utilization required to implement the design due to the different ways synthesis tools treat different values for the assignment, and how the synthesis tools use different speed and area optimizations.

In general, to obtain best results, explicitly define invalid CASE selections with a separate DEFAULT or OTHERS statement instead of combining the invalid cases with one of the defined cases.

If the value in the invalid cases is not important, specify those cases explicitly by assigning the X (don't care) logic value instead of choosing another value. This assignment allows your synthesis tool to perform the best area optimizations.

You can experiment with different DEFAULT or OTHERS assignments for your HDL design and your synthesis tool to test the effect they have on logic utilization in your design.

### Implicit Defaults

The IF statements in Verilog HDL and VHDL can be a convenient way to specify conditions that do not easily lend themselves to a CASE-type approach. However, using IF statements can result in complicated multiplexer trees that are not easy for synthesis tools to optimize.

In particular, every IF statement has an implicit ELSE condition, even when it is not specified. These implicit defaults can cause additional complexity in a multiplexed design.

The following code in the "VHDL IF Statement with Implicit Defaults" example represents a multiplexer with four inputs (a, b, c, d) and one output (z).

#### Example 6-41. VHDL IF Statement with Implicit Defaults

```
IF cond1 THEN
    IF cond2 THEN
    z <= a;
    END IF;
ELSIF cond3 THEN
    IF cond4 THEN
    z <= b;
ELSIF cond5 THEN
    z <= c;
END IF;
ELSIF cond6 THEN
    z <= d;
END IF;</pre>
```

Although the code appears to implement a 4:1 multiplexer, each of the three separate IF statements in the code has an implicit ELSE condition that is not specified. Because the output values for the ELSE cases are not specified, the synthesis tool assumes the intent is to maintain the same output value for these cases.

The code sample shown in Example 6–42 shows code with the same functionality as the code shown in Example 6–41, but specifies the ELSE cases explicitly.

### Example 6-42. VHDL IF Statement with Default Conditions Explicitly Specified

```
IF cond1 THEN
   IF cond2 THEN
     z \ll a;
   ELSE
     z <= z;
   END IF;
ELSIF cond3 THEN
   IF cond4 THEN
     z \ll b;
   ELSIF cond5 THEN
      Z <= C;
   ELSE
     z <= z;
  END IF;
ELSIF cond6 THEN
  z \ll d;
ELSE
  z <= z;
END IF;
```

Figure 6–3 is a schematic representing the code in Example 6–42, which illustrates that the multiplexer logic is significantly more complicated than a basic 4:1 multiplexer, although there are only four inputs.



Figure 6–3. Multiplexer Implementation of an IF Statement with Implicit Defaults

There are several ways you can simplify the multiplexed logic and remove the unneeded defaults. The optimal method may be to recode the design so the logic takes the structure of a 4:1 CASE statement.

Alternatively, if priority is important, you can restructure the code to deduce default cases and flatten the multiplexer. In this example, instead of IF cond1 THEN IF cond2, use IF (cond1 AND cond2) which performs the same function. In addition, examine whether the defaults are don't care cases. In this example, you can promote the last ELSIF cond6 statement to an ELSE statement if no other valid cases can occur.

Avoid unnecessary default conditions in your multiplexer logic to reduce the complexity and logic utilization required to implement your design.

## Degenerate Multiplexers

A degenerate multiplexer is a multiplexer in which not all of the possible cases are used for unique data inputs. The unneeded cases tend to contribute to inefficiency in the logic utilization for these multiplexers. You can recode degenerate multiplexers so they take advantage of the efficient logic utilization possible with full binary multiplexers.

The number of select lines in a binary multiplexer normally dictates the size of a multiplexer needed to implement the desired function. For example, the multiplexer structure represented in Figure 6–4 has four select lines capable of implementing a binary multiplexer with 16 inputs. However, the design does not use all 16 inputs, which makes this multiplexer a degenerate 16:1 multiplexer.

#### Example 6–43. VHDL CASE Statement Describing a Degenerate Multiplexer

```
CASE sel[3:0] IS

WHEN "0101" => z <= a;

WHEN "0111" => z <= b;

WHEN "1010" => z <= c;

WHEN OTHERS => z <= d;

END CASE;
```

Figure 6-4. Binary Degenerate Multiplexer



In the example in Figure 6–4, the first and fourth multiplexers in the top level can easily be eliminated because all four inputs to each multiplexer are the same value, and the number of inputs to the other multiplexers can be reduced, as shown in Figure 6–5.

Figure 6-5. Optimized Version of the Degenerate Binary Multiplexer



Implementing this version of the multiplexer still requires at least five 4-input LUTs, two for each of the remaining 3:1 multiplexers and one for the 2:1 multiplexer. This design selects an output from only four inputs, a 4:1 binary multiplexer can be implemented optimally in two LUTs, so this degenerate multiplexer tree reduces the efficiency of the logic.

You can improve logic utilization of this structure by recoding the select lines to implement a full 4:1 binary multiplexer. The code sample shown in Example 6–44 shows a recoder design that translates the original select lines into a signal z sel with binary encoding.

## Example 6-44. VHDL Recoder Design for Degenerate Binary Multiplexer

```
CASE sel[3:0] IS

WHEN "0101" => z_sel <= "00";

WHEN "0111" => z_sel <= "01";

WHEN "1010" => z_sel <= "10";

WHEN OTHERS => z_sel <= "11";

END CASE;
```

The code sample shown in Example 6–45 shows you how to implement the full binary multiplexer.

## Example 6-45. VHDL 4:1 Binary Multiplexer Design

```
CASE z_sel[1:0] IS

WHEN "00" => z <= a;

WHEN "01" => z <= b;

WHEN "10" => z <= c;

WHEN "11" => z <= d;

END CASE;
```

Use the new <code>z\_sel</code> control signal from the recoder design to control the 4:1 binary multiplexer that chooses between the four inputs <code>a</code>, <code>b</code>, <code>c</code>, and <code>d</code>, as illustrated in Figure 6–6. The complexity of the select lines is handled in the recoder design, and the data multiplexing is performed with simple binary select lines enabling the most efficient implementation.

Figure 6-6. Binary Multiplexer with Recorder



The design for the recoder can be implemented in two LUTs and the efficient 4:1 binary multiplexer uses two LUTs, for a total of four LUTs. The original degenerate multiplexer required five LUTs, so the recoded version uses 20% less logic than the original.

You can often improve the logic utilization of multiplexers by recoding the select lines into full binary cases. Although logic is required to perform the encoding, the overall logic utilization is often improved.

## Buses of Multiplexers

The inputs to multiplexers are often data input buses in which the same multiplexer function is performed on a set of data input buses. In these cases, any inefficiency in the multiplexer is multiplied by the number of bits in the bus. The issues described in the previous sections become even more important for wide multiplexer buses.

For example, the recoding of select lines into full binary cases detailed in the previous section can often be used in multiplexed buses. Recoding the select lines may need to be completed only once for all the multiplexers in the bus. By sharing the recoder logic among all the bits in the bus, you can greatly improve the logic efficiency of a bus of multiplexers.

The degenerate multiplexer in the previous section requires five LUTs to implement. If the inputs and output are 32 bits wide, the function could require  $32 \times 5$  or 160 LUTs for the whole bus. The recoder design uses only two LUTs, and the select lines only need to be recoded once for the entire bus. The binary 4:1 multiplexer requires two LEs per bit of the bus. The total logic utilization for the recoded version could be  $2 + (2 \times 32)$  or 66 LUTs for the whole bus, compared to 160 LUTs for the original version. The logic savings become more important with wide multiplexer buses.

Using techniques to optimize degenerate multiplexers, removing unneeded implicit defaults, and choosing the optimal DEFAULT or OTHERS case can play an important role when optimizing buses of multiplexers.

## Quartus II Software Option for Multiplexer Restructuring

Quartus II integrated synthesis provides the **Restructure Multiplexers** logic option that extracts and optimizes buses of multiplexers during synthesis. In certain situations, this option automatically performs some of the recoding functions described without changing the HDL code in your design. This option is on by default, when the Optimization technique is set to **Balanced** (the default for most device families) or set to **Area**.



For details, refer to the *Restructure Multiplexers* subsection in the *Quartus II Integrated Synthesis* chapter in volume 1 of the *Quartus II Handbook*.

## **Cyclic Redundancy Check Functions**

Cyclic redundancy check (CRC) computations are used heavily by communications protocols and storage devices to detect any corruption of the data. These functions are highly effective; there is a very low probability that corrupted data can pass a 32-bit CRC check.

CRC functions typically use wide XOR gates to compare the data. The way that synthesis tools flatten and factor these XOR gates to implement the logic in FPGA LUTs can greatly impact the area and performance results for the design. XOR gates have a cancellation property which creates an exceptionally large number of reasonable factoring combinations, so synthesis tools can not always choose the best result by default.

The 6-input ALUT in Stratix II devices has a significant advantage over 4-input LUTs for these designs. When properly synthesized, CRC processing designs can run at high speeds in Stratix II devices.

The following guidelines will help you improve the quality of results for CRC designs in Altera devices.

## If Performance is Important, Optimize for Speed

Synthesis tools flatten XOR gates to minimize area and depth of levels of logic. Synthesis tools such as Quartus II integrated synthesis target area optimization by default for these logic structures. Therefore, for more focus on depth reduction, set the synthesis optimization technique to speed.



Note that flattening for depth sometimes causes a significant increase in area.

## Use Separate CRC Blocks Instead of Cascaded Stages

Some designers optimize their CRC designs to use cascaded stages, for example 4 stages of 8 bits. In such designs, intermediate calculations are used as needed (such as the calculations after 8, 24, or 32 bits) depending on the data width. This design is not optimal in FPGA devices. The XOR cancellations that can be performed in CRC designs mean that the function does not require all the intermediate calculations to determine the final result. Therefore forcing the use of intermediate calculations increases the area required to implement the function, as well as increasing the logic depth because of the cascading. It is typically better to create full separate CRC blocks for each data width that you need in the design, then multiplex them together to choose the appropriate mode at a given time.

## Use Separate CRC Blocks Instead of Allowing Blocks to Merge

Synthesis tools often attempt to optimize CRC designs by sharing resources and extracting duplicates in usually two different CRC blocks because of the factoring options in the XOR logic. As addressed previously, the CRC logic allows significant reductions but this works best when each CRC function is optimized separately. Check for duplicate extraction behavior if you have different CRC functions that are driven by common data signals or that feed the same destination signals.

If you are having problems with quality of results and you see that two CRC functions are sharing logic, ensure that the blocks are synthesized independently using one of the following methodologies:

- Synthesize each CRC block as a separate project and then write a separate VQM or EDIF netlist file for each.
  - To create a VQM file using Quartus II integrated synthesis, on the Processing menu click Start, then click Start VQM Writer.
- Define each CRC block as a separate design partition in an incremental compilation design flow.
  - For details, refer to the Quartus II Incremental Compilation for Hierarchical & Team-Based Design chapter in volume 1 of the Quartus II Handbook.
- Use synthesis options to preserve the hierarchical boundary of the CRC block.
  - On the Assignments menu, click Assignment Editor. Set Preserve Hierarchical Boundary to Firm.

## Take Advantage of Latency if Available

If your design can use more than one cycle to implement the CRC functionality, adding registers and retiming the design can help reduce area, improve performance and reduce power utilization. If your synthesis tool offers a retiming feature (such as the Quartus II software **Perform gate-level register retiming** option), you can insert an extra bank of registers at the input and allow the retiming feature to move the registers for better results. You can also build the CRC unit half as wide and alternate between halves of the data in each clock cycle.

## Save Power by Disabling CRC Blocks When Not in Use

CRC designs are heavy consumers of dynamic power because the logic toggles whenever there is a change in the design. To save power, use clock enables to disable the CRC function for every clock cycle that the logic is not needed. Some designs don't check the CRC results for a few clock cycles while other logic is performed. It is valuable to disable the CRC function even for this short amount of time.

Use the Device Synchronous Load (sload) Signal to Initialize

The data in many CRC designs must be initialized to 1's before operation. If your target device supports the use of the sload signal, you should use it to set all the registers in your design to 1's before operation. To enable use of the sload signal, follow the coding guidelines presented in the "Secondary Register Control Signals Such as Clear & Clock Enable" on page 6–32 section. You can check the register equations in the Timing Closure Floorplan or the Chip Editor to ensure that the signal was used as expected.



If you must force a register implementation using an sload signal, you can use low-level device primitives as described in the *Introduction to Low-Level Primitives Design User Guide*.

## Conclusion

Because coding style and megafunction implementation can have such large effects on your design performance, it is important to match the coding style to the device architecture from the very beginning of the design process. To improve design performance and area utilization, take advantage of advanced device features, such as memory and DSP blocks, as well as the logic architecture of the targeted Altera device by following the coding recommendations presented in this chapter.



For additional optimization recommendations, refer to the *Area & Timing Optimization* chapter in volume 2 of the *Quartus II Handbook*.



# Section III. Synthesis

As programmable logic devices (PLDs) become more complex and require increased performance, advanced design synthesis has become an important part of the design flow. In the Quartus® II software you can use the Analysis & Synthesis module of the Compiler to analyze your design files and create the project database. You can also use other EDA synthesis tools to synthesize your designs, and then generate EDIF netlist files or VQM files that can be used with the Quartus II software. This section explains the options that are available for each of these flows, and how they are supported in the Quartus II, version 6.0 software.

This section includes the following chapters:

- Chapter 7, Quartus II Integrated Synthesis
- Chapter 8, Synplicity Synplify & Synplify Pro Support
- Chapter 9, Mentor Graphics Precision RTL Synthesis Support
- Chapter 10, Mentor Graphics LeonardoSpectrum Support
- Chapter 11, Synopsys Design Compiler FPGA Support
- Chapter 12, Analyzing Designs with Quartus II Netlist Viewers

The previously documented chapter, *Synopsys FPGA Compiler II BLIS & Quartus II LogicLock*<sup>TM</sup> *Design Flow*, has been removed from the Quartus II Handbook version 5.1.

Altera Corporation Section III-1

# $\textbf{Revision History} \qquad \text{The table below shows the revision history for Chapter 7 to 12}.$

| Chapter(s) | Date / Version       | Changes Made                                                                                                                                                                                                                                       |
|------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | May 2006 v6.0.0      | Updated for the Quartus II software version 6.0.0:  Added language support.  Added Quartus II Synthesis options.  Added information on setting other Quartus II options in HDL source code.                                                        |
|            | December 2005 v5.1.1 | Minor typographic update.                                                                                                                                                                                                                          |
|            | October 2005 v5.1.0  | <ul> <li>Updated for the Quartus II software version 5.1.</li> <li>Chapter 7 was formerly Chapter 8 in version 5.0.</li> </ul>                                                                                                                     |
|            | May 2005 v5.0.0      | <ul> <li>Chapter 8 was formerly Chapter 6 in version 4.2.</li> <li>Updated information.</li> <li>Updated figures.</li> <li>Restructured information.</li> <li>Renamed sections.</li> <li>New functionality for Quartus II software 5.0.</li> </ul> |
|            | Dec. 2004 v3.0       | <ul> <li>Chapter 7 was formerly Chapter 8 in version 4.1.</li> <li>Added documentation of incremental synthesis feature</li> <li>New functionality for Quartus II software version 4.2</li> </ul>                                                  |
|            | June 2004 v2.0       | <ul><li>Updates to tables, figures.</li><li>New functionality for Quartus II software version 4.1.</li></ul>                                                                                                                                       |
|            | Feb. 2004 v1.0       | Initial release.                                                                                                                                                                                                                                   |
| 8          | May 2006 v6.0.0      | Updated for the Quartus II software version 6.0.0:  Updated cross probling information.  Added NativeLink® integration information.  Added Synplify design flow support.  Added Altera megafunction guidelines and architecture-specific features. |
|            | December 2005 v5.1.1 | Minor typographic update.                                                                                                                                                                                                                          |
|            | October 2005 v5.1.0  | <ul> <li>Updated for the Quartus II software version 5.1.</li> <li>Chapter 8 was formerly chapter 9 in version 5.0.</li> </ul>                                                                                                                     |
|            | May 2005 v5.0.0      | Chapter 9 was formerly chapter 7 in version 4.2.                                                                                                                                                                                                   |
|            | Dec. 2004 v2.1       | <ul> <li>Chapter 8 was formerly Chapter 9 in version 4.1.</li> <li>Updated information.</li> <li>New functionality for Quartus II software version 4.2.</li> <li>Updated figure 8-1.</li> </ul>                                                    |
|            | June 2004 v2.0       | <ul><li>Updates to tables, figures.</li><li>New functionality for Quartus II software version 4.1.</li></ul>                                                                                                                                       |
|            | Feb. 2004 v1.0       | Initial release.                                                                                                                                                                                                                                   |

Section III-2 Altera Corporation

| Chapter(s) | Date / Version      | Changes Made                                                                                                                                                                                                      |
|------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9          | May 2006 v6.0.0     | Minor updates for the Quartus II software version 6.0.0.                                                                                                                                                          |
|            | October 2005 v5.1.0 | <ul> <li>Updated for the Quartus II software version 5.1.</li> <li>Chapter 9 was formerly Chapter 10 in version 5.0.</li> </ul>                                                                                   |
|            | May 2005 v5.0.0     | Chapter 10 was formerly chapter 8 in version 4.2.                                                                                                                                                                 |
|            | Dec. 2004 v2.1      | <ul> <li>Chapter 9 was formerly Chapter 10 in version 4.1.</li> <li>Updates to tables and figures.</li> <li>New functionality for Quartus II software version 4.2.</li> </ul>                                     |
|            | June 2004 v2.0      | <ul><li>Updates to tables and figures.</li><li>New functionality for Quartus II software version 4.1.</li></ul>                                                                                                   |
|            | Feb. 2004 v1.0      | Initial release.                                                                                                                                                                                                  |
| 10         | May 2006 v6.0.0     | Minor updates for the Quartus II software version 6.0.0.                                                                                                                                                          |
|            | October 2005 v5.1.0 | <ul> <li>Updated for the Quartus II software version 5.1.</li> <li>Chapter 10 was formerly chapter 11 in version 5.0.</li> </ul>                                                                                  |
|            | May 2005 v5.0.0     | Chapter 11 was formerly chapter 9 in version 4.2.                                                                                                                                                                 |
|            | Dec. 2004 v2.1      | <ul> <li>Chapter 10 was formerly Chapter 11 in version 4.1.</li> <li>Updated information.</li> <li>New functionality in Quartus II software version 4.2.</li> <li>Updated tables and figures.</li> </ul>          |
|            | June 2004 v2.0      | <ul><li>Updates to tables, and figures.</li><li>New functionality for Quartus II software version 4.1.</li></ul>                                                                                                  |
|            | Feb. 2004 v1.0      | Initial release.                                                                                                                                                                                                  |
| 11         | May 2006 v6.0.0     | Minor updates for the Quartus II software version 6.0.0.                                                                                                                                                          |
|            | October 2005 v5.1.0 | <ul> <li>Updated for the Quartus II software version 5.1.</li> <li>Chapter 11 was formerly chapter 13 in version 5.0.</li> </ul>                                                                                  |
|            | May 2005 v5.0.0     | Chapter 13 was formerly chapter 11 in version 4.2.                                                                                                                                                                |
|            | Dec. 2004 v1.1      | <ul> <li>Chapter 12 was formerly Chapter 13 in version 4.1.</li> <li>Updated information.</li> <li>New functionary for Quartus II software version 4.2.</li> <li>Moved figure 12-3 within the chapter.</li> </ul> |
|            | June 2004 v1.0      | Initial release.                                                                                                                                                                                                  |

Altera Corporation Section III–3

| Chapter(s) | Date / Version        | Changes Made                                                                                                                                                                                                            |
|------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12         | May 2006 v6.0.0       | Name changed to Analyzing Designs with the Quartus II Netlist Viewers. Updated for the Quartus II software version 6.0.0:  Updated GUI information.                                                                     |
|            | December 2005, v5.1.1 | Updated for version 5.1, including viewing inside device atoms, filter on bus index, display timing path in the RTL Viewer, state machine access from Tools menu, locate from state machines, and state encoding table. |
|            | October 2005 v5.1.0   | <ul> <li>Updated for the Quartus II software version 5.1.</li> <li>Chapter 12 was formerly chapter 14 in version 5.0.</li> </ul>                                                                                        |
|            | May 2005 v5.0.0       | Chapter 14 was formerly chapter 12 in version 4.2.                                                                                                                                                                      |
|            | Dec. 2004 v2.1        | <ul> <li>Chapter 13 was formerly Chapter 14 in version 4.1.</li> <li>Updates to tables and figures.</li> <li>New functionality for Quartus II software version 4.2.</li> </ul>                                          |
|            | June 2004 v 2.0       | <ul> <li>Updates to tables, and figures.</li> <li>New functionality for Quartus II software version 4.1.</li> </ul>                                                                                                     |
|            | Feb. 2004 v1.0        | Initial release.                                                                                                                                                                                                        |

Section III-4 Altera Corporation



# 7. Quartus II Integrated Synthesis

QII51008-6.0.0

## Introduction

As programmable logic designs become more complex and require increased performance, advanced synthesis has become an important part of the design flow. The Quartus<sup>®</sup> II software includes advanced integrated synthesis that fully supports VHDL and Verilog HDL, as well as Altera<sup>®</sup>-specific design entry languages, and provides options to control the synthesis process. With this synthesis support, the Quartus II software provides a complete, easy-to-use solution.

This chapter documents the design flow and language support in the Quartus II software. It explains how to improve and control your Quartus II synthesis results with incremental synthesis. Additionally, you can improve synthesis results with Quartus II synthesis options and by controlling the inference of architecture-specific megafunctions. This chapter also explains some of the node-naming conventions used during synthesis to help you better understand your synthesized design, and the messages issued during synthesis to improve your HDL code. Scripting techniques for applying all the options and settings described are also provided.

This chapter contains the following sections:

- Design Flow
- Language Support
- Incremental Synthesis
- Quartus II Synthesis Options
- Setting Other Quartus II Options in Your HDL Source Code
- Analyzing Synthesis Results
- VHDL & Verilog HDL Messages
- Node-Naming Conventions in Quartus II Integrated Synthesis
- Scripting Support

## **Design Flow**

The Quartus II Analysis & Synthesis process includes Quartus II integrated synthesis, which fully supports the Verilog HDL and VHDL languages as well as Altera-specific languages (refer to "Language Support" on page 7–5 for details), and supports a subset of the SystemVerilog language. This stage of the compilation flow performs logic synthesis to optimize design logic, and performs technology mapping to implement the design logic using device resources such as logic elements (LEs) or adaptive logic modules (ALMs). This stage also generates the single project database that integrates all the design files in a project (including any netlists from third-party synthesis tools).

You can use the Analysis & Synthesis stage of the Quartus II compilation to perform any of the following levels of analysis and synthesis:

- Analyze Current File—Parse the current design source file to check for syntax errors. This command does not report on many semantic errors that require further design synthesis. On the Processing menu, click Analyze Current File.
- Analysis & Elaboration—Check a design for syntax and semantic errors and perform elaboration. On the Processing menu, click Start, and then click Start Analysis & Elaboration.
- Analysis & Synthesis—Perform complete analysis and synthesis on a design, including technology mapping. On the Processing menu, point to Start, and then click Start Analysis & Synthesis. This is the most commonly used command and is part of the full compilation flow.

The Quartus II design and compilation flow using Quartus II integrated synthesis is made up of the following steps:

- 1. Create a project in the Quartus II software, and specify the general project information, including the top-level design entity name.
- 2. Create design files in the Quartus II software or with a text editor.
- 3. Add all design files to your Quartus II project using the **Files** page of the Settings dialog box.
- Specify compiler settings that control the compilation and optimization of the design during synthesis and fitting. For synthesis settings, refer to "Quartus II Synthesis Options" on page 7–20.
- 5. Compile the design in the Quartus II software. To synthesize the design, on the Processing menu, point to Start, and click **Start Analysis & Synthesis**.



On the Processing menu, click **Start Compilation** to run a complete compilation flow including placement, routing, creation of a programming file, and timing analysis.

6. After obtaining synthesis and place-and-route results that meet your needs, program the Altera device.

The software provides netlists that allow you to perform functional simulation and gate-level timing simulation in the Quartus II simulator or a third-party simulator, perform timing analysis in a third-party timing analysis tool in addition to the TimeQuest or Classic Timing Analyzer, and/or perform formal verification in a third-party formal verification tool. The Quartus II software also provides many additional analysis and debugging features.



For more information about creating a project, compilation flow, and other features in the Quartus II software, refer to the Quartus II Help. For an overall summary of Quartus II features, refer to the *Introduction to Quartus II Manual*.

Figure 7–1 shows the basic design flow using Quartus II integrated synthesis.

Formal Verification Using Source Code Verilog HDL VHDL AHDL BDF as Golden Netlist Functional/RTL Simulation Gate-Level Constraints Analysis & Synthesis Functional & Settings Simulation Post Synthesis Simulation File Internal (.vho/.vo) Synthesis Netlist Gate-Level Timing Timing Constraints Assembler Fitter Simulation & Settings Analyzer Post Place-and-Route Simulation File (.vho/.vo) Formal Verification Using VO as Timing & Area Revised Netlist No Requirements Post Satisfied? Place-and-Route Formal Verification File (.vo) Yes Configuration/ Programming Files (.sof/.pof) Configure/Program Device

Figure 7-1. Quartus II Design Flow Using Quartus II Integrated Synthesis

## Language Support

This section explains the Quartus II software's integrated synthesis support for HDL and schematic design entry. You can mix all supported languages, and netlists generated by third-party synthesis tools, in a single Quartus II project.

## Verilog HDL Support

The Quartus II Compiler's analysis and synthesis module supports the following Verilog HDL standards:

- Verilog-1995 (IEEE Standard 1364-1995)
- Verilog-2001 (IEEE Standard 1364-2001)
- SystemVerilog-2005 (IEEE Standard 1800-2005) (only certain constructs are supported)

Refer to the subsections that follow for more info about language support.



For complete information about specific syntax features and language constructs, refer to the Quartus II Help.

To specify a default Verilog HDL version for all files, perform the following steps:

- 1. On the Assignments menu, click **Settings**.
- In the Settings dialog box, under Category, expand Analysis & Synthesis Settings, and select Verilog HDL Input, then click OK.
- 3. On the **Verilog HDL Input** page, under **Verilog version**, select the appropriate Verilog version, then click **OK**.

You can also specify the Verilog HDL version for each design file using a synthesis directive. For details, refer to "Specifying Verilog & VHDL Versions for Each Design File" on page 7–24.

The Quartus II Compiler uses the Verilog-2001 standard by default.



The Verilog HDL code samples provided in this document follow the Verilog-2001 standard unless otherwise specified.

The Quartus II software support for Verilog HDL is case-sensitive in accordance with the Verilog HDL standard.

The Quartus II software supports the include compiler directive to include files with absolute paths (with either "/" or "\" as the separator), or relative paths (relative to project root or current file location). When

searching for a relative path, the Quartus II software first searches relative to the project directory. If the software cannot find the file, it then searches relative to the directory location of the file.

## Verilog-2001 Support

The Quartus II software does not support Verilog-2001 libraries and configurations.

## SystemVerilog Support

The Quartus II software supports the following SystemVerilog constructs:

- Built-in data types logic, bit, byte, shortint, longint, int
- Enumeration data types using enum (no support for enum methods)
- Structure data types using struct
- Unpacked and packed arrays (no support for packed arrays with more than one dimension)
- User-defined types using typedef (no support for global typedefs or forward type declarations)
- Coding constructs always comb, always latch, always ff
- Assignment operators +=, -=, \*=, /=, %=, &=, |=, ^=, <<=, >>=, <<<=, and >>>=
- Increment ++ and decrement --
- Assignment patterns (no support for patterns that specify default, member name, or type)
- Keywords unique and priority in case statements
- Default values for function/task arguments



Designs written to comply with the Verilog-2001 standard may not compile successfully using the SystemVerilog setting because the SystemVerilog standard adds a number of new reserved keywords. For a list of reserved words in each language standard, refer to the Quartus II Help.

## Verilog HDL Macros

The Quartus II software supports the compiler directive `define, in accordance with the Verilog HDL standard. The Quartus II software also provides an equivalent Verilog HDL macro that you can turn on or off via the GUI or from the command line.

## Specifying a Verilog Macro in the GUI

To specify a macro in the GUI, on the Assignments menu, click **Settings**. Under **Category**, expand **Analysis & Synthesis Settings** and click **Verilog HDL Input**. Under **Verilog HDL macro**, type the macro name in the **Setting** box, and click **Add**.

## Specifying a Verilog Macro on the Command Line

Type the command shown in Example 7–1 at the command prompt to specify a Verilog macro.

### Example 7–1. Command Syntax for Specifying a Verilog Macro

quartus\_map <Design name> --verilog\_macro= "<Macro Name>=<Macro Setting>" ←

For example, the command in Example 7–2 has the same effect as specifying `define a=2 in the Verilog HDL source code:

#### Example 7-2. Specifying a Verilog Macro a = 2

quartus map my design --verilog macro="a=2" ←

To specify multiple macros, you can repeat the option more than once, as in Example 7–3:

### Example 7–3. Specifying Verilog Macros a = 2 & a = 3

quartus map my design --verilog macro="a=2" --verilog macro="b=3" ←

## **VHDL Support**

The Quartus II Compiler's analysis and synthesis module supports the following VHDL standards:

- VHDL 1987 (IEEE Standard 1076-1987)
- VHDL 1993 (IEEE Standard 1076-1993)



For information about specific syntax features and language constructs, refer to the Quartus II Help.

To specify a default VHDL version for all files, perform the following steps:

1. On the Assignments menu, click **Settings**.

- 2. In the Settings dialog box, under Category, expand **Analysis & Synthesis Settings**, and select **VHDL Input**, then click **OK**.
- 3. On the **VHDL Input** page, under **VHDL version**, select the appropriate version, then click **OK**.
- 4. You can also specify the VHDL version for each design file using a synthesis directive.

For details, refer to "Specifying Verilog & VHDL Versions for Each Design File" on page 7–24. The Quartus II Compiler uses the VHDL 1993 standard by default.



The VHDL code samples provided in this document follow the VHDL 1993 standard.

### VHDL Libraries

The Quartus II software includes the standard IEEE libraries and a number of vendor-specific VHDL libraries. You can also create custom VHDL libraries to store your own VHDL design units.

The IEEE library includes the standard VHDL packages std\_logic\_1164, numeric\_std, numeric\_bit, and math\_real. The STD library is part of the VHDL language standard and includes packages standard (included in every project by default) and textio. For compatibility with older designs, the Quartus II software also supports the following vendor-specific packages and libraries:

- Synopsys packages such as std\_logic\_arith and std\_logic\_unsigned in the IEEE library
- Mentor Graphics<sup>®</sup> packages such as std\_logic\_arith in the ARITHMETIC library
- Altera primitive packages altera\_primitives\_components (for primitives such as GLOBAL and DFFE) and maxplus2 (for legacy support of MAX+PLUS® II primitives) in the ALTERA library
- Altera megafunction packages altera\_mf\_components and stratixgx\_mf\_components in the ALTERA\_MF library (for Altera-specific megafunctions including LCELL), and lpm\_components in the LPM library for library of parameterized modules (LPM) functions.



For a complete listing of library and package support, refer to the Quartus II Help.



Beginning with the Quartus II software version 5.1, you should import component declarations for Altera primitives such as GLOBAL and DFFE from the

altera\_primitives\_components package and not the altera mf components package.

To ensure that the software reads all associated project files, add each VHDL file to your Quartus II project. To add files to your project, on the Project menu, click **Add/Remove Files In Project**.



Beginning in the Quartus II software version 5.1, VHDL design files can be added to the project in any order.

By default, the Quartus II software compiles all VHDL files into the work library. If a VHDL file refers to a library that does not exist, or if the library does not contain a referenced design unit, then the software searches the work library. This default behavior allows the Quartus II software to compile most VHDL designs with minimal setup.

To compile your VHDL design files into specific libraries, you can specify a destination library for each design file in one of the following ways:

- In the **Settings** dialog box
- In the Quartus II Settings File (.qsf)
- With a Tcl command
- In the VHDL file itself, with a synthesis directive

When the Quartus II Compiler analyzes the file, it stores the analyzed design units in the file's destination library.



A VHDL design cannot contain two or more entities with the same name, even if they are compiled into separate custom libraries.

Specifying a Destination Library Name in the Settings Dialog Box To specify a library name for one of your VHDL files:

- 1. From the Assignments menu, choose **Settings**.
- 2. On the **Files** page of the **Settings** dialog box, specify the library name in the **File Name** list.
- 3. Click Properties.
- In the File Properties dialog box, from the Type list, select VHDL File.

- 5. Type the desired library name in the **Library** field.
- 6. Click **OK**.

# Specifying a Destination Library Name in the Quartus II Settings File or Using Tcl

You can specify the VHDL library name with the -library option to the VHDL\_FILE assignment in the Quartus II Setting File or with Tcl commands.

For example, the following Quartus II Settings File or Tcl assignment specifies that the Quartus II software analyze my\_file.vhd and store its contents (design units) in the VHDL library my\_lib.

## Example 7-4. Specifying a Destination Library Name

set\_global\_assignment VHDL\_FILE my\_file.vhd -library my\_lib

For more information about Tcl scripting, refer to "Scripting Support" on page 7–70.

### Specifying a Destination Library Name in Your VHDL File

You can use the library synthesis directive to specify a library name in your VHDL source file. This directive takes a single string argument: the name of the destination library. Specify the library directive in a VHDL comment prior to the context clause for a primary design unit (that is, a package declaration, an entity declaration, or a configuration), using one of the supported keywords for synthesis directives, that is, altera, synthesis, pragma, synopsys, or exemplar.

For more information about specifying synthesis directives, refer to "Synthesis Directives" on page 7–24.

The library directive overrides the default library destination work, the library setting specified for the current file through the Settings dialog box, an existing Quartus II Settings File setting, setting made through the Tcl interface, or any prior library directive in the current file. The directive remains effective until the end of the file or the next library synthesis directive.

Example 7–5 uses the library synthesis directive to create a library called **my\_lib** that contains the design unit my entity.

#### Example 7-5. Using the library Synthesis Directive

```
-- synthesis library my_lib
library ieee;
use ieee.std_logic_1164.all;
entity my_entity(...)
end entity my entity;
```



You can specify a single destination library for all the design units in a given source file by specifying the library name in the the **Settings** dialog box, editing the Quartus II Settings File, or using the Tcl interface. Using the library directive to change the destination VHDL library within a source file gives you the option to organizing the design units in a single file into different libraries, rather than just a single library.

The Quartus II software gives an error if you use the library directive within a design unit.

## **AHDL Support**

The Quartus II Compiler's analysis and synthesis module fully supports the Altera Hardware Description Language (AHDL).

AHDL designs use Text Design Files (.tdf). You can import AHDL Include Files (.inc) into a Text Design File with an AHDL include statement. Altera provides AHDL Include Files for all megafunctions shipped with the Quartus II software.



For information about specific syntax features and language constructs, refer to the Quartus II Help.



The AHDL language does not support the synthesis directives or attributes described in this chapter.

## **Schematic Design Entry Support**

The Quartus II Compiler's analysis and synthesis module fully supports Block Design Files (.bdf) for schematic design entry.

Use the Quartus II software's Block Editor to create and edit Block Design Files and open Graphic Design Files (.gdf) imported from the MAX+PLUS II software. Use the Symbol Editor to create and edit Block Symbol Files (.bsf) and open MAX+PLUS II Symbol Files (.sym). You can

read and edit these legacy MAX+PLUS II formats with the Quartus II Block and Symbol Editors; however, the Quartus II software saves them as BDF or BSF files.



For information about creating and editing schematic designs, refer to the Quartus II Help.



Schematic entry methods do not support the synthesis directives or attributes described in this chapter.

# Incremental Synthesis

The incremental synthesis feature in the Quartus II software manages a design hierarchy for incremental design by allowing you to divide the design into multiple partitions. Incremental synthesis ensures that when a design is compiled, only those partitions of the design that have been updated will be resynthesized, reducing synthesis time and runtime memory usage. You can change and resynthesize a design partition without affecting other design partitions, which means that node names are maintained during synthesis for all registered and combinational nodes in unchanged partitions.

Conventionally, a hierarchical design is flattened into a single netlist of logic gates before logic synthesis and technology mapping. However, incremental synthesis allows you to partition a hierarchical design along any of its hierarchical boundaries. The individual hierarchical partitions are synthesized and mapped separately by the Quartus II software. The hierarchical partitions are then combined—or merged—to form a flattened netlist for further stages of the Quartus II compilation flow, including fitting. The mapped netlist for each partition is stored by the Quartus II software. Therefore, if the source code for one partition changes during the design cycle, only the partition that changed is resynthesized during the next compilation of the design.

You can use incremental synthesis by itself, or use a full incremental compilation flow in which you also preserve the placement and potentially routing information for unchanged partitions.



This chapter describes incremental synthesis only. For information about the full incremental compilation flow, refer to the *Quartus II Incremental Compilation for Hierarchical & Team-Based Design* chapter in volume 1 of the *Quartus II Handbook*.

The flow chart in Figure 7–2 shows the steps in the incremental synthesis flow.



Figure 7–2. Summary of Design Flow Using Quartus II Incremental Synthesis Flow

## **Partitions for Incremental Synthesis**

A partition represents a portion of the design that you want to synthesize incrementally. Partitions must be bounded by hierarchical boundaries, and therefore, cannot be a portion of the logic within a hierarchical block. When a partition is declared, every hierarchical block within that partition becomes part of the same partition. You can create new partitions for hierarchical blocks within an existing partition, in which case the blocks designates as a new partition are no longer part of the higher-level partition.

In Figure 7–3, hierarchical entities B and F form partitions in the complete design, which is made up of entities A, B, C, D, E, and F. The shaded boxes in Representation A indicate design partitions in a "tree" representation of the hierarchy. In Representation B, the lower-level entities are represented inside of higher-level entities, and the partitions are illustrated with different colored shading. The top-level partition Top automatically contains the top-level entity in the design, and any logic that is not defined as part of another partition. The design file for the top-level may be just a wrapper for the hierarchical entities below it, or it may contain its own logic. In this example, the partition for top-level entity A also includes the logic in one of its lower-level entities, C. Because entity F is contained in its own partition, it is not treated as part of the top-level partition. Another separate partition, B, contains the logic in entities B, D, and E.

Partition Top

B

C

Partition B

Representation B

C

F

Partition F

Representation B

Figure 7–3. Partitions in a Hierarchical Design

## **Partitions for Preserving Hierarchical Boundaries**

Use partitions if you need to preserve hierarchical boundaries through the synthesis process. For example, if you are performing formal verification, you must use partitions to ensure that no optimizations occur across specific design hierarchies.

Follow the steps described in the next section, "Preparing a Design for Incremental Synthesis" on page 7–15, if you need to set up your design to preserve hierarchical boundaries during Quartus II synthesis. If desired, you can use partitions with full incremental compilation (instead of incremental synthesis only) to preserve boundaries throughout the entire compilation process.



Beginning with the Quartus II software version 6.0, Altera recommends using Design Partition assignments instead of the Preserve Hierarchical Boundary logic option, which may be removed in future versions of the Quartus II software.

## **Preparing a Design for Incremental Synthesis**

To set up your design with partitions for incremental synthesis, identify the design partitions and turn on incremental synthesis using the following steps:

- On the Processing menu, point to Start and click Start Analysis & Elaboration to elaborate the design, or perform any compilation flow that includes this step. This allows the Quartus II software to identify your design's hierarchy.
- Identify the partitions in your design by applying the PARTITION\_HIERARCHY assignment to the appropriate instances. You can do this using the list of instances under Compilation Hierarchy in the Project Navigator. Right-click on an instance in the Project Navigator and click Set as Design Partition.



An incremental compilation icon appears next to each instance that is set as a partition.

- On Assignments menu, click Settings. The Settings dialog box appears.
- On the Compilation Process Settings page of the Settings dialog box, select Incremental synthesis only in the Incremental compilation section.



When you specify your first partition, a dialog box appears asking whether you wish to enable incremental compilation. Click **Incremental synthesis only** to turn on incremental synthesis.

To remove an existing PARTITION\_HIERARCHY assignment with the GUI, right-click the instance in the **Project Navigator** and select **Set as Design Partition** to turn off the option.

## Synthesizing a Design Using Incremental Synthesis

Once incremental synthesis is enabled, it becomes the default compilation procedure under normal circumstances, that is, when you click **Start Compilation** from the Processing menu, or when you select **Start Compilation** in the toolbar.

During compilation, the software synthesizes each partition separately, and then merges the partitions to create a flattened netlist for further stages of the Quartus II compilation flow, including fitting.

For subsequent iterations of analysis and synthesis, the Quartus II software uses an internal checksum calculation to determine whether the file should be resynthesized. The software checks the contents of the source file, as well as the values of the synthesis and netlist optimization settings.



When you are using the full incremental compilation flow, changes in settings do not trigger automatic resynthesis of the design when you specify that you want to use an existing netlist. For more information about the differences between full incremental compilation and incremental synthesis, refer to the *Quartus II Incremental Compilation for Hierarchical & Team-Based Design* chapter in volume 1 of the *Quartus II Handbook*.

The Quartus II software resynthesizes only those partitions that contain changed source code, or changes to synthesis or netlist optimization settings. If you modify a file in the top-level partition, but none of the lower-level partitions are affected, the Quartus II software only resynthesizes the top-level partition.

The software always maintains the synthesis results for unchanged partitions, and merges newly synthesized partitions with unchanged partitions.

## Synthesizing Using the Synthesis & Merge Commands

If you compile your design using the individual compilation steps available from the Start submenu of the Processing menu or by selecting **Compilation Tool** from the Tools menu, use the separate synthesis and merge commands.

Once incremental synthesis is enabled, on the Processing menu, point to **Start** and click **Start Analysis & Synthesis** to separately synthesize each partition. You must then merge the partitions to create a flattened netlist for further stages of the Quartus II compilation flow, including fitting. On the Processing menu, point to **Start** and click **Start Partition Merge**. After each incremental iteration of analysis and synthesis, merge the newly synthesized partitions with the unchanged partitions.

## **Forcing Complete Resynthesis**

Because the incremental synthesis flow identifies changes to source code and assignments and resynthesizes only the partitions that have changed, you usually do not have to completely resynthesize all of your source files.

If you want to force complete resynthesis, from the **Incremental compilation** section of the **Compilation Process** page of the **Settings** dialog box, select **Off**. Then resynthesize your entire design, and turn on **Incremental synthesis only** again (if desired). Alternately, to save the extra synthesis run, you can make a small change and save at least one file in each design partition, so that the Quartus II software detects the changes and resynthesizes each partition on the next analysis and synthesis.

# Considerations & Restrictions When Using Incremental Synthesis

To use incremental synthesis effectively, there are some issues to consider when planning your design's structure. Additionally, there are restrictions when using incremental synthesis with other Quartus II features. This section provides information about the following considerations and restrictions:

- Hierarchical considerations
- Restrictions on megafunction partitions
- Resource balancing
- Back-annotating node locations using the Altera LogicLock<sup>™</sup> design methodology
- SignalTap<sup>®</sup> II logic analyzer

## Hierarchical Considerations

When planning a design, keep in mind the size and scope of each partition, and how likely it is that different parts of your design will change as your design develops.



For guidelines about design hierarchical partitioning, refer to the *Hierarchical Design Partitioning* section of the *Design Recommendations for Altera Devices* chapter in volume 1 of the *Quartus II Handbook*.

Observe the following important hierarchical design considerations:

 Register all inputs and outputs of each block. This helps avoid any delay penalty on signals that cross partition boundaries.



While this can be difficult in practice, greater adherence to this principle results in less timing degradation and area increase when using incremental flows. Registering lessens the need for the cross-partition optimizations that are prevented by partitioning.

Do not use tri-state signals or bidirectional ports on hierarchical boundaries unless they are directly connected to top-level pins. If you use boundary tri-states in a lower-level block, synthesis pushes the tri-states through the hierarchy to the top-level to take advantage of the tri-state drivers on the output pins of the device. Because this requires optimizing through hierarchies, lower-level boundary tri-state signals are restricted with a block-level or incremental design methodology.

Using incremental synthesis, internal tri-states are supported only when all the destination logic is contained in the same partition, in which case analysis and synthesis implements the internal tri-state signals using multiplexing logic. For bidirectional ports that feed a bidirectional pin at the top level, all the logic that forms the bidirectional I/O cell must reside in the same partition.

Remember that logic is not synthesized, or optimized, across partition boundaries, which means any constant value (e.g., signals set to GND) will not be propagated across partitions.

## Restrictions on Megafunction Partitions

The Quartus II software does not support partitions for megafunction instantiations. If you use the MegaWizard® Plug-In Manager to customize a megafunction variation, the MegaWizard-generated wrapper file instantiates the megafunction. You can create a partition for the MegaWizard-generated megafunction custom variation wrapper file.

The Quartus II software does not support the creation of a partition for inferred megafunctions (that is, in which the software uses a megafunction to implement logic in your design). If you have a module or entity for the logic that is inferred, you can create a partition for that hierarchy level in the design.

The Quartus II software does not support creation of a partition for any Quartus II internal hierarchy that is dynamically-generated during compilation to implement the contents of a megafunction.

## Resource Balancing

You may have to do some manual resource balancing across partitions. When using incremental synthesis, each partition is synthesized separately, with no data about the resources used in other partitions. This means device resources could be overused in the individual partitions during synthesis, and thus the design may not fit in the target device when the partitions are merged.

For example, in the regular synthesis flow, when DSP blocks or RAM blocks are overused, the Quartus II Compiler can perform resource balancing and convert some of the logic into regular logic cells, for example, LEs or adaptive logic modules (ALMs). Without data about resources used in other partitions, it is possible for the logic in each separate partition to maximize the use of a particular device resource such that the design does not fit once all the partitions are merged. In this case, you may be able to manually balance the resources by using the Quartus II synthesis options to control inference of megafunctions that use the DSP or RAM blocks.

Refer to "Megafunction Inference Control" on page 7–40 for more information about resource balancing. You can also use the MegaWizard Plug-In Manager to customize your RAM or DSP megafunctions to use regular logic instead of the dedicated hardware blocks.

For more tips on resource balancing and reducing resource utilization, refer to the appropriate section of the *Area & Timing Optimization* chapter in volume 2 of the *Quartus II Handbook*.

## Preserving Compilation Results

Altera recommends using full incremental compilation for top-down and bottom-up compilation flows where you wish to preserve placement and routing information and the performance of unchanged parts of your design. The full incremental compilation feature also allows you to export and import lower-level design files to enable team-based design flows or design flows where you need to optimize different blocks separately.

For more information about preserving results and exporting or importing design blocks using full incremental compilation, refer to the *Quartus II Incremental Compilation for Hierarchical & Team-Based Design* chapter in volume 1 of the *Quartus II Handbook*.

### OpenCore Plus MegaCore Functions

The circuitry involved in providing OpenCore® Plus MegaCore® functions is currently incompatible with incremental synthesis and full incremental compilation.

## Quartus II Synthesis Options

The Quartus II software offers a number of options to help you control the synthesis process and achieve the optimal results for your design. The "Setting Synthesis Options" on page 7–21 section describes the synthesis settings dialog box where you can set the most common global settings and options, and defines three types of synthesis options: Quartus II logic options, synthesis attributes, and synthesis directives. The other subsections describe the following common synthesis options in the Quartus II software, and provide HDL examples of how to use each option where applicable:

- Specifying Verilog & VHDL Versions for Each Design File
- Optimization Technique
- Speed Optimization Technique for Clock Domains
- PowerPlay Power Optimization
- State Machine Processing
- Manually Specifying State Assignments Using the syn\_encoding Attribute
- Manually Specifying Enumerated Types Using the enum\_encoding Attribute
- Preserve Hierarchical Boundary
- Restructure Multiplexers
- Power-Up Level
- Power-Up Don't Care
- Remove Duplicate Logic
- Remove Duplicate Registers
- Remove Redundant Logic Cells
- Preserve Registers
- Noprune Synthesis Attribute/Preserve Fanout Free Node
- Keep Combinational Node/Implement as Output of Logic Cell
- Maximum Fan-Out
- Megafunction Inference Control
- RAM Style & ROM Style—for Inferred Memory
- RAM Initialization File—for Inferred Memory
- Multiplier Style—for Inferred Multipliers
- Full Case
- Parallel Case
- Translate Off & On
- Ignore Translate Off
- Read Comments as HDL

For information about using other Quartus II synthesis attributes to make pin-related assignments and set other entity options (available only as logic options) in your Verilog HDL or VHDL code, refer to "Setting Other Quartus II Options in Your HDL Source Code" on page 7–52.

## **Setting Synthesis Options**

You can set synthesis options in the **Settings** dialog box, or with logic options in the Quartus II software, or you can use synthesis attributes and directives within the HDL source code.

## Analysis & Synthesis Page of the Settings Dialog Box

On the Assignments menu, click **Settings** to open the **Settings** dialog box. The **Analysis & Synthesis Settings** page allows you to set global synthesis options that apply to the entire project. These options are described in later subsections.

## Quartus II Logic Options

Quartus II logic options control many aspects of the synthesis and place-and-route process. To set logic options in the Quartus II graphical user interface, on the Tools menu, click **Assignment Editor**. You can also use a corresponding Tcl command. Quartus II logic options allow you to set instance or node-specific assignments without editing the source HDL code. Logic options can be used with all design entry languages supported by the Quartus II software.

## Synthesis Attributes

The Quartus II software supports synthesis attributes for Verilog HDL and VHDL, also commonly called pragmas. These attributes are not standard Verilog HDL or VHDL commands. They are used only by synthesis tools to control the synthesis process in a particular manner. Attributes always apply to a specific design element, and are applied in the HDL source code. Some synthesis attributes are also available as Quartus II logic options via the Quartus II user interface or with Tcl. Each attribute description in this chapter indicates whether there is a corresponding setting or logic option that can be set in the user interface; some attributes can be specified only with HDL synthesis attributes. Attributes specified in your HDL code are not visible in the user interface or in the Quartus II Settings File. Assignments or settings made through the Quartus II user interface, the Quartus II Settings File, or the Tcl interface take precedence over assignments or settings made with synthesis attributes in your HDL code.

The Verilog-2001, SystemVerilog, and VHDL language definitions provide specific syntax for specifying attributes. However in Verilog-1995 HDL, you must embed attribute assignments in comments. You can enter attributes in your code using the syntax in Examples 7–6, 7–7, and 7–8, where *<attribute>*, *<attribute type>*, *<value>*, *<object>*, and *<object type>* are variables, and the entry in brackets is optional. The examples in this chapter demonstrate each syntax form.



Verilog HDL is case-sensitive, therefore, synthesis attributes are also case sensitive.

### Example 7-6. Synthesis Attributes in Verilog-1995 HDL

Verilog-1995 comment-embedded attributes as shown in Example 7–6 must be used as a suffix to (that is, placed after) the declaration of an item and must appear before the semicolon when one is required.



You cannot use the open one-line comment in Verilog HDL when a semicolon is required at the end of the line because it is not clear to which HDL element the attribute applies. For example, you cannot make an attribute assignment such as reg r; // synthesis <a href="mailto:attribute">attribute</a> because the attribute could be read as part of the next line.

To apply multiple attributes to the same instance, separate the attributes with spaces, as follows:

```
//synthesis <attribute1> [ = <value> ] <attribute2> [ = <value> ]
```

For example, to set the maxfan attribute to 16 (Refer to "Maximum Fan-Out" on page 7–39 for details) and set the preserve attribute (Refer to "Preserve Registers" on page 7–36 for details) on a register called my\_reg, use the following syntax:

```
reg my_reg /* synthesis maxfan = 16 preserve */;
```

In addition to the synthesis keyword as shown above, the keywords pragma, synopsys, and exemplar are supported for compatibility with other synthesis tools. The keyword altera is also supported, which allows you to add synthesis attributes that will be recognized only by Quartus II integrated synthesis and not by other tools that recognize the same synthesis attribute.



Because formal verification tools do not recognize the exemplar, pragma, and altera keywords, avoid using these attribute keywords when using formal verification.

## Example 7-7. Synthesis Attributes in Verilog-2001 & SystemVerilog

```
(* <attribute> [ = <value> ] *)
```

Verilog-2001 attributes as shown in Example 7–7 must be used as a prefix to (that is, placed before) a declaration, module item, statement, or port connection, and used as a suffix to (that is, placed after) an operator or a Verilog HDL function name in an expression.



Because formal verification tools do not recognize the syntax, the Verilog-2001 attribute syntax is not supported when using formal verification.

To apply multiple attributes to the same instance, separate the attributes with commas, as shown in the following example:

```
(* <attribute1> [ = <value1>], <attribute2> [ = <value2> ] *)
```

For example, to set the maxfan attribute to 16 (Refer to "Maximum Fan-Out" on page 7–39 for details) and set the preserve attribute (Refer to "Preserve Registers" on page 7–36 for details) on a register called my\_reg, use the following syntax:

```
(* preserve, maxfan = 16 *) reg my_reg;
```

## Example 7-8. Synthesis Attributes in VHDL

```
attribute <attribute> : <attribute type> ;
attribute <attribute> of <object> : <object type> is <value>;
```

VHDL attributes, as shown in Example 7–8, declare the attribute type and then apply it to a specific object. For VHDL designs, all supported synthesis attributes are declared in the altera\_syn\_attributes package in the Altera library. You can call this library from your VHDL code to declare the synthesis attributes, as follows:

```
LIBRARY altera;
USE altera.altera_syn_attributes.all;
```

## Synthesis Directives

The Quartus II software supports synthesis directives, also commonly called compiler directives or pragmas. You can include synthesis directives in Verilog HDL or VHDL code as comments. These directives are not standard Verilog HDL or VHDL commands; however, synthesis tools use them to control the synthesis process in a particular manner. Other tools such as simulators ignore these directives and treat them as comments.

You can enter synthesis directives in your code using the following syntax shown in Examples 7–9 and 7–10, where *<directive>* and *<value>* are variables, and the entry in brackets is optional. The examples in this chapter demonstrate each syntax form.



Verilog HDL is case-sensitive, therefore, all synthesis directives are also case sensitive.

## Example 7-9. Synthesis Directives in Verilog HDL

```
// synthesis <directive> [ =<value> ]
    or
/* synthesis <directive> [ =<value> ] */
```

## Example 7-10. Synthesis Directives in VHDL

```
-- synthesis <directive> [ =<value> ]
```

In addition to the synthesis keyword shown above, the pragma, synopsys, and exemplar keywords are supported in both Verilog HDL and VHDL for compatibility with other synthesis tools. The keyword altera is also supported, which allows you to add synthesis directives that will be recognized only by Quartus II integrated synthesis and not by other tools that recognize the same synthesis directive.



Because formal verification tools ignore keywords exemplar, pragma, and altera, avoid using these directive keywords when you are using formal verification to prevent mismatches with the Quartus II results.

# Specifying Verilog & VHDL Versions for Each Design File

Your design may require you to override the default Verilog HDL or VHDL input versions (specified in the **Settings** dialog box) for some design files. This situation can occur when you want to take advantage of the features in a newer standard. If your Quartus II project contains older

design files that declare objects with these new keywords, you must use the VERILOG\_INPUT\_VERSION or VHDL\_INPUT\_VERSION synthesis directive in these files to override the default language version.

To control the language version used to process a specific file, use the following synthesis directives.

## Example 7-11. Verilog HDL Design Files

// synthesis VERILOG\_INPUT\_VERSION < language version >

The variable *<language version>* takes one of the following values:

- VERILOG 1995
- VERILOG 2001
- SYSTEMVERILOG\_2005

## Example 7-12. VHDL Design Files

--synthesis VHDL INPUT VERSION < language version >

The variable *<language version>* takes one of the following values:

- VHDL87
- VHDL93

When the software reads a VERILOG\_INPUT\_VERSION or VHDL\_INPUT\_VERSION synthesis directive, it changes the current language version as specified until the end of the file, or until it reaches the next VERILOG\_INPUT\_VERSION or VHDL\_INPUT\_VERSION directive.



You cannot change the language version in the middle of a Verilog module or VHDL design unit.

## **Optimization Technique**

The **Optimization Technique** logic option specifies the goal for logic optimization during compilation, that is, whether to attempt to achieve maximum speed performance or minimum area usage, or a balance between the two. Table 7–1 lists the settings for this logic option, which you can apply only to a design entity. You can also set this logic option for your whole project on the **Analysis & Synthesis Settings** page in the **Settings** dialog box.

| Table 7–1. Optimization Technique Settings |                                                                                                                                                                                                       |  |  |
|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Setting                                    | Description                                                                                                                                                                                           |  |  |
| Area                                       | The Compiler makes the design as small as possible to minimize resource usage                                                                                                                         |  |  |
| Speed                                      | The Compiler chooses a design implementation that has the fastest f <sub>MAX</sub>                                                                                                                    |  |  |
| Balanced (1)                               | The Compiler maps part of the design for area and part for speed, providing better area utilization than optimizing for speed, with only a slightly slower f <sub>MAX</sub> than optimizing for speed |  |  |

#### Note to Table 7-1:

(1) Balanced optimization technique is not supported for all device families.

The default setting varies by device family, and is generally optimized for the best area/speed trade-off. Results are design-dependent and vary depending on which device family you use.

# **Speed Optimization Technique for Clock Domains**

The **Speed Optimization Technique for Clock Domains** logic option specifies that all combinational logic in or between the specified clock domain(s) is optimized for speed.

When this option is set on a particular clock signal, all the logic in this clock domain is optimized for speed during synthesis. The remainder of the design in other clock domains is synthesized with the project-wide **Optimization Technique** that is set in the **Analysis & Synthesis Settings**. The option can also be set from one clock to another clock signal, in which case the logic in paths from registers the first clock domain to registers in the second clock domain are synthesized for speed. The advantage of using this option over the project-wide setting to optimize for speed is that there is less penalty to the area of the design, because a smaller part of the circuit is optimized for speed. This may also have a positive effect on the clock speed. This option also has an advantage over setting the **Optimization Technique** on a design entity, because that option forces the hierarchical blocks to be synthesized separately. Doing so may increase area and decrease performance due to the lack of optimizations across hierarchies. The **Speed Optimization Technique for Clock** 

**Domains** option does not treat hierarchical entities separately, and can optimize across hierarchical boundaries for logic within the same clock domain.

This option is useful if you have one or more clock domains that do not meet your timing requirements. When there are failing paths within a clock domain, the option can be set on the clock of that clock domain. When there are failing paths between clock domains, the option can be set from one clock domain to the other one.

This option is available for the following device families:

- Stratix® II
- Stratix II GX
- Stratix
- Stratix GX
- Cyclone<sup>TM</sup> II
- Cyclone
- HardCopy® II
- HardCopy Stratix
- MAX® II

## **PowerPlay Power Optimization**

This logic option controls the power-driven compilation setting of Analysis & Synthesis and determines how aggressively Analysis & Synthesis optimizes the design for power. On the Assignments menu, click Settings, under Category, click Analysis & Synthesis Settings, this displays the Analysis & Synthesis Settings page. The following three settings are available for the PowerPlay power optimization option:

- Off—Analysis & Synthesis does not perform any power optimizations.
- Normal Compilation—Analysis & Synthesis performs power optimizations, without reducing design performance.
- Extra Effort—Analysis & Synthesis performs additional power optimizations which may reduce design performance.

## **State Machine Processing**

This logic option specifies the processing style used to compile a state machine. Table 7–2 lists the settings for this logic option, which you can apply to a state machine name or to a design entity containing a state machine. You can also set this option for your whole project on the **Analysis & Synthesis Settings** page in the **Settings** dialog box.

| Table 7–2. State Machine Processing Settings |                                                                                                |  |  |  |
|----------------------------------------------|------------------------------------------------------------------------------------------------|--|--|--|
| Setting                                      | Description                                                                                    |  |  |  |
| Auto (Default)                               | Allows the Compiler to choose what it determines to be the best encoding for the state machine |  |  |  |
| Minimal Bits                                 | Uses the least number of bits to encode the state machine                                      |  |  |  |
| One-Hot                                      | Encodes the state machine in the one-hot style                                                 |  |  |  |
| User-Encoded                                 | Encodes the state machine in the manner specified by the user                                  |  |  |  |

The default state machine encoding, which is Auto, uses one-hot encoding for FPGA devices and minimal-bits encoding for CPLDs. These settings achieve the best results on average, but another encoding style might be more appropriate for your design, so this option allows you to control the state machine encoding.



Refer to the *Recommended HDL Coding Styles* chapter in the *Quartus II Handbook* for guidelines to ensure that your state machine is inferred and encoded correctly.

If the State Machine Processing logic option is set to **User-Encoded** in a Verilog HDL design, then the software uses the original design values for the state constants. For example, a Verilog HDL design can contain a declaration such as the following:

```
parameter S0 = 4'b1010, S1 = 4'b0101, ...
```

If the software infers states S0, S1,... it uses the encoding 4 'b1010, 4 'b0101,...

To assign your own state encoding with the **User-Encoded State Machine Processing option** in a VHDL design, you must apply specific binary encoding to the elements of an enumerated type because enumeration literals have no numeric values in VHDL. Use the syn\_encoding synthesis attribute to apply your encoding values. Refer to "Manually Specifying State Assignments Using the syn\_encoding Attribute" on page 7–29.

## Manually Specifying State Assignments Using the syn\_encoding Attribute

The Quartus II software infers state machines from enumerated types and automatically assigns state encoding based on "State Machine Processing" on page 7–28. However, in standard VHDL code, you cannot specify user encoding in the state machine description because enumeration literals have no numeric values in VHDL.

To assign your own state encoding for the **User-Encoded State Machine Processing** setting, you must use the syn\_encoding synthesis attribute to apply specific binary encodings to the elements of an enumerated type.

In Example 7–13, the  $syn_{encoding}$  attribute associates a binary encoding with the states in the enumerated type  $count_{state}$ . In this example, the states are encoded with the following values: zero = "11", one = "01", two = "10", three = "00".

## Example 7-13. Example of the syn\_encoding VHDL Attribute

```
ARCHITECTURE rtl OF my_fsm IS

TYPE count_state is (zero, one, two, three);

ATTRIBUTE syn_encoding : STRING;

ATTRIBUTE syn_encoding OF count_state : TYPE IS "11 01 10 00";

SIGNAL present_state, next_state : count_state;

BEGIN
```

# Manually Specifying Enumerated Types Using the enum\_encoding Attribute

By default, the Quartus II software one-hot encodes all user-defined Enumerated Types. With the <code>enum\_encoding</code> attribute, you can specify the logic encoding for an Enumerated Type and override the default one-hot encoding to improve the logic efficiency.



If an Enumerated Type represents the states of a state machine, using the <code>enum\_encoding</code> attribute to specify a manual state encoding prevents the Compiler from recognizing state machines based on the Enumerated Type. Instead, the Compiler processes these state machines as "regular" logic using the encoding specified by the attribute, and they are not listed as state machines in the Report window for the project. If you wish to control the encoding for a recognized state machine, use the State Machine Processing logic option and the <code>syn\_encoding</code> <code>synthesis</code> attribute.

To use the <code>enum\_encoding</code> attribute in a VHDL design file, associate the attribute with the Enumeration Type whose encoding you want to control. The <code>enum\_encoding</code> attribute must follow the Enumeration Type Definition but precede its use. In addition, the attribute value must be a string literal that specifies either an arbitrary user encoding or an <code>encoding</code> style of <code>"default"</code>, <code>"sequential"</code>, <code>"gray"</code>, or <code>"one-hot"</code>.

An arbitrary user encoding consists of a space-delimited list of encodings. The list must contain as many encodings as there are enumeration literals in your Enumeration Type. In addition, the encodings must all have the same length, and each encoding must consist solely of values from the std\_ulogic type declared by the std\_logic\_1164 package in the IEEE library. In the code fragment of Example 7–14, the enum\_encoding attribute specifies an arbitrary user encoding for the Enumeration Type fruit.

## Example 7-14. Specifying an Arbitrary User Encoding for Enumerated Type

```
type fruit is (apple, orange, pear, mango);
attribute enum_encoding : string;
attribute enum encoding of fruit : type is "11 01 10 00";
```

In this example, the enumeration literals are encoded as:

```
apple = "11"
orange = "01"
pear = "10"
mango = "00"
```

Sometimes you may wish to specify an encoding style, rather than a manual user encoding, especially when the Enumeration Type has a large number of enumeration literals. The Quartus II software can implement Enumeration Types with four different encoding styles:

- "default"—Use an encoding based on the number of enumeration literals in the Enumeration Type. If there are fewer than 5 literals, use the "sequential" encoding. If there are more than five but fewer than 50 literals, use a "one-hot" encoding. Otherwise, use a "gray" encoding.
- "sequential"—Use a binary encoding in which the first enumeration literal in the Enumeration Type has encoding 0, the second 1, and so on.
- "gray"—Use an encoding in which the encodings for adjacent enumeration literals differ by exactly one bit.
- "one-hot"—The default encoding style requiring *N* bits, where *N* is the number of enumeration literals in the Enumeration Type.

Observe that in Example 7–14, the enum\_encoding attribute manually specified a gray encoding for the Enumeration Type fruit. This example could be written more concisely by specifying the "gray" encoding style instead of a manual encoding, as shown in Example 7–15.

## Example 7-15. Specifying the "gray" Encoding Style or Enumeration Type

```
type fruit is (apple, orange, pear, mango);
attribute enum_encoding : string;
attribute enum encoding of fruit : type is "gray";
```

## **Preserve Hierarchical Boundary**

This logic option allows you to preserve the hierarchical boundaries between design entities. Beginning with the Quartus II software version 6.0, Altera recommends using design partitions with incremental synthesis or full incremental compilation instead of using the **Preserve Hierarchical Boundary** logic option.



The **Preserve Hierarchical Boundary** logic option may be removed in future versions of the Quartus II software.

Refer to "Partitions for Preserving Hierarchical Boundaries" on page 7–14 for details about using design partitions.

## **Restructure Multiplexers**

This option specifies whether the Quartus II software should extract and optimize buses of multiplexers during synthesis.

This option is useful if your design contains buses of fragmented multiplexers. This option restructures multiplexers more efficiently for area, allowing the design to implement multiplexers with a reduced number of LEs or ALMs. This option is available for Stratix II, Stratix, Stratix GX, Cyclone II, Cyclone, and MAX II devices.

The **Restructure Multiplexers** option works on entire trees of multiplexers. Multiplexers may arise in different parts of the design through Verilog HDL or VHDL constructs such as the "if," "case," or "?:" statements. When multiplexers from one part of the design feed multiplexers in another part of the design, trees of multiplexers are formed. Multiplexer buses occur most often as a result of multiplexing together vectors in Verilog HDL, or STD\_LOGIC\_VECTOR signals in VHDL. The **Restructure Multiplexers** option identifies buses of multiplexer trees that have a similar structure. When it is turned on, the

**Restructure Multiplexers** option optimizes the structure of each multiplexer bus for the target device to reduce the overall amount of logic used in the design.

Results of the multiplexer optimizations are design dependent, but area reductions as high as 20% are possible. The option may negatively affect your design's  $f_{MAX}$ .

Table 7–3 lists the settings for the logic option, which you can apply only to a design entity. You can also specify this option on the **Analysis & Synthesis Settings** page in the **Settings** dialog box for your whole project.

| Table 7–3. Restructure Multiplexers Settings |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Setting                                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| On                                           | Enables multiplexer restructuring to minimize your design area. This setting may reduce the $f_{\mbox{\scriptsize MAX}}.$                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| Off                                          | Disables multiplexer restructuring to avoid possible reductions in f <sub>MAX</sub> .                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| Auto (Default)                               | Allows the Compiler to determine whether to enable the option based on your other Quartus II synthesis settings. The option is On when the <b>Optimization Technique</b> option is set to <b>Area</b> or <b>Balanced</b> , and Off when the <b>Optimization Technique</b> option is <b>Speed</b> . (Note that since the default Optimization Technique is Balanced for many device families including Stratix and Stratix II devices, this option is turned on by default for those families.) |  |  |  |

After you have compiled your design, you can view multiplexer restructuring information in the **Multiplexer Restructuring Statistics** report in the **Multiplexer Statistics** folder under **Analysis & Synthesis Optimization Results** in the **Analysis & Synthesis** section of the **Compilation Report**. Table 7–4 describes the information that is listed in the **Multiplexer Restructuring Statistics** report table for each bus of multiplexers.

| Table 7–4. Multiplexer Information in the Multiplexer Restructuring Statistics Report (Part 1 of 2) |                                                                                                                                                                                                                     |  |  |  |
|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Heading                                                                                             | Description                                                                                                                                                                                                         |  |  |  |
| Multiplexer Inputs                                                                                  | The number of different choices that are multiplexed together.                                                                                                                                                      |  |  |  |
| Bus Width                                                                                           | The width of the bus in bits.                                                                                                                                                                                       |  |  |  |
| Baseline Area                                                                                       | An estimate of how many logic cells are needed to implement the bus of multiplexers (before any multiplexer restructuring takes place). This estimate can be used to identify any large multiplexers in the design. |  |  |  |
| Area if Restructured                                                                                | An estimate of how many logic cells are needed to implement the bus of multiplexers if <b>Multiplexer Restructuring</b> is applied.                                                                                 |  |  |  |

| Table 7–4. Multiplexer Information in the Multiplexer Restructuring Statistics Report (Part 2 of 2) |                                                                                                                                                                                                                                                                                            |  |  |  |
|-----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Heading                                                                                             | Description                                                                                                                                                                                                                                                                                |  |  |  |
| Saving if Restructured                                                                              | An estimate of how many logic cells are saved if <b>Multiplexer Restructuring</b> is applied.                                                                                                                                                                                              |  |  |  |
| Registered                                                                                          | An indication of whether registers are present on the multiplexer outputs.  Multiplexer Restructuring uses the secondary control signals of a register (such as synchronous clear and synchronous-load) to further reduce the amount of logic needed to implement the bus of multiplexers. |  |  |  |
| Example Multiplexer<br>Output                                                                       | The name of one of the multiplexers' outputs. This name can help determine where in the design the multiplexer bus originated.                                                                                                                                                             |  |  |  |



For more information about optimizing for multiplexers, refer to the *Multiplexers* section of the *Design Recommendations for Altera Devices* chapter in volume 1 of the *Quartus II Handbook*.

## **Power-Up Level**

This logic option causes a register (flip-flop) to power up with the specified logic level, either **High** (1) or **Low** (0). Registers in the device core hardware power up to 0 in all Altera devices. For the register to power up with a logic level **High** specified using this option, the Compiler performs an optimization referred to as NOT-gate push back on the register. NOT-gate push back adds an inverter to the input and the output of the register so that the reset and power-up conditions will appear to be high and the device operates as expected. The register itself actually still powers up low, but the register output is inverted so the signal arriving at all destinations is high.

This option supports wildcard characters, and you can apply this option to any register or to a pin with the logic configurations described in the following list:

- If this option is turned on for an input pin, the option is transferred automatically to the register that is driven by the pin if the following conditions are present:
  - There is no logic, other than inversion, between the pin and the register
  - The input pin drives the data input of the register
  - The input pin does not fan out to any other logic

- If this option is turned on for an output or bidirectional pin, it is transferred automatically to the register that feeds the pin, if the following conditions are present:
  - There is no logic, other than inversion, between the register and the pin
  - The register does not fan out to any other logic

For VHDL, Quartus II integrated synthesis also reads default values for registered signals defined in the VHDL code and converts the default values into Power-Up Level settings. That way, the synthesized behavior matches the power-up state of the VHDL code during a functional simulation. The Quartus II software, like most synthesis tools, does not synthesize variables that are assigned values in Verilog HDL initial blocks into power-up conditions. Initial blocks are generally not synthesized.



For more information about NOT gate push-back, the power-up states for Altera devices, and how power-up level is affected by set and reset control signals, refer to *Recommended HDL Coding Styles* in volume 1 of the *Quartus II Handbook*.

## **Power-Up Don't Care**

This logic option causes registers to power up with the logic level most appropriate for the design. This option allows the Compiler to change the power-up condition of a register to, for example, minimize your design's area usage. This option is turned on by default.

For example, a register may have its D input tied to VCC. If you turn this option off, the register powers up low even though it goes high at the first clock signal. If you turn this option on, the Compiler sets the power-up value of the register to high and, therefore, can eliminate the register and connect the output of the register to VCC. If the Compiler performs this type of optimization, it issues a message indicating it is doing so.

This project-wide option does not apply to registers that have the **Power-Up Level** logic option set to either **High** or **Low**.

# Remove Duplicate Logic

If you turn on this logic option, the Compiler removes logic that is identical to other logic in the design. If two functions generate the same logic, the Compiler removes the second one, and the first one fans out to the second one's destinations. Additionally, if the deleted logic function has different logic option assignments, the Compiler ignores them. This option is turned on by default.

When turned on, this option also removes all duplicate registers in the same way as does the **Remove Duplicate Registers** option. If you do not want the Compiler to remove certain registers when this option is turned on, turn off the **Remove Duplicate Registers** option for those registers. For more details, refer to Table 7–5.

Even if you turn this option on, the Compiler does not remove duplicate logic that you inserted deliberately. If a function's output feeds an LCELL buffer, the Compiler always treats it as a unique signal and the **Remove Duplicate Logic** option does not apply (that is, the Compiler does not remove an LCELL buffer if you turn on this option).

## **Remove Duplicate Registers**

If you turn on this logic option, the Compiler removes registers that are identical to another register. If two registers generate the same logic, the Compiler removes the second one, and the first one fans out to the second one's destinations. Also, if the deleted register has different logic option assignments, the Compiler ignores them. This option is turned on by default.

The Compiler recognizes this option only if you turned on the **Remove Duplicate Logic** option. When turned on, the **Remove Duplicate Logic** option also removes duplicate registers. Therefore, you should use this option only if you want to prevent the Compiler from removing duplicate registers that you have used deliberately. That is, you should use this option only with the **Off** setting. Refer to Table 7–5. You can apply this option to an individual register or a design entity that contains registers.

| Table 7–5. Settings for Remove Duplicate Logic & Remove Duplicate Registers |                                       |                                                                                                                                                                                              |  |  |  |
|-----------------------------------------------------------------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Remove Duplicate<br>Logic Setting                                           | Remove Duplicate<br>Registers Setting | Description                                                                                                                                                                                  |  |  |  |
| On (Default)                                                                | On (Default)                          | Removes logic (including registers) if it is identical to other logic in the design.                                                                                                         |  |  |  |
| On                                                                          | Off                                   | Preserves all registers for which the <b>Remove Duplicate Registers</b> option is turned off. Removes logic (including any other registers) if it is identical to other logic in the design. |  |  |  |
| Off                                                                         | On or Off                             | Preserves duplicate logic and registers.                                                                                                                                                     |  |  |  |

# Remove Redundant Logic Cells

This logic option removes redundant LCELL primitives or WYSIWYG cells. If you turn on this option, the Compiler optimizes a circuit for area and speed. The project-wide option is turned off by default.

## **Preserve Registers**

This attribute and logic option direct the Compiler not to minimize or remove a specified register during synthesis optimizations or register netlist optimizations. Optimizations can eliminate redundant registers and registers with constant drivers; this option prevents a register from being reduced to a constant or merged with a duplicate register. This option can preserve a register so you can observe it during simulation or with the SignalTap II logic analyzer. Additionally, it can preserve registers if you are creating a preliminary version of the design in which secondary signals are not specified. You can also use the attribute to preserve a duplicate of an I/O register so that one copy can be placed in an I/O cell and the second can be placed in the core. By default, the software may remove one of the two duplicate registers in this case; the preserve attribute can be added to both registers to prevent this.



This option cannot preserve registers that have no fan-out. To prevent the removal of registers with no fanout, refer to "Noprune Synthesis Attribute/Preserve Fanout Free Node" on page 7–37.



The Preserve Registers attribute prevents a register from being inferred as a state machine.

You can set the **Preserve Registers** logic option in the Quartus II GUI or you can set the preserve attribute in your HDL code as shown in Example 7–16, 7–17, and 7–18. In the examples, the my\_reg register is preserved.



In addition to preserve, the Quartus II software supports the syn\_preserve attribute name for compatibility with other synthesis tools.

### Example 7–16. Verilog HDL Example of a preserve Attribute

reg my\_reg /\* synthesis preserve = 1 \*/;

### Example 7–17. Verilog-2001 Example of a syn\_preserve Attribute

(\* syn preserve = 1 \*) reg my reg;



The " = 1" after the "preserve" in Example 7–16 and Example 7–17 is optional, because the assignment uses a default value of 1 when it is specified.

## Example 7-18. VHDL Example of a preserve Attribute

```
signal my_reg : stdlogic;
attribute preserve : boolean;
attribute preserve of my reg : signal is true;
```

## Noprune Synthesis Attribute/Preserve Fanout Free Node

This synthesis attribute and corresponding logic option direct the Compiler to preserve a fanout free register through the entire compilation flow. This is different from the Preserve Registers option, which prevents a register from being reduced to a constant or merged with a duplicate register. Standard synthesis optimizations remove nodes that do not directly or indirectly feed a top-level output pin. This option can retain a register so you can observe it in the Simulator or the SignalTap II logic analyzer. Additionally, it can retain registers if you are creating a preliminary version of the design in which the registers' fanout logic is not specified.

You can set the **Preserve Fanout Free Node logic** option in the Quartus II GUI, or you can set the noprune attribute in your HDL code as shown in Example 7–19, Example 7–20, and Example 7–21. In these examples, the my reg register is preserved.



You must use the noprune attribute instead of the logic option if the register has no immediate fanout in its module or entity. If you do not use the synthesis attribute, registers with no fanout are removed (or "pruned") during analysis and elaboration before the logic synthesis stage applies any logic options. If the register has no fanout in the full design, but has fanout within its module or entity, then you can use the logic option to retain the register through compilation.



The attribute name syn\_noprune is supported for compatibility with other synthesis tools.

## Example 7–19. Verilog HDL Example of a noprune Attribute

```
reg my reg /* synthesis noprune = 1 */;
```

## Example 7–20. Verilog-2001 Example of a noprune Attribute

```
(* noprune = 1 *) reg my_reg;
```

#### Example 7-21. VHDL Example of a noprune Attribute

```
signal my_reg : stdlogic;
attribute noprune: boolean;
attribute noprune of my_reg : signal is true;
```

## Keep Combinational Node/Implement as Output of Logic Cell

This synthesis attribute and corresponding logic option direct the Compiler to keep a wire or combinational node through logic synthesis minimizations and netlist optimizations. A wire that has a keep attribute or a node that has the **Implement as Output of Logic Cell** logic option applied becomes the output of a logic cell in the final synthesis netlist, and the name of the logic cell will be the same as the name of the wire or node. You can use this directive to make combinational nodes visible to the SignalTap II logic analyzer.



The option cannot keep nodes that have no fan-out. Node names cannot be maintained for wires with tri-state drivers, or if the signal feeds a top-level pin of the same name (in this case the node name is changed to a name such as <net name>~req0).

You can set the **Implement as Output of Logic Cell** logic option in the Quartus II GUI, or you can set the keep attribute in your HDL code as shown in Example 7–22, Example 7–23, and Example 7–24. In these examples, the Compiler maintains the node name my wire.



In addition to keep, the Quartus II software supports the syn\_keep attribute name for compatibility with other synthesis tools.

#### Example 7-22. Verilog HDL Example of a keep Attribute

```
wire my wire /* synthesis keep = 1 */;
```

## Example 7-23. Verilog-2001 Example of a keep Attribute

```
(* keep = 1 *) wire my_wire;
```

#### Example 7–24. VHDL Example of a syn keep Attribute

```
signal my_wire: bit;
attribute syn_keep: boolean;
attribute syn_keep of my_wire: signal is true;
```

## Maximum Fan-Out

This attribute and logic option directs the Compiler to control the number of destinations fed by a node. The Compiler duplicates a node and splits its fan-out until the individual fan-out of each copy falls below the maximum fan-out restriction. You can apply this option to a register or a logic cell buffer. You can also use this option to reduce the load of critical signals, which can improve performance. You can use this option to instruct the Compiler to duplicate (or replicate) a register that feeds nodes in different locations on the target device. Duplicating the register may allow the Fitter to place these new registers closer to their destination logic, minimizing routing delay.

This option is available for all devices supported in the Quartus II software except MAX® 3000, MAX 7000, FLEX  $10K^{\otimes}$ , ACEX® 1K, and Mercury devices. The maximum fan-out constraint is honored as long as the following conditions are met:

- The node is not part of a cascade, carry, or register cascade chain
- The node does not feed itself
- The node feeds other logic cells, DSP blocks, RAM blocks and/or pins through data, address, clock enable, etc, but not through any asynchronous control ports (such as asynchronous clear)

The software does not create duplicate nodes in these cases either because there is no clear way to duplicate the node, or, in the third condition above where asynchronous control signals are involved, to avoid the possible situation that small differences in timing could produce functional differences in the implementation. If the constraint cannot be applied because one of these conditions is not met, the Quartus II software issues a message indicating that it ignored maximum fan-out assignment.



If you have enabled any of the Quartus II netlist optimizations that affect registers, add the preserve attribute to any registers to which you have set a maxfan attribute. The preserve attribute ensures that the registers are not affected by any of the netlist optimization algorithms such as register retiming.



For details about netlist optimizations, refer to the *Netlist Optimization & Physical Synthesis* chapter in volume 2 of the *Quartus II Handbook*.

You can set the **Maximum Fan-Out** logic option in the Quartus II GUI, and this option supports wildcard characters. You can also set the maxfan attribute in your HDL code as shown in Example 7–25, 7–26, and 7–27. In these examples, the Compiler duplicates the clk\_gen register, so its fan-out is not greater than 50.



In addition to maxfan, the Quartus II software supports the syn\_maxfan attribute name for compatibility with other synthesis tools.

## Example 7–25. Verilog HDL Example of a syn\_maxfan Attribute

```
reg clk_gen /* synthesis syn_maxfan = 50 */;
```

### Example 7–26. Verilog-2001 Example of a maxfan Attribute

```
(* maxfan = 50 *) req clk qen;
```

## Example 7-27. VHDL Example of a maxfan Attribute

```
signal clk_gen : stdlogic;
attribute maxfan : signal ;
attribute maxfan of clk gen : signal is 50;
```

## **Megafunction Inference Control**

The Quartus II Compiler automatically recognizes certain types of HDL code and infers the appropriate megafunction The software uses the Altera megafunction code when compiling your design even when you do not specifically instantiate the megafunction. The software infers megafunctions to take advantage of logic that is optimized for Altera devices. The area and performance of such logic may be better than the results obtained by inferring generic logic from the same HDL code.

Additionally, you must use megafunctions to access certain architecture-specific features, such as RAM, digital signal processing (DSP) blocks, and shift registers, that generally provide improved performance compared with basic logic elements.



For details on coding style recommendations when targeting megafunctions in Altera devices, refer to the *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook*.

The Quartus II software provides options to control the inference of certain types of megafunctions, as described in the following sub-sections.

### Multiply-Accumulators & Multiply-Adders

Use the **Auto DSP Block Replacement** logic option to control DSP block inference for multiply-accumulations and multiply-adders. This option is turned on by default. To disable inference, turn off this option for your

whole project on the **Analysis & Synthesis Settings** page of the **Settings** dialog box, or disable the option for a specific block with the **Assignment Editor**.



Any registers that the software maps to the altmult\_accum and altmult\_add megafunctions and places in DSP blocks are not available in the Simulator because their node names do not exist after synthesis.

## Shift Registers

Use the Auto Shift Register Replacement logic option to control shift register inference. This option is turned on by default. To disable inference, turn off this option for your whole project on the Analysis & Synthesis Settings page of the Settings dialog box, or for a specific block with the Assignment Editor. The software may not infer small shift registers because small shift registers typically do not benefit from implementation in dedicated memory. However, you can use the Allow Any Shift Register Size for Recognition logic option to instruct synthesis to infer a shift register even when its size is considered too small.



The registers that the software maps to the altshift\_taps megafunction and places in RAM are not available in the Simulator because their node names do not exist after synthesis.

The Auto Shift Register Replacement logic option is turned off automatically when a formal verification tool is selected in the EDA Tool Settings. The software issues a warning and lists shift registers that would have been inferred if no formal verification tool was selected in the compilation report. To allow the use of a megafunction for the shift register in the formal verification flow, you can either instantiate a shift register explicitly using the MegaWizard Plug-in Manager or black-box the shift register in a separate entity/module.

### RAM & ROM

Use the **Auto RAM Replacement** and **Auto ROM Replacement** logic options to control RAM and ROM inference, respectively. These options are turned on by default. To disable inference, turn off the appropriate option for your whole project on the **Analysis & Synthesis Settings** page of the **Settings** dialog box, or disable the option for a specific block with the **Assignment Editor**.

The software may not infer very small RAM or ROM blocks because very small memory blocks can typically be implemented more efficiently by using the registers in the logic. However, you can use the **Allow Any RAM Size for Recognition** and **Allow Any ROM Size for Recognition** logic options to instruct synthesis to infer a memory block even when its size is considered too small.



The **Auto ROM Replacement** logic option is automatically turned off when a formal verification tool is selected in the **EDA Tool Settings** page. A warning is issued and a report panel lists ROMs that would have been inferred if no formal verification tool was selected. To allow the use of a megafunction for the shift register in the formal verification flow, you can either instantiate a ROM explicitly using the MegaWizard Plug-in Manager or create a black box the ROM in a separate entity/module.

Although formal verification tools do not support inferred RAM blocks, because of the importance of inferring RAM in many designs, the **Auto RAM Replacement** logic option remains on when a formal verification tool is selected in the **EDA Tool Settings** page. The Quartus II software automatically black boxes any module or entity that contains a RAM block that is inferred. The software issues a warning and lists the black box that is created in the compilation report. This block box allows formal verification tools to proceed; however, the entire module or entity containing the RAM cannot be verified in the tool. Altera recommends explicitly instantiating RAM blocks in separate modules or entities so that as much logic as possible can be verified by the formal verification tool.

# RAM Style & ROM Style—for Inferred Memory

These attributes specify the implementation for an inferred RAM or ROM block. You can specify the type of TriMatrix™ embedded memory block to be used, or specify the use of standard logic cells (LEs or ALMs). The attributes are supported only for device families with TriMatrix embedded memory blocks.

The ramstyle and romstyle attributes take a single string value. The values "M512", "M4K", and "M-RAM" indicates the type of memory block to use for the inferred RAM or ROM. The value "logic" indicates that the RAM or ROM should be implement in regular logic rather than dedicated memory blocks. You can set the attribute on a module or entity, in which case it specifies the default implementation style for all inferred memory blocks in the immediate hierarchy. You can also set the attribute on a specific signal (VHDL) or variable (Verilog HDL) declaration, in which case it specifies the preferred implementation style for that specific memory, overriding the default implementation style.



If you specify a value of "logic", the memory still appears as a RAM or ROM block in the RTL Viewer, but it is converted to regular logic during a later synthesis step.



In addition to ramstyle and romstyle, the Quartus II software supports the syn\_ramstyle attribute name for compatibility with other synthesis tools.

Example 7–28, 7–29, and 7–30 specify that all memory in the module or entity my\_memory\_blocks should be implemented using a specific type of block.

# Example 7–28. Verilog-1995 Example of Applying a romstyle Attribute to a Module Declaration module my memory blocks (...) /\* synthesis romstyle = "M4K" \*/

# Example 7-29. Verilog-2001 Example of Applying a ramstyle Attribute to a Module Declaration (\* ramstyle = "M512" \*) module my memory blocks (...);

## Example 7-30. VHDL Example of Applying a romstyle Attribute to an Architecture

```
architecture rtl of my_ my_memory_blocks is
attribute romstyle : string;
attribute romstyle of rtl : architecture is "M-RAM";
begin
```

Example 7–31, 7–32, and 7–33 specify that the inferred memory my\_ram or my\_rom should be implemented using regular logic instead of a TriMatrix memory block.

# Example 7-31. Verilog-1995 Example of Applying a syn\_ramstyle Attribute to a Variable Declaration reg [0:7] my\_ram[0:63] /\* synthesis syn\_ramstyle = "logic" \*/;

# Example 7–32. Verilog-2001 Example of Applying a romstyle Attribute to a Variable Declaration (\* romstyle = "logic" \*) reg [0:7] my\_rom[0:63];

## Example 7–33. VHDL Example of Applying a ramstyle Attribute to a Variable Declaration

```
type memory_t is array (0 to 63) of std_logic_vector (0 to 7);
signal my_ram : memory_t;
attribute ramstyle : string;
attribute ramstyle of my_ram : signal is "logic";
```

## RAM Initialization File—for Inferred Memory

The ram\_init\_file attribute specifies the initial contents of an inferred memory in the form of a Memory Initialization File (.mif). The attribute takes a string value containing the name of the RAM initialization file.

## Example 7-34. Verilog-1995 Example of Applying a ram\_init\_file Attribute

```
reg [7:0] mem[0:255] /* synthesis ram_init_file
= " my_init_file.mif" */;
```

## Example 7–35. Verilog-2001 Example of Applying a ram\_init\_file Attribute

```
(* ram init file = "my init file.mif" *) reg [7:0] mem[0:255];
```

## Example 7-36. VHDL Example of Applying a ram init file Attribute

```
type mem_t is array(0 to 255) of unsigned(7 downto 0);
signal ram : mem_t;
attribute ram_init_file : string;
attribute ram_init_file of ram :
signal is "my init file.mif";
```



In VHDL, you can also initialize the contents of an inferred memory by specifying a default value for the corresponding signal. Quartus II integrated synthesis automatically converts the default value into a MIF for the inferred RAM.

# Multiplier Style—for Inferred Multipliers

The multstyle attribute specifies the implementation style for multiplication operations (\*) in your HDL source code. You can use this attribute to specify whether you prefer the Compiler to implement a multiplication operation in general logic or dedicated hardware, if available in the target device.



Specifying a multstyle of "dsp" does not guarantee that the Quartus II software can implement a multiplication in dedicated DSP hardware. The final implementation depends, among other things, on the availability of dedicated hardware in the target device, the size of the operands, and whether or not one or both operands are constant.

The multstyle attribute takes a string value of "logic" or "dsp," indicating a preferred implementation in logic or in dedicated hardware, respectively. In Verilog HDL, apply the attribute to a module declaration,

a variable declaration, or a specific binary expression containing the \* operator. In VHDL, apply the synthesis attribute to a signal, variable, entity, or architecture.



In addition to multstyle, the Quartus II software supports the syn\_multstyle attribute name for compatibility with other synthesis tools.

When applied to a Verilog HDL module declaration, the attribute specifies the default implementation style for all instances of the \* operator in the module. For example, in the following code examples, the multstyle attribute directs the Quartus II software to implement all multiplications inside module my\_module in dedicated multiplication hardware.

```
Example 7-37. Verilog-1995 Example of Applying a multstyle Attribute to a Module Declaration module my_module (...) /* synthesis multstyle = "dsp" */;
```

```
Example 7–38. Verilog-2001 Example of Applying a multstyle Attribute to a Module Declaration (* multstyle = "dsp" *) module my module(...);
```

When applied to a Verilog HDL variable declaration, the attribute specifies the implementation style to be used for a multiplication operator whose result is directly assigned to the variable. It overrides the multstyle attribute associated with the enclosing module, if present. For example, in Example 7–39 and 7–40, the multstyle attribute applied to variable result directs the Quartus II software to implement a \* b in general logic rather than dedicated hardware.

## Example 7-39. Verilog-2001 Example of Applying a multstyle Attribute to a Variable Declaration

## Example 7–40. Verilog-1995 Example of Applying a multstyle Attribute to a Variable Declaration

When applied directly to a binary expression containing the \* operator, the attribute specifies the implementation style for that specific operator alone and overrides any multstyle attribute associated with target variable or enclosing module. For example, in Example 7–41, the multstyle attribute indicates that a \* b should be implemented in dedicated hardware.

## Example 7-41. Verilog-2001 Example of Applying a multstyle Attribute to a Binary Expression

```
wire [8:0] a, b;
wire [17:0] result;
assign result = a * (* multstyle = "dsp" *) b;
```



You can not use Verilog-1995 attribute syntax to apply the multstyle attribute to a binary expression.

When applied to a VHDL entity or architecture, the attribute specifies the default implementation style for all instances of the \* operator in the entity or architecture. For example, in Example 7–42, the multstyle attribute directs the Quartus II software to use dedicated hardware, if possible, for all multiplications inside architecture rtl of entity my entity.

## Example 7–42. VHDL Example of Applying a multstyle Attribute to an Architecture

```
architecture rtl of my_entity is
    attribute multstyle : string;
    attribute multstyle of rtl : architecture is "dsp";
begin
```

When applied to a VHDL signal or variable, the attribute specifies the implementation style to be used for all instances of the \* operator whose result is directly assigned to the signal or variable. It overrides the multstyle attribute associated with the enclosing entity or architecture, if present. For example, in Example 7–43, the multstyle attribute associated with signal result directs the Quartus II software to implement a \* b in general logic rather than dedicated hardware.

#### Example 7–43. VHDL Example of Applying a multstyle Attribute to a Signal or Variable

```
signal a, b : unsigned(8 downto 0);
signal result : unsigned(17 downto 0);
attribute multstyle : string;
attribute multstyle of result : signal is "logic";
result <= a * b;</pre>
```

## **Full Case**

A Verilog HDL case statement is considered full when its case items cover all possible binary values of the case expression or when a default case statement is present. A full\_case attribute attached to a case statement header that is not full forces the unspecified states to be treated as a "don't care" value. VHDL case statements must be full, so the attribute does not apply to VHDL.



Using this attribute on a case statement that is not full avoids the latch inference problems discussed in the *Design Recommendations for Altera Devices* chapter in volume 1 of the *Quartus II Handbook*.



Latches have limited support in formal verification tools. It is important to ensure that you do not infer latches unintentionally, e.g. through an incomplete case statement, when using formal verification. Formal verification tools do support the full\_case synthesis attribute (with limited support for attribute syntax, as described in "Synthesis Attributes" on page 7–21).

When you are using the full\_case attribute, there is a potential cause for a simulation mismatch between Verilog HDL functional and post-Quartus II simulation because unknown case statement cases may still function like latches during functional simulation. For example, a simulation mismatch may occur with the code in the following example when sel is 2 'b11 because a functional HDL simulation output behaves like a latch while the Quartus II simulation output behaves like "don't care."



Altera recommends making the case statement "full" in your regular HDL code, instead of using the full case attribute.

The case statement in Example 7–44 is not full because not all binary values for sel are specified. Because the full\_case attribute is used, synthesis treats the output as "don't care" when the sel input is 2 'bl1.

### Example 7-44. Verilog HDL Example of a full\_case Attribute

```
module full_case (a, sel, y);
  input [3:0] a;
  input [1:0] sel;
  output y;
  reg y;
  always @ (a or sel)
  case (sel) // synthesis full_case
      2'b00: y=a[0];
      2'b01: y=a[1];
      2'b10: y=a[2];
      endcase
endmodule
```

Verilog-2001 syntax also accepts the statements in Example 7–45 in the case header instead of the comment form shown in Example 7–44.

## Example 7-45. Verilog-2001 Syntax for the full\_case Attribute

```
(* full case *) case (sel)
```

## **Parallel Case**

The parallel\_case attribute indicates that a Verilog HDL case statement should be considered parallel, that is, only one case item can be matched at a time. Case items in Verilog HDL case statements may overlap. To resolve multiple matching case items, the Verilog HDL language defines a priority relationship among case items in which the case statement always executes the first case item that matches the case expression value. By default, the Quartus II software implements the extra logic required to satisfy this priority relationship.

Attaching a parallel\_case attribute to a case statement's header allows the Quartus II software to consider its case items as inherently parallel, that is, at most one case item matches the case expression value. Parallel case items reduce the complexity of the generated logic.

In VHDL, the individual choices in a case statement may not overlap, so they are always parallel and this attribute does not apply.

Use this attribute only when the case statement is truly parallel. If you use the attribute in any other situation, the generated logic will not match the functional simulation behavior of the Verilog HDL.



Altera recommends that you avoid using the parallel\_case attribute, due to the possibility of introducing mismatches between Verilog HDL functional and post-Quartus II simulation.

If you specify the supported Verilog HDL version as SystemVerilog-2005 for your design, you can use the SystemVerilog keyword unique to achieve the same result as the parallel\_case directive without causing simulation mismatches.

The following example shows a casez statement with overlapping case items. In functional HDL simulation, the three case items have a priority order that depends on the bits in sel. For example, sel [2] takes priority over sel [1] which takes priority over sel [0]. However the synthesized design may simulate differently because the parallel\_case attribute eliminates this priority order. If more than one bit of sel is high, then more than one output (a, b, or c) is high as well, a situation that cannot occur in functional HDL simulation.

## Example 7-46. Verilog HDL Example of a parallel\_case Attribute

Verilog-2001 syntax also accepts the statements as shown in Example 7–47 in the case (or casez) header instead of the comment form as shown in Example 7–46.

### Example 7-47. Verilog-2001 Syntax

```
(* parallel_case *) casez (sel)
```

## Translate Off & On

The translate\_off and translate\_on synthesis directives indicate whether the Quartus II software or a third-party synthesis tool should compile a portion of HDL code that is not relevant for synthesis. The translate\_off directive marks the beginning of code that the synthesis tool should ignore; the translate\_on directive indicates that synthesis should resume. A common use of these directives is to indicate a portion of code that is intended for simulation only. The synthesis tool reads synthesis-specific directives and processes them during synthesis; however, third-party simulation tools read the directives as comments and ignore them. Example 7–48 and Example 7–49 show these directives.

## Example 7-48. Verilog HDL Example of Translate Off & On

## Example 7-49. VHDL Example of Translate Off & On

```
-- synthesis translate_off
use std.textio.all;
-- synthesis translate_on
```

If you wish to ignore a portion of code in Quartus II integrated synthesis only, you can use the Altera-specific attribute keyword altera. For example, use the // altera translate\_off and // altera translate\_on directives to direct Quartus II integrated synthesis to ignore a portion of code that is intended only for other synthesis tools.

## **Ignore Translate Off**

The Ignore Translate Off logic option directs Quartus II integrated synthesis to ignore the translate\_off and translate\_on attributes described in the previous section. This allows you to compile code that was previously intended to be ignored by third-party synthesis tools, for example megafunction declarations that were treated as black boxes in other tools but can be compiled in the Quartus II software. To set the Ignore Translate Off logic option, click More Settings on the Analysis & Synthesis Settings page of the Settings dialog box.

## **Read Comments as HDL**

The read\_comments\_as\_HDL synthesis directive indicates that the Quartus II software should compile a portion of HDL code that is commented out. This directive allows you to comment out portions of HDL source code that are not relevant for simulation, while instructing the Quartus II software to read and synthesize that same source code. Setting the read\_comments\_as\_HDL directive to on marks the beginning of commented code that the synthesis tool should read; setting the read\_comments\_as\_HDL directive to off indicates the end of the code.



You can use this directive with translate\_off and translate\_on to create one HDL source file that includes both a megafunction instantiation for synthesis and a behavioral description for simulation.

Because formal verification tools do not recognize the read\_comments\_as\_HDL directive, it is not supported when you are using formal verification.

In Example 7–50 and 7–51, the commented code enclosed by read\_comments\_as\_HDL is visible to the Quartus II Compiler and is synthesized.



Because synthesis directives are case-sensitive in Verilog HDL, you must match the case of the directive, as shown below.

### Example 7-50. 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 7-51. 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
```

# Setting Other Quartus II Options in Your HDL Source Code

This section describes Quartus II synthesis attributes that can be used to set other Quartus II options and settings in your HDL source code. The attributes described in the "chip\_pin" and "Use I/O Flip-Flops" sections can help you make pin-related assignments in your HDL code, and the attribute described in the "Altera Attribute" section can be used to make any other Quartus II option or setting assignments in your HDL code. Assignments made with these synthesis attributes take precedence over assignments made through the Quartus II user interface, the Quartus II Settings File, or the Tcl interface.

## Use I/O Flip-Flops

This attribute directs the Quartus II software to implement input, output, and output enable flip-flops (or registers) in I/O cells that have fast, direct connections to an I/O pin, when possible. Applying the useioff synthesis attribute can improve I/O performance by minimizing setup, clock-to-output, and clock-to-output enable times. This synthesis attribute is supported using the Fast Input Register, Fast Output Register, and Fast Output Enable Register logic options that can also be set in the Assignment Editor.



For more information about which device families support fast input, output, and output enable registers, refer to the device family data sheet, device handbook, or the Quartus II Help.

The useioff synthesis attribute takes a Boolean value and can only be applied to the port declarations of a top-level Verilog HDL module or VHDL entity (it is ignored if applied elsewhere). Setting the value to 1 (Verilog HDL) or TRUE (VHDL) instructs the Quartus II software to pack registers into I/O cells. Setting the value to 0 (Verilog HDL) or FALSE (VHDL) prevents register packing into I/O cells.

In Example 7–52 and 7–53, the useioff synthesis attribute directs the Quartus II software to implement the registers a\_reg, b\_reg, and o reg in the I/O cells corresponding to the ports a, b, and o respectively.

## Example 7-52. Verilog HDL Example of a useioff Attribute

```
module top_level(clk, a, b, o);
    input clk;
    input [1:0] a, b /* synthesis useioff = 1 */;
    output [2:0] o /* synthesis useioff = 1 */;
    reg [1:0] a_reg, b_reg;
    reg [2:0] o_reg;
    always @ (posedge clk)
    begin
        a_reg <= a;
        b_reg <= b;
        o_reg <= a_reg + b_reg;
    end
    assign o = o_reg;
endmodule</pre>
```

Verilog-2001 syntax also accepts the type of statements shown in Example 7–53 and 7–54 instead of the comment form shown in Example 7–52.

### Example 7-53. Verilog-2001 Syntax for a useioff Attribute

```
(* useioff = 1 *) input [1:0] a, b;
(* useioff = 1 *) output [2:0] o;
```

#### Example 7-54. VHDL with a useioff Attribute

```
library ieee;
use ieee.std logic 1164.all;
use ieee.numeric std.all;
entity top level is
  port (
     clk : in std_logic;
     a, b : in unsigned(1 downto 0);
     o : out unsigned(1 downto 0));
  attribute useioff : boolean;
  attribute useioff of a : signal is true;
  attribute useioff of b : signal is true;
  attribute useioff of o : signal is true;
end top level;
architecture rtl of top level is
  signal o_reg, a_reg, b_reg : unsigned(1 downto 0);
  process(clk)
  begin
     a req <= a;
     b reg <= b;
     o_reg <= a_reg + b_reg;
  end process;
  o <= o reg;
end rtl;
```

## **Altera Attribute**

This attribute enables you to apply Quartus II options and assignments to an object (entity, instance, or net) in your HDL source code. With altera\_attribute, you can control synthesis options from your HDL source even when the options lack a specific HDL synthesis attribute (such as many of the logic options presented earlier in this chapter). You can also use this attribute to pass entity-level settings and assignments to phases of the Compiler flow beyond Analysis & Synthesis, such as Fitting.

Assignments and settings made with the Altera Attribute take precedence over assignments and settings made through the Quartus II user interface, the Quartus II Settings File, or the Tcl interface.

The syntax for setting this attribute in HDL is the same as the syntax for other synthesis attributes, as shown in "Synthesis Attributes" on page 7–21.

The attribute value is a single string containing a list of Quartus II Settings File variable assignments separated by semicolons, as shown in the following example:

```
-name <variable_1> <value_1>; -name <variable_2> <value_2>[;...]
```

If the Quartus II option or assignment includes a target, source, and/or section tag, use the following syntax for each Quartus II Settings File variable assignment.

```
-from <source> -to <target> -section_id <section>
-name <variable> <value>
```

The syntax for the full attribute value, including the optional target, source, and section tags for two different Quartus II Settings File assignments is shown in the following example:

```
"[-from <source_1>] [-to <target_1>] [-section_id
<section_1>] -name <variable_1> <value_1>; [-from <source_2>]
[-to <target_2>] [-section_id <section_2>] -name <variable_2>
<value 2>"
```

If a variable's assigned value is a string of text, you must use escaped quotes around the value, as in the following examples (using non-existent variable and value terms):

## Verilog HDL

```
"VARIABLE NAME \"STRING VALUE\""
```

## **VHDL**

```
"VARIABLE NAME ""STRING VALUE""
```

To find the Quartus II Settings File variable name or value corresponding to a specific Quartus II option or assignment, you can make the option setting or assignment in the Quartus II user interface and then note the changes in the Quartus II Settings File. You can also refer to the *Quartus II Settings File Reference Manual* which documents all variable names.

Example 7–55, 7–56, and 7–57 use altera\_attribute to set the power-up level of an inferred register. Note that for inferred instances, you cannot apply the attribute to the instance directly so you should apply the attribute to one of the instance's output nets. The Quartus II software moves the attribute to the inferred instance automatically.

#### Example 7-55. Verilog-1995 Example of Applying Altera Attribute to an Instance

reg my\_reg /\* synthesis altera\_attribute = "-name POWER\_UP\_LEVEL HIGH" \*/;

#### Example 7–56. Verilog-2001 Example of Applying Altera Attribute to an Instance

(\* altera\_attribute = "-name POWER\_UP\_LEVEL HIGH" \*) reg my\_reg;

#### Example 7–57. VHDL Example of Applying Altera Attribute to an Instance

```
signal my_reg : std_logic;
attribute altera_attribute : string;
attribute altera_attribute of my_reg: signal is "-name POWER_UP_LEVEL
HIGH";
```

Example 7–58, 7–59, and 7–60 use the altera\_attribute to disable the **Auto Shift Register Replacement** synthesis option for an entity. To apply the Altera Attribute to a VHDL entity, you must set the attribute on its architecture rather than on the entity itself.

## Example 7-58. Verilog-1995 Example of Applying Altera Attribute to an Entity

module my\_entity(...) /\* synthesis altera\_attribute = "-name
AUTO\_SHIFT\_REGISTER\_RECOGNITION OFF" \*/;

#### Example 7-59. Verilog-2001 Example of Applying Altera Attribute to an Entity

```
(* altera_attribute = "-name AUTO_SHIFT_REGISTER_RECOGNITION OFF" *)
module my_entity(...) ;
```

#### Example 7–60. VHDL Example of Applying Altera Attribute to an Entity

```
entity my_entity is
-- Declare generics and ports
end my_entity;
architecture rtl of my_entity is
    attribute altera_attribute : string;
    -- Attribute set on architecture, not entity
    attribute altera_attribute of rtl: architecture is "-name
AUTO_SHIFT_REGISTER_RECOGNITION OFF";
begin
    -- The architecture body
end rtl;
```

You can also use altera\_attribute for more complex assignments involving more than one instance. In Example 7–61, 7–62, and 7–63 the altera\_attribute is used to cut all timing paths from reg1 to reg2, equivalent to this Tcl or QSF command:

 $\verb|set_instance_assignment -name CUT ON -from reg1 -to reg2|\\$ 

## Example 7-61. Verilog-1995 Example of Applying Altera Attribute with -to

```
reg reg2;
reg reg1 /* synthesis altera_attribute = "-name CUT ON -to reg2" */;
```

## Example 7–62. Verilog-2001 Example of Applying Altera Attribute with -to

```
reg reg2;
(* altera attribute = "-name CUT ON -to reg2" *) reg reg1;
```

## Example 7-63. VHDL Example of Applying Altera Attribute with -to

```
signal reg1, reg2 : std_logic;
attribute altera_attribute: string;
attribute altera attribute of reg1 : signal is "-name CUT ON -to reg2";
```

You may specify either the -to option or the -from option in a single altera\_attribute; integrated synthesis automatically sets the remaining option to the target of the altera\_attribute. You may also specify wildcards for either option. For example, if you specify "\*" for the -to option instead of reg2 in these examples, the Quartus II software cuts all timing paths from reg1 to every other register in this design entity.



The altera\_attribute can be used only for entity-level settings, and the assignments (including wildcards) apply only to the current entity.

## chip\_pin

This attribute enables you to assign pins to the ports of an entity or module in your HDL source. You may only assign pins to single-bit or one-dimensional bus ports in your design.

For single-bit ports, the value of the chip\_pin attribute is the name of the pin on the target device, as specified by the device's pin table.



In addition to chip\_pin, the Quartus II software supports the altera\_chip\_pin\_lc attribute name for compatibility with other synthesis tools. When using this attribute in other synthesis tools, some older device families require an "@" symbol in front of each pin assignment. In the Quartus II software, the "@" is optional.

Example 7–64, 7–65, and 7–66 show different ways of assigning input pin my pin1 to Pin C1 and my pin2 to Pin 4 on a different target device.

#### Example 7-64. Verilog-1995 Examples of Applying Chip Pin to a Single Pin

```
input my_pin1 /* synthesis chip_pin = "C1" */;
input my_pin2 /* synthesis altera_chip_pin_lc = "@4" */;
```

## Example 7-65. Verilog-2001 Example of Applying Chip Pin to a Single Pin

```
(* chip_pin = "C1" *) input my_pin1;
(* altera_chip_pin_lc = "@4" *) input my_pin2;
```

#### Example 7–66. VHDL Example of Applying Chip Pin to a Single Pin

```
entity my_entity is
        port(my_pin1: in std_logic; my_pin2: in std_logic;...);
end my_entity;
attribute chip_pin : string;
attribute altera_chip_pin_lc : string;
attribute chip_pin of my_pin1 : signal is "C1";
attribute altera chip pin lc of my pin2 : signal is "@4"
```

For bus I/O ports, the value of the chip pin attribute is a comma-delimited list of pin assignments. The order in which you declare the port's range determines the mapping of assignments to individual bits in the port. To leave a particular bit unassigned, simply leave its corresponding pin assignment blank.

Example 7-67 assigns my\_pin[2] to Pin\_4, my\_pin[1] to Pin\_5, and my pin[0] to Pin\_6.

#### Example 7–67. Verilog-1995 Example of Applying Chip Pin to a Bus of Pins

```
input [2:0] my_pin /* synthesis chip_pin = "4, 5, 6" */;
```

Example 7–68 reverses the order of the signals in the bus, assigning my\_pin[0] to Pin\_4 and my\_pin[2] to Pin\_6 but leaves my\_pin[1] unassigned.

#### Example 7–68. Verilog-1995 Example of Applying Chip Pin to Part of a Bus

```
input [0:2] my pin /* synthesis chip pin = "4, ,6" */;
```

Example 7–69 assigns my\_pin[2] to Pin 4 and my\_pin[0] to Pin 6, but leaves my\_pin[1] unassigned.

#### Example 7–69. VHDL Example of Applying Chip Pin to Part of a Bus of Pins

```
entity my_entity is
     port(my_pin: in std_logic_vector(2 downto 0);...);
end my_entity;
attribute chip_pin of my_pin: signal is "4, , 6";
```

#### Analyzing Synthesis Results

After you have performed synthesis, you can check your synthesis results in the following locations:

- Messages
- Analysis & Synthesis Section of Compilation Report
- Project Navigator

#### Messages

The messages that appear during Analysis & Synthesis describe many of the optimizations that the software performs during the synthesis stage, and provide information about how the design is interpreted. You should always check the messages to analyze critical warnings and warnings, because these messages may relate to important design problems. It is also useful to read the Information messages to get more information about how the software processes your design.

#### **Analysis & Synthesis Section of Compilation Report**

The Compilation Report, which provides a summary of results for the project, appears after a successful compilation, or you can choose it from the Processing menu. After Analysis & Synthesis, before the Fitter begins, the Summary information provides a summary of utilization based on synthesis data, before fitter optimizations have occurred. Synthesis-specific information is listed in the Analysis & Synthesis section.

There are various report sections under Analysis & Synthesis, including a list of the source files read for the project, the resource utilization by entity after synthesis, and information about state machines, latches, optimization results, and parameter settings.



For more information about each report section, refer to the Quartus II Help.

#### **Project Navigator**

The Hierarchy tab of the Project Navigator provides a summary of resource information about the entities in the project. After Analysis & Synthesis, before the Fitter begins, the Project Navigator provides a summary of utilization based on synthesis data, before Fitter optimizations have occurred.

If you hold your mouse pointer over one of the entities in the Hierarchy tab, a tooltip that shows parameter information for each instance.

# VHDL & Verilog HDL Messages

The Quartus II software issues a variety of messages when it is analyzing and elaborating the Verilog HDL and VHDL files in your design. These HDL messages help you identify potential problems early in the design process.

#### **HDL Message Types**

HDL messages fall into three categories: Info, Warning, and Error.

- **Info message**—Lists a property of your design.
- Warning message—Indicates a potential problem in your design. Potential problems come from a variety of sources, including typos, inappropriate design practices, or the functional limitations of your target device. Though HDL warning messages do not always identify actual problems, you should always investigate code that generates an HDL warning. Otherwise, the synthesized behavior of your design might not match your original intent or its simulated behavior.
- Error message—Indicates an actual problem with your design. Your HDL code may be invalid due to a syntax or semantic error, or it may not be synthesizable as written. Consult the Help associated with any HDL error messages for assistance in removing the error from your design.

In Example 7–70, the sensitivity list contains multiple copies of the variable i. While the Verilog HDL language does not prohibit duplicate entries in a sensitivity list, it is clear that this design has a typo: Variable j should be listed on the sensitivity list to avoid a possible simulation/synthesis mismatch.

#### Example 7–70. Generating an HDL Warning Message

```
//dup.v
module dup(input i, input j, output reg o);
always @ (i)
    o = i & j;
endmodule
```

When processing this HDL code, the Quartus II software generates the following warning message:

Warning: (10276) Verilog HDL sensitivity list warning at dup.v(2): sensitivity list contains multiple entries for "i".

In Verilog HDL, variable names are case-sensitive, so the variables my\_reg and MY\_REG in Example 7–71 are two different variables. However, declaring variables whose names only differ in case may confuse some users, especially those users who use VHDL, where variables are not case-sensitive.

#### Example 7-71. Generating HDL Info Messages

```
// namecase.v
module namecase (input i, output o);
   reg my_reg;
   reg MY_REG;
   assign o = i;
endmodule
```

When processing this HDL code, the Quartus II software generates the following informational message:

```
Info: (10281) Verilog HDL information at
namecase.v(3): variable name "MY_REG" and variable
name "my_reg" should not differ only in case.
```

In addition, the Quartus II software generates additional HDL info messages to inform you that neither my\_reg or MY\_REG are used in this small design:

```
Info: (10035) Verilog HDL or VHDL information at namecase.v(3): object "my_reg" declared but not used Info: (10035) Verilog HDL or VHDL information at namecase.v(4): object "MY REG" declared but not used
```

#### **Controlling the Display of HDL Messages**

The Quartus II software allows you to control how many HDL messages you see during the analysis and elaboration of your design files. You can set the HDL Message Level to enable or disable groups of HDL messages, or you can enable or disable specific messages.

For more information about synthesis directives and their syntax, refer to "Synthesis Directives" on page 7–24.



These options are in addition to the general message suppression options in the Quartus II software. For more information about suppressing other messages, refer to the *Quartus II Project Management* chapter in volume 2 of the *Quartus II Handbook*.

#### Setting the HDL Message Level

The HDL Message Level specifies the types of messages that the Quartus II software displays when it is analyzing and elaborating your design files. Table 7–6 details the information about the HDL message levels.

| able 7–6. HDL Info Message Level |                                                       |                                                                                                                                                                                                                                                                                       |
|----------------------------------|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Level                            | Purpose                                               | Description                                                                                                                                                                                                                                                                           |
| Level1                           | Displays high-severity messages only                  | If you want to see only those HDL messages that identify likely problems with your design, select <b>Level1</b> . When <b>Level1</b> is selected, the Quartus II software will only issue a message if there is a high probability that it points an actual problem with your design. |
| Level2                           | Displays high-severity and medium-severity messages   | If you want to see additional HDL messages that identify possible problems with your design, select <b>Level2</b> . This is the default setting.                                                                                                                                      |
| Level3                           | Displays all messages, including low-severity message | If you want to see all HDL info and warning messages, select <b>Level3</b> . This level includes extra "LINT" messages that suggest changes to improve the style of your HDL code or make it easier to understand.                                                                    |

You should address all issues reported at the **Level1** setting. The default HDL message level is **Level2**.

To set the HDL Message Level in the user interface, on the Assignments menu, click **Settings**; under Category, click **Analysis & Synthesis Settings**. Set the HDL Message Level.

You can override this default setting in a source file with the message\_level synthesis directive, which takes the values **level1**, **level2**, and **level3**, as shown in Example 7–72 and 7–73.

#### Example 7-72. Verilog HDL Examples of message\_level Directive

#### Example 7-73. VHDL Example of message\_level Directive

-- altera message level level2

A message\_level synthesis directive remains effective until the end of a file or until the next message\_level directive. In VHDL, you can use the message\_level synthesis directive to set the HDL Message Level for entities and architectures, but not for other design units. An HDL Message Level for an entity applies to its architectures, unless overridden by another message\_level directive. In Verilog HDL, you can use the message level directive to set the HDL Message Level for a module.

#### Enabling or Disabling Specific HDL Messages

You can enable or disable a specific HDL info or warning message with its Message ID, which is displayed in parentheses at the beginning of the message. Enabling or disabling a specific message overrides its HDL Message Level.

To disable specific HDL messages in the GUI, from the Settings menu, select **Analysis & Synthesis Settings** and click the **Advanced** button next to the HDL Message Level setting. In the Advanced Message Settings dialog box, add the Message IDs you wish to enable or disable.

To enable or disable specific HDL messages in your HDL, use the message\_on and message\_off synthesis directives. Both directives take a space-separated list of Message IDs. You can enable or disable messages with these synthesis directives immediately before Verilog HDL modules, VHDL entities, or VHDL architectures. You cannot enable or disable a message in the middle of an HDL construct.

A message enabled or disabled via a message\_on or message\_off synthesis directive overrides its HDL Message Level or any message\_level synthesis directive. The message will remain disabled until the end of the source file or until its status is changed by another message\_on or message\_off directive.

#### Example 7-74. Verilog HDL message\_off Directive for Message with ID 10000

```
^{\prime\prime} altera message_off 10000 ^{\circ} ^{\circ} ^{\prime} altera message off 10000 */
```

#### Example 7–75. VHDL message\_off Directive for Message with ID 10000

```
-- altera message off 10000
```

## Node-Naming Conventions in Quartus II Integrated Synthesis

Being able to find the logic node names after synthesis can be useful during verification or while debugging a design. This section provides an overview of the conventions used by the Quartus II software when it names the nodes created from your HDL design. The section focuses on the conventions for Verilog HDL and VHDL code, but AHDL and BDFs are discussed when appropriate.

Whenever possible, as described in this section, Quartus II integrated synthesis uses wire or signal names from your source code to name nodes such as LEs or ALMs. Some nodes, such as registers, have predictable names that typically do not change when a design is resynthesized. The names of other nodes, particularly LEs or ALMs that contain only combinational logic, can change due to logic optimizations that the software performs.

Synthesis netlist optimizations also change node names because nodes are changed, combined, and duplicated to optimize the design.



For more information about the type of optimizations performed by synthesis netlist optimizations, refer to *Netlist Optimizations & Physical Synthesis* in volume 2 of the *Quartus II handbook*.



The Quartus II Fitter can also change node names after synthesis. For example when the Fitter uses register packing to pack a register into an I/O element, or when logic is modified by physical synthesis.

#### **Hierarchical Node-Naming Conventions**

To make each name in the design unique, the Quartus II software adds the hierarchy path to the beginning of each name. The "|" separator is used to indicate a level of hierarchy. For each instance in the hierarchy, the software adds the entity name and the instance name of that entity, using the ":" separator between each entity name and its instance name. For example, if a design instantiates entity A with the name my\_A\_inst, the hierarchy path of that entity would be A:my\_A\_inst. The full name of any node is obtained by starting with the hierarchical instance path; followed by a "|", and ending with the node name inside that entity, using the following convention:

```
<entity 0>:<instance_name 0> | <entity 1>:
<instance_name 1> | . . . | <instance_name n>
```

For example, if entity A contains a register (DFF atom) called my\_dff, its full hierarchy name would be A:my\_A\_inst | my\_dff.

You can turn off the **Display Entity Name for Node Name** option on the **Compilation Process Settings** page of the **Settings** dialog box to instruct the Compiler to generate node names that do not contain the name for each level of the hierarchy. With this option on, the node names use the following convention:

<instance\_name 0> | <instance\_name 1> | . . . | <instance\_name n>

## Node-Naming Conventions for Registers (DFF or D Flip-Flop Atoms)

In Verilog HDL and VHDL, inferred registers are named after the reg or signal connected to the output.

For example, the following is a description of a register in Verilog HDL that creates a DFF primitive called my\_dff\_out:

#### Example 7-76. Verilog HDL Register

```
wire dff_in, my_dff_out, clk;
always @ (posedge clk)
  my dff out <= dff in;</pre>
```

Similarly, Example 7–77 is a description of a register in VHDL that creates a DFF primitive called my dff out.

#### Example 7-77. VHDL Register

```
signal dff_in, my_dff_out, clk;
process (clk)
  begin
  if (rising_edge(clk)) then
    my_dff_out <= dff_in;
  end if;
end process;</pre>
```

In AHDL designs, DFF registers are declared explicitly rather than inferred, so the software uses the user-declared name for the register.

For schematic designs using BDF, all elements are given a name when they are instantiated in the design, so the software uses the user-defined name for the register or DFF.

In the special case that a wire or signal (such as my\_dff\_out in the above examples) is also an output pin of your top-level design, the Quartus II software cannot use that name for the register (e.g., cannot use

my\_dff\_out) because the software requires that all logic and I/O cells have unique names. In this case, the Quartus II integrated synthesis appends ~reg0 to the register name.

For example, the Verilog HDL code in Example 7–78 produces a register called q~req0:

#### Example 7-78. Verilog HDL Register Feeding Output Pin

```
module my_dff (input clk, input d, output q);
  always @ (posedge clk)
    q <= d;
endmodule</pre>
```

This situation occurs only for registers driving top-level pins. If a register drives a port of a lower level of the hierarchy, then the port is removed during hierarchy flattening and the register retains its original name, in this case, q.

#### **Register Changes During Synthesis**

On some occasions, you may not be able to find registers that you expect to see in the synthesis netlist. Registers may be removed by logic optimization, or their names may be changed due to synthesis optimization. Common optimizations include inference of a state machine, counter, adder-subtractor, or shift register from registers and surrounding logic. Other common register changes occur when registers are packed into dedicated hardware on the FPGA such as a DSP block or a RAM block.

This section describes the device features that affect register names:

- State machines
- Inferred adder-subtractors, shift registers, memory, and DSP functions
- Input and output registers of RAM and DSP blocks

#### State Machines

If a state machine is inferred from your HDL code, then the registers that represent the states will be mapped into a new set of registers that implement the state machine. Most commonly, the software converts the state machine into a one-hot form where each state is represented by one register. In this case for Verilog HDL or VHDL designs, the registers are named according to the name of the state register and the states, where possible.

For example, consider a Verilog HDL state machine where the states are parameter state0 = 1, state1 = 2, state2 = 3, and where the state machine register is declared as reg [1:0] my\_fsm. In this example, the three one-hot state registers are named my\_fsm.state0, my\_fsm.state1, and my\_fsm.state2.

In AHDL, state machines are explicitly specified with a machine name. State machine registers are given synthesized names based on the state machine name but not the state names. For example, if a state machine is called my\_fsm and has four state bits, they may be synthesized with names such as my\_fsm~12, my\_fsm~13, my\_fsm~14, and my\_fsm~15.

Inferred Adder-Subtractors, Shift Registers, Memory & DSP Functions

The Quartus II software infers megafunctions from Verilog HDL and VHDL code for logic that forms adder-subtractors, shift registers, RAM, ROM, and arithmetic functions that can be placed in DSP blocks.

For information about inferring megafunctions, refer to the *Recommended HDL Coding Styles* chapter in the *Quartus II Handbook*.

Because adder-subtractors are part of a megafunction instead of generic logic, the combinational logic exists in the design with different names. For shift registers, memory, and DSP functions, the registers and logic are typically implemented inside the dedicated RAM or DSP blocks in the device. Thus, the registers are not visible as separate LEs or ALMs.

#### Input & Output Registers of RAM & DSP Blocks

Registers can be packed into the input registers and output registers of RAM and DSP blocks, so that they are not visible as separate registers in LEs or ALMs.

For information about packing registers into RAM and DSP megafunctions, refer to the *Recommended HDL Coding Styles* chapter in the *Quartus II Handbook*.

#### **Node-Naming Conventions for Combinational Logic Cells**

Whenever possible for Verilog HDL, VHDL, and AHDL code, the Quartus II software uses wire names that are the targets of assignments, but may change the node names due to synthesis optimizations.

For example, consider the Verilog HDL code in Example 7–79. Quartus II integrated synthesis uses the names c, d, e, and f for the combinational logic cells that are produced.

#### Example 7–79. Naming Nodes for Combinational Logic Cells in Verilog HDL

```
wire c;
reg d, e, f;
assign c = a | b;
always @ (a or b)
    d = a & b;
always @ (a or b) begin : my_label
    e = a ^ b;
end

always @ (a or b)
    f = ~(a | b);
```

For schematic designs using BDF, all elements are given a name when they are instantiated in the design and the software uses the user-defined name when possible.

If logic cells, such as those created in the above example, are packed with registers in device architectures such as the Stratix and Cyclone device families, those names may not appear in the netlist after fitting. In other devices such as the Stratix II and Cyclone II device families, the register and combinational nodes are kept separate throughout the compilation, so these names are more often maintained through fitting.

When logic optimizations occur during synthesis, it is not always possible to retain the initial names as described above. In some cases, synthesized names will be used, which are the wire names with a tilde (~) and a number appended. For example, if a complex expression is assigned to a wire w and that expression generates several logic cells, those cells may have names such as w, w~1, w~2, and so on. Sometimes the original wire name w is removed, and an arbitrary name such as rt1~123 is created. It is a goal of Quartus II integrated synthesis to retain user names whenever possible. Any node name ending with ~<number> is a name created during synthesis, which may change if the design is

changed and re-synthesized. Knowing these naming conventions can help you understand your post-synthesis results and make it easier to debug your design or make assignments.

# 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*. 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 specify many of the options described in this section either on an instance, or global level, or both.

Use the following Tcl command to make a global assignment:

```
set_global_assignment -name <QSF Variable Name> <Value>
```

Use the following Tcl command to make an instance assignment:

set\_instance\_assignment -name <QSF Variable Name> <Value>\
-to <Instance Name>

#### **Quartus II Synthesis Options**

Table 7–7 lists the Quartus II Settings File variable names and applicable values for the settings discussed in this chapter. The Quartus II Settings File variable name is used in the Tcl assignment to make the setting along with the appropriate value. The *Type* column indicates whether the setting is supported as a Global setting, or an Instance setting, or both.

| Table 7–7. Quartus II Synthesis Options (Part 1 of 2) |                                                               |                                                    |                     |
|-------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------|---------------------|
| Setting Name                                          | Quartus II Settings File Variable                             | Values                                             | Туре                |
| Allow Any RAM Size for Recognition                    | ALLOW_ANY_RAM_SIZE_FOR_RECOGNITION                            | ON, OFF                                            | Global,<br>Instance |
| Allow Any ROM<br>Size for Recognition                 | ALLOW_ANY_ROM_SIZE_FOR_RECOGNITION                            | ON, OFF                                            | Global,<br>Instance |
| Allow Any Shift<br>Register Size for<br>Recognition   | ALLOW_ANY_SHIFT_REGISTER_SIZE_FOR_<br>RECOGNITION             | ON, OFF                                            | Global,<br>Instance |
| Auto DSP Block<br>Replacement                         | AUTO_DSP_RECOGNITION                                          | ON, OFF                                            | Global,<br>Instance |
| Auto RAM<br>Replacement                               | AUTO_RAM_RECOGNITION                                          | ON, OFF                                            | Global,<br>Instance |
| Auto ROM<br>Replacement                               | AUTO_ROM_RECOGNITION                                          | ON, OFF                                            | Global,<br>Instance |
| Auto Shift-Register<br>Replacement                    | AUTO_SHIFT_REGISTER_RECOGNITION                               | ON, OFF                                            | Global,<br>Instance |
| Fast Input Register                                   | FAST_INPUT_REGISTER                                           | ON, OFF                                            | Instance            |
| Fast Output Enable<br>Register                        | FAST_OUTPUT_ENABLE_REGISTER                                   | ON, OFF                                            | Instance            |
| Fast Output<br>Register                               | FAST_OUTPUT_REGISTER                                          | ON, OFF                                            | Instance            |
| Implement as<br>Output of Logic Cell                  | IMPLEMENT_AS_OUTPUT_OF_LOGIC_CELL                             | ON, OFF                                            | Instance            |
| Maximum Fan-Out                                       | MAX_FANOUT                                                    | <maximum fan-out<br="">Value&gt;</maximum>         | Instance            |
| Optimization<br>Technique                             | <pre><device family="">_OPTIMIZATION_TECHNIQUE</device></pre> | Area, Speed,<br>Balanced                           | Global,<br>Instance |
| PowerPlay Power<br>Optimization                       | OPTIMIZE_POWER_DURING_SYNTHESIS                               | "NORMAL<br>COMPILATION",<br>"EXTRA EFFORT",<br>OFF | Global,<br>Instance |
| Power-Up Don't<br>Care                                | ALLOW_POWER_UP_DONT_CARE                                      | ON, OFF                                            | Global              |

| Table 7–7. Quartus II Synthesis Options (Part 2 of 2) |                                   |                                                       |                     |
|-------------------------------------------------------|-----------------------------------|-------------------------------------------------------|---------------------|
| Setting Name                                          | Quartus II Settings File Variable | Values                                                | Туре                |
| Power-Up Level                                        | POWER_UP_LEVEL                    | HIGH, LOW                                             | Instance            |
| Preserve<br>Hierarchical<br>Boundary                  | PRESERVE_HIERARCHICAL_BOUNDARY    | Off, Relaxed,<br>Firm                                 | Instance            |
| Preserve Registers                                    | PRESERVE_REGISTER                 | ON, OFF                                               | Instance            |
| Remove Duplicate<br>Logic                             | REMOVE_DUPLICATE_LOGIC            | ON, OFF                                               | Global,<br>Instance |
| Remove Duplicate<br>Registers                         | REMOVE_DUPLICATE_REGISTERS        | ON, OFF                                               | Global,<br>Instance |
| Remove Redundant<br>Logic Cells                       | REMOVE_REDUNDANT_LOGIC_CELLS      | ON, OFF                                               | Global              |
| Restructure<br>Multiplexers                           | MUX_RESTRUCTURE                   | On, Off, Auto                                         | Global,<br>Instance |
| Speed Optimization<br>Technique for Clock<br>Domains  | SYNTH_CRITICAL_CLOCK              | ON, OFF                                               | Instance            |
| State Machine<br>Processing                           | STATE_MACHINE_PROCESSING          | AUTO, "MINIMAL<br>BITS", "ONE HOT",<br>"USER-ENCODED" | Global,<br>Instance |

#### **Assigning a Pin**

Use the following Tcl command to assign a signal to a pin or device location.

```
set_location_assignment -to <signal name> <location>
```

For example, set\_location\_assignment -to data\_input Pin\_A3

Valid locations are pin location names. Some device families also support edge and I/O bank locations. Edge locations are EDGE\_BOTTOM, EDGE\_LEFT, EDGE\_TOP, and EDGE\_RIGHT. I/O bank locations include IOBANK\_1 to IOBANK\_n, where n is the number of I/O banks in a particular device.

#### **Preparing a Design for Incremental Synthesis**

To set up your design for incremental synthesis, identify design partitions and enable incremental synthesis.

#### Creating Design Partitions

To create a partition, use the following command:

```
set_instance_assignment -name PARTITION_HIERARCHY \
<file name> -to <destination> -section id cpartition name>
```

The <destination> should be the entity's short hierarchy path. A short hierarchy path is the full hierarchy path without the top-level name, for example: "ram:ram\_unit|altsyncram:altsyncram\_component" (with quotation marks). For the top-level partition, you can use the pipe (|) symbol to represent the top-level entity.

For more information about hierarchical naming conventions, refer to "Node-Naming Conventions in Quartus II Integrated Synthesis" on page 7–65.

The *<partition name>* is the user-designated partition name, which must be unique and less than 1024 characters long. The name can consist only of alpha-numeric characters, as well as pipe ( | ), colon ( : ) and underscore ( \_ ) characters. Altera recommends enclosing the name in double quotation marks (" ").

The *<file name>* is the name used for internally generated netlists files during incremental compilation. Netlists are named automatically by the Quartus II software based on the instance name if you create the partition in the user interface. If you are using Tcl to create your partitions, you must assign a custom file name that is unique across all partitions. For the top-level partition, the specified file name is ignored, and you can use any dummy value. To ensure the names are safe and platform independent, file names must be unique regardless of case. For example, if a partition uses the file name my\_file, no other partition can use the file name MY\_FILE. For simplicity, Altera recommends that you base each file name on the corresponding instance name for the partition.

The software stores all netlists in the **db** compilation database directory.

#### Enabling Incremental Synthesis

Turn on incremental synthesis using the following Tcl command:

```
set_global_assignment -name INCREMENTAL_COMPILATION \
INCREMENTAL SYNTHESIS
```

#### Synthesizing a Design Using Incremental Synthesis

Once incremental synthesis is turned on in the Quartus II Settings File file, or through a Tcl command, incremental synthesis automatically occurs when you compile using the execute\_flow -compile command for the quartus\_sh compiler executable.

#### Synthesizing Using the Synthesis & Merge Commands

Use the separate synthesis and merge commands if you compile your design using the individual compiler executables (e.g., quartus\_map and quartus\_fit) instead of using the execute\_flow -compile command for the quartus\_sh compiler executable.

To enable incremental synthesis when using the **quartus\_map** executable, perform the following two steps:

1. Type the following command at a command prompt:

quartus map --incremental compilation=incremental synthesis ←



This command enables the flow in the project, so subsequent synthesis runs can be performed with the quartus\_map command without the incremental compilation option.

2. Merge the synthesized partitions to create a flattened netlist for further stages of the Quartus II compilation flow, including fitting. Type the following command at a system command prompt:

quartus cdb --merge ←

#### **Conclusion**

The Quartus II software includes complete Verilog HDL and VHDL language support, as well as support for Altera-specific languages, making it an easy-to-use, standalone solution for Altera designs. You can use the synthesis options available in the software to help you improve your synthesis results, giving you more control over the way your design is synthesized.



# 8. Synplicity Synplify & Synplify Pro Support

QII51009-6.0.0

#### Introduction

As programmable logic device (PLD) designs become more complex and require increased performance, advanced synthesis has become an important part of the design flow. This chapter documents support for the Synplicity Synplify and Synplify Pro software in the Quartus<sup>®</sup> II software, as well as key design flows, methodologies, and techniques for achieving good results in Altera<sup>®</sup> devices, including the following topics:

- General design flow with the Synplify and Quartus II software
- Synplify software optimization strategies, including timing-driven compilation settings, optimization options, and Altera-specific attributes
- Exporting designs and constraints to the Quartus II software using NativeLink<sup>®</sup> integration
- Guidelines for Altera megafunctions and library of parameterized module (LPM) functions, instantiating them in a clear- or black-box flow with the MegaWizard<sup>®</sup> Plug-In Manager, and tips for inferring them from hardware description language (HDL) code
- Incremental compilation and block-based design, including the Synplify Pro software MultiPoint flow

The content in this chapter applies to both the Synplify and Synplify Pro software unless otherwise specified.

This chapter assumes that you have set up, licensed, and are familiar with the Synplify or Synplify Pro software.



For more information about obtaining, licensing, and using the Synplify software, refer to the Synplicity web site at **www.synplicity.com**.

#### **Design Flow**

A Quartus II software design flow using the Synplify software consists of the following steps:

- 1. Create Verilog HDL or VHDL design files in the Quartus II software, Synplify software, or a text editor.
- 2. Set up a project in the Synplify software and add the HDL design files for synthesis.
- 3. Select a target device and add timing constraints and compiler directives to optimize the design during synthesis.

- 4. Synthesize the design in the Synplify software.
- Create a Quartus II project and import the technology-specific netlist and the tool command language (Tcl) constraint file generated by the Synplify software into the Quartus II software for placement and routing, and for performance evaluation.
- 6. After obtaining place-and-route results that meet your needs, configure or program the Altera device.

Figure 8–1 shows the recommended design flow when using the Synplify and the Quartus II software.



Figure 8-1. Recommended Design Flow

The Synplify and Synplify Pro software support both VHDL and Verilog HDL source files. The Synplify Pro software also supports mixed synthesis, allowing a combination of VHDL and Verilog HDL source files.

Specify timing constraints and attributes for the design in a Synplify Constraints File (.sdc) with the SCOPE editor in the Synplify software or directly in the HDL source file. Compiler directives can also be defined in the HDL source file. Many of these constraints are forward-annotated in the Tcl file for Quartus II software use. You can save all project options and included files in a Synplify Project file (.prj).

The HDL Analyst that is included in the Synplify software is a graphical tool for generating schematic views of the technology-independent register transfer level (RTL) view netlist (.srs) and technology-view netlist (.srm) files. You can use the Synplify HDL Analyst to visually analyze and debug your design. The HDL Analyst supports cross probing between the RTL and Technology views, the HDL source code, and the Finite State Machine (FSM) viewer. Refer to "FSM Compiler" on page 8–9.



A separate license file is required to enable the HDL Analyst in the Synplify software. The Synplify Pro software includes the HDL Analyst.

Once synthesis is complete, import the electronic design interchange format (EDIF) or Verilog Quartus Mapping (VQM) netlist to the Quartus II software for place-and-route. You can use the Tcl file generated by the Synplify software to forward-annotate your constraints, and optionally to set up your project in the Quartus II software.

If the area and timing requirements are satisfied, use the files generated by the Quartus II software to program or configure the Altera device. As shown in Figure 8–1, if your area or timing requirements are not met, you can change the constraints in the Synplify software or the Quartus II software and repeat the synthesis. Repeat the process until the area and timing requirements are met.

While you can perform simulation at various points in the process, final timing analysis should be performed after placement and routing is complete. Formal verification may also be performed at various stages of the design process.



For more information about how the Synplify software supports formal verification, refer to the *Formal Verification* section in volume 3 of the *Quartus II Handbook*.

You can also use other options and techniques in the Quartus II software to meet area and timing requirements. One such option is called WYSIWYG Primitive Resynthesis, which can perform optimizations on your VQM netlist within the Quartus II software.



For information about netlist optimizations, refer to the *Netlist Optimizations & Physical Synthesis* chapter in volume 2 of the *Quartus II Handbook*.

In some cases, you may be required to modify the source code if area and timing requirements cannot be met using options in the Synplify and Quartus II software.

After synthesis, the Synplify software produces several intermediate and output files. Table 8–1 lists these file types.

| Table 8–1. Synplify Intermediate & Output Files |                                                                                               |  |
|-------------------------------------------------|-----------------------------------------------------------------------------------------------|--|
| File Extensions                                 | File Description                                                                              |  |
| .srs                                            | Technology-independent RTL netlist that can be read only by the Synplify software             |  |
| .srm                                            | Technology view netlist                                                                       |  |
| .srr (1)                                        | Synthesis Report file                                                                         |  |
| .edf/.vqm (2)                                   | Technology-specific netlist in electronic design interchange format (EDIF) or VQM file format |  |
| .acf/.tcl (3)                                   | Forward-annotated constraints file containing constraints and assignments                     |  |

#### Notes to Table 8-1:

- (1) This report file includes performance estimates that are often based on pre-place-and-route information. Use the f<sub>MAX</sub> reported by the Quartus II software after place-and-route, because it is the only reliable source of timing information. This report file includes post-synthesis device resource utilization statistics that may inaccurately predict resource usage after place-and-route. The Synplify software does not account for black box functions nor for logic usage reduction achieved through register packing performed by the Quartus II software. Register packing combines a single register and look-up table (LUT) into a single logic cell, reducing the logic cell utilization below the Synplify software estimate. Use the device utilization reported by the Quartus II software after place-and-route.
- (2) An EDIF output file (.edf) is created only for ACEX® 1K, FLEX® 10K, FLEX 10KA, FLEX 10KE, FLEX 6000, FLEX 8000, MAX® 7000, MAX 9000, and MAX 3000 devices. A VQM file is created for all other Altera device families.
- (3) An Assignment and Configuration File (.acf) file is created only for ACEX 1K, FLEX 10K, FLEX 10KA, FLEX 10KE, FLEX 6000, FLEX 8000, MAX 7000, MAX 9000, and MAX 3000 devices. The ACF is generated for backward compatibility with the MAX+PLUS® II software. A Tcl file for the Quartus II software is created for all devices, and also contains Tcl commands to create a Quartus II project and, if applicable, the MAX+PLUS® II assignments are imported from the ACF file.

#### **Output Netlist File Name & Result Format**

Specify the output netlist directory location and name by performing the following steps:

- 1. On the Project menu, click **Implementation Options**.
- 2. Click the **Implementation Results** tab.

- 3. In the **Results Directory** box, type your output netlist file directory location.
- 4. In the **Result File Name** box, type your output netlist file name.

By default, directory and file name are set to the project implementation directory and the top-level design module or entity name.

The **Result Format** and **Quartus version** options are also available on the **Implementation Results** tab. The **Result Format** list specifies an EDIF or VQM netlist depending on your device family. The software creates an EDIF output netlist file only for ACEX 1K, FLEX 10K, FLEX 10KA, FLEX 10KE, FLEX 6000, FLEX 8000, MAX 7000, MAX 9000, and MAX 3000 devices. For other Altera devices, the software generates a VQM-formatted netlist.

Beginning with the Synplify software version 8.4, select the version of the Quartus II software that you are using in the **Quartus version** list. This option ensures that the netlist is compatible with the software version and supports the newest features. Altera recommends using the latest version of the Quartus II software whenever possible. If your Quartus II software is newer than the versions available in the **Quartus version** list, check if there is a newer version of the Synplify software available that supports the current Quartus II software version. Otherwise, choose the latest version in the list for the best compatibility.

### Synplify Optimization Strategies

As designs become more complex and require increased performance, using different optimization strategies has become important. Combining Synplify software constraints with VHDL and Verilog HDL coding techniques and Quartus II software options can help you obtain the required results.



For additional design and optimization techniques, refer to the *Design Recommendations for Altera Devices* chapter in volume 1 and the *Area & Timing Optimization* chapter in volume 2 of the *Quartus II Handbook*.

The Synplify software offers many constraints and optimization techniques to improve your design's performance. The Synplify Pro software adds some additional techniques that are not supported in the basic Synplify software. Wherever this document describes Synplify support, this includes both the basic Synplify and the Synplify Pro software; Synplify Pro-only features are labeled as such. This section provides an overview of some of the techniques you can use to help improve the quality of your results.



For more information about applying the attributes discussed in this section, refer to the *Tasks & Tips* chapter of the *Synplify Software User Guide*.

#### Implementations in Symplify Pro

In the Synplify Pro software, on the Project menu, click **New Implementation** to create different synthesis results without overwriting the others. For each implementation, specify the target device, synthesis options, and constraint files. Each implementation generates its own subdirectory that contains all the resulting files, including VQM and Tcl files, from a compilation of the particular implementation. You can then compare the results of the different implementations to find the optimal set of synthesis options and constraints for a design.

#### **Timing-Driven Synthesis Settings**

The Synplify software supports timing-driven synthesis through user-assigned timing constraints to optimize the performance of the design. The Synplify software optimizes the design to attempt to meet these constraints.

The Quartus II NativeLink feature allows timing constraints that are applied in the Synplify software to be forward-annotated for the Quartus II software using a Tcl script file for timing-driven place and route. Refer to "Passing Constraints to the Quartus II Software" for more details about how constraints such as clock frequencies, false paths, and multicycle paths are forward-annotated. This section explains some of the important timing constraints in the Synplify software.



The Synplify Synthesis Report File (.srr) contains timing reports of estimated place-and-route delays. The Quartus II software can perform further optimizations on a post-synthesis netlist from third-party synthesis tools. In addition, designs may contain black boxes or IP functions that have not been optimized by the third-party synthesis software. Actual timing results are obtained only after the design has gone through full placement and routing in the Quartus II software. For these reasons, the Quartus II post place-and-route timing reports provide a more accurate representation of the design. The statistics in these reports should be used to evaluate design performance.

#### Clock Frequencies

For single-clock designs, specify a global frequency when using the push-button flow. While this flow is simple and provides good results, often it does not meet the performance requirements for more advanced

designs. You can use timing constraints, compiler directives, and other attributes to help optimize the performance of a design. You can enter these attributes and directives directly in the HDL code. Alternatively, you can enter attributes (not directives) into an SDC file with the SCOPE editor in the Synplify software.

Use the SCOPE editor to set global frequency requirements for the entire design and individual clock settings. Use the **Clocks** tab in the SCOPE editor to specify frequency (or period), rise times, fall times, duty cycle, and other settings. Assigning individual clock settings, rather than over-constraining the global frequency, helps the Quartus II software and the Synplify software achieve the fastest clock frequency for the overall design. The define clock attribute assigns clock constraints.

#### Multiple Clock Domains

The Synplify software can perform timing analysis on unrelated clock domains. Each clock group is a different clock domain and is treated as unrelated to the clocks in all other clock groups. All the clocks in a single clock group are assumed to be related and the Synplify software automatically calculates the relationship between the clocks. You can assign clocks to a new clock group, or put related clocks in the same clock group by using the **Clocks** tab in the SCOPE editor or with the define clock attribute.

#### Input/Output Delays

Specify the input and output delays for the ports of a design in the **Input/Output** tab of the SCOPE editor or with the define\_input\_delay and define\_output\_delay attributes. The Synplify software does not allow you to assign the  $t_{CO}$  and  $t_{SU}$  values directly to inputs and outputs. However, a  $t_{CO}$  value can be inferred by setting an external output delay, and a  $t_{SU}$  value can be inferred by setting an external input delay. The following equations illustrate the relationship between  $t_{CO}/t_{SU}$  and the input/output delays:

- (1)  $t_{CO} = \text{clock period} \text{external output delay}$
- (2)  $t_{SU} = \text{clock period} \text{external input delay}$

When the syn\_forward\_io\_constraints attribute is set to 1, the Synplify software passes the external input and output delays to the Quartus II software using NativeLink integration. The Quartus II software then uses the external delays to calculate the maximum system frequency.

#### Multicycle Paths

Specify any multicycle paths in the design in the Multi-Cycle Paths tab of the SCOPE editor or with the define\_multicycle\_path attribute. A multicycle path is a path that requires more than one clock cycle to propagate. It is important to specify which paths are multicycle to avoid having the Quartus II and the Synplify compilers work excessively on a non-critical path. Not specifying these paths can also result in an inaccurate critical path being reported during timing analysis.

#### False Paths

False paths are paths that should not be considered during timing analysis or which should be assigned low (or no) priority during optimization. Some examples of false paths are slow asynchronous resets and test logic added to the design. Set these paths in the **False Paths** tab of the SCOPE editor. Use the define false path attribute.

#### **FSM Compiler**

If the FSM Compiler is turned on, the compiler automatically detects state machines in a design. The compiler can then extract and optimize the state machine. The FSM Compiler analyzes the state machine and decides to implement sequential, gray, or one-hot encoding based on the number of states. It also performs unused-state analysis, optimization of unreachable states, and minimization of transition logic.

If the FSM Compiler is turned off, the compiler does not infer state machines. The state machines are implemented as coded in the HDL code. Thus, if the coding style for the state machine was sequential, then the implementation is also sequential. If the FSM Compiler is turned on, the compiler infers the state machines. The implementation is based on the number of states regardless of the coding style in the HDL code.

You can use the syn\_state\_machine complier directive to specify or prevent a state machine from being extracted and optimized. To override the default encoding of the FSM Compiler, use the syn\_encoding directive.

| 771 1 ( (1             | 3 1 1 1                         | · TE 1 1 0 0  |
|------------------------|---------------------------------|---------------|
| The values for the syn | encoding directive are shown in | in Table 8–2  |
| THE VALUE FOR THE BYIL | chicoaring affective are brown  | mi idoic o z. |

| Table 8–2. syn_encoding Directive Values |                                                                                                                                                                                                                                                                                                                   |  |
|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Value                                    | Description                                                                                                                                                                                                                                                                                                       |  |
| Sequential                               | Generates state machines with the fewest possible flip-flops. Sequential, also called binary, state machines are useful for area-critical designs when timing is not the primary concern.                                                                                                                         |  |
| Gray                                     | Generates state machines where only one flip-flop changes during each transition. Gray-encoded state machines tend to be free of glitches.                                                                                                                                                                        |  |
| One-hot                                  | Generates state machines containing one flip-flop for each state. One-hot state machines typically provide the best performance and shortest clock-to-output delays. However, one-hot implementations are usually larger than binary implementations.                                                             |  |
| Safe                                     | Generates extra control logic to force the state machine to the reset state if an invalid state is reached. The safe value can be used in conjunction with the other three values, which results in the state machine being implemented with the requested encoding scheme and the generation of the reset logic. |  |

Example 8–1 shows sample VHDL code for applying the syn\_encoding directive.

#### Example 8-1. VHDL Code for syn\_encoding

```
SIGNAL current_state : STD_LOGIC_VECTOR(7 DOWNTO 0);
ATTRIBUTE syn_encoding : STRING;
ATTRIBUTE syn encoding OF current state : SIGNAL IS "sequential";
```

The default is to optimize state machine logic for speed and area, but this is potentially undesirable for critical systems. The safe value generates extra control logic to force the state machine to the reset state if an invalid state is reached.

#### FSM Explorer in Synplify Pro

The Synplify Pro software can use the FSM Explorer to automatically explore different encoding styles for a state machine, and then implement the best encoding based on the overall design constraints. The FSM Explorer uses the FSM Compiler to identify and extract state machines from a design. However, unlike the FSM Compiler which chooses the encoding style based on the number of states, the FSM Explorer tries several different encoding styles before choosing a specific one. The trade-off is that the compilation requires more time to perform the analysis of the state machine, but finds an optimal encoding scheme for the state machine.

#### **Optimization Attributes & Options**

The following sections list other attributes and options that you can modify in the Synplify software to improve your design performance.

#### Retiming in Synplify Pro

The Synplify Pro software can retime a design, which can improve the timing performance of sequential circuits by moving registers (register balancing) across combinational elements. Be aware that retimed registers incur name changes. To retime your design, turn on the **Retiming** option in the **Device** tab in the **Implementation Options** section, or use the syn\_allow\_retiming attribute.

#### Maximum Fan-Out

When your design has critical path nets with high fan-outs, you can use the <code>syn\_maxfan</code> attribute to control the fan-out of the net. Setting this attribute for a specific net results in the replication of the driver of the net to reduce the overall fan-out. The <code>syn\_maxfan</code> attribute takes an integer value and applies it to inputs or registers. (The <code>syn\_maxfan</code> attribute cannot be used to duplicate control signals, and the minimum allowed value of the attribute is 4.) Using this attribute may result in increased logic resource utilization, thus putting a strain on routing resources and leading to long compile times and difficult fitting.

If you need to duplicate an output register or output enable register, you can create a register for each output pin by using the syn\_useioff attribute (refer to "Register Packing").

#### Preserving Nets

During synthesis, the compiler maintains ports, registers, and instantiated components. However, some nets may not be maintained in order to create an optimized circuit. Applying the <code>syn\_keep</code> directive overrides the optimization of the compiler and preserves the net during synthesis. The <code>syn\_keep</code> directive takes a Boolean value and can be applied to wires (Verilog HDL) and signals (VHDL). Setting the value to <code>true</code> preserves the net through synthesis.

#### Register Packing

Altera devices allow for the packing of registers into I/O cells. Altera recommends allowing the Quartus II software to make the I/O register assignments. However, it is possible to control register packing with the syn\_useioff attribute. The syn\_useioff attribute takes a Boolean value and can be applied to ports or entire modules. Setting the value to 1 instructs the compiler to pack the register into an I/O cell. Setting the value to 0 prevents register packing in both the Synplify and Quartus II software.

#### Resource Sharing

The Synplify software uses resource sharing techniques during synthesis by default to reduce area. Turning off the **Resource Sharing** option on the **Options** tab of the **Implementation Options** dialog box can improve performance results for some designs. If you turn off this option, be sure to check the results to determine if it helps the timing performance, and if it does not help, then you should leave it on.

#### Preserving Hierarchy

The Synplify software performs cross-boundary optimization by default. This results in the flattening of the design to allow optimization. Use the syn\_hier attribute to over-ride the default compiler settings. The syn\_hier attribute takes a string value and applies it to modules and/or architectures. Setting the value to hard maintains the boundaries of a module and/or architecture, and prevents cross-boundary optimization.

By default, the Synplify software generates a hierarchical VQM file. To flatten the file, set the syn\_netlist\_hierarchy attribute equal to "0".

#### Register Input & Output Delays

The advanced options called define\_reg\_input\_delay and define\_reg\_output\_delay can speed up paths feeding a register or coming from a register by a specific number of nanoseconds. The Synplify software attempts to meet the global clock frequency goals for a design as well as the individual clock frequency goals (set with define\_clock). You can use these attributes to add delay to paths feeding into/out of registers to further constrain critical paths.

These options are useful in closing timing when your design does not meet timing goals because the routing delay after placement and routing exceeds the delay predicted by the Synplify software. Rerun synthesis using this option, specifying the actual routing delay (from place-and-route results) so that the tool can meet the required clock frequency.

In the SCOPE constraint editor, use the registers panel with the following entries:

- Register—Specifies the name of the register. If you have initialized a compiled design, you can choose the name from the list.
- Type—Specifies whether the delay is an input or output delay.
- Route—Shrinks the effective period for the constrained registers by the specified value without affecting the clock period that is forward-annotated to the Quartus II software.

Use the following Tcl command syntax to specify an input or output register delay in nanoseconds.

#### Example 8–2. Specifying an Input or Output Register Delay Using Tcl Command Syntax

```
define_reg_input_delay {<Register>} -route <delay in ns>
define_reg_output_delay {<Register>} -route <delay in ns>
```

#### syn direct enable

This attribute controls the assignment of a clock-enable net to the dedicated enable pin of a register. Using this attribute, you can direct the Synplify mapper to use a particular net as the only clock enable when the design has multiple clock enable candidates.

You can also use this attribute as a compiler directive to infer registers with clock enables. To do so, enter the <code>syn\_direct\_enable</code> directive in your source code, not the SCOPE spreadsheet.

The syn\_direct\_enable data type is Boolean. A value of **1** or **true** enables net assignment to the clock-enable pin. The syntax for Verilog HDL is shown below:

```
object /* synthesis syn_direct_enable = 1 */;
```

#### Standard I/O Pad

For certain Altera devices and the equivalent device I/O standard, you can specify the I/O standard type to use for the I/O pad in the design using the **I/O Standard** panel in the Synplify SCOPE editor.

Example 8–3 shows the Synplify SDC syntax for the **define\_io\_standard** constraint, in which the delay\_type must be either input\_delay or output\_delay.

#### Example 8-3. Synplify SDC Syntax for the define\_io\_standard Constraint

```
define_io_standard [-disable|-enable] {<objectName>} -delay_type \
[input_delay|output_delay] <columnTclName>{<value>} \
[<columnTclName>{<value>}...]
```



For details about supported I/O standards, refer to *Altera I/O Standards* in the *Symplify Reference Manual*.

#### **Altera-Specific Attributes**

The following attributes are for use with specific Altera device features. These attributes are forward-annotated to the Quartus II project and are used during the place-and-route process.

altera\_chip\_pin\_lc

Use this attribute to make pin assignments. This attribute takes a string value and applies it to inputs and outputs.



This attribute is not supported for any of the MAX series devices. In the SCOPE editor, select the attribute altera\_chip\_pin\_lc and set the value to a pin number or a list of pin numbers.

Example 8–4 shows VHDL code for making location assignments to ACEX 1K and FLEX 10KE devices.



The "@" is used to specify pin locations for ACEX 1K and FLEX 10KE devices. For these devices the pin location assignments are written to the output EDIF.

#### Example 8-4. Making Location Assignments to ACEX 1K & FLEX 10KE Devices, VHDL

```
ENTITY sample (data_in : IN STD_LOGIC_VECTOR (3 DOWNTO 0);
  data_out: OUT STD_LOGIC_VECTOR (3 DOWNTO 0));
ATTRIBUTE altera_chip_pin_lc : STRING;
ATTRIBUTE altera_chip_pin_lc OF data_out : SIGNAL IS "@14, @5,@16, @15";
```

Example 8–5 shows VHDL code for making location assignments for other Altera devices. The pin location assignments for these devices are written to the output Tcl script.

#### Example 8-5. Making Location Assignments to Other Devices, VHDL

```
ENTITY sample (data_in : IN STD_LOGIC_VECTOR (3 DOWNTO 0);
   data_out: OUT STD_LOGIC_VECTOR (3 DOWNTO 0));
ATTRIBUTE altera_chip_pin_lc : STRING;
ATTRIBUTE altera_chip_pin_lc OF data_out : SIGNAL IS "14, 5, 16, 15";
```



The data\_out signal is a 4-bit signal; data\_out [3] is assigned to pin 14 and data\_out [0] is assigned to pin 15.

#### altera implement in esb or altera implement in eab

You can use these attributes to implement logic in either embedded system blocks (ESBs) or embedded array blocks (EABs) rather than in logic resources to improve area utilization. The modules selected for such implementation cannot have feedback paths, and either all or none of the I/Os must be registered. This attribute takes a boolean value and can be applied to instances. (This option is applicable for devices with ESBs/EABs only. For example, the Stratix® family of devices is not supported by this option. This attribute is ignored for designs targeting devices that do not have ESBs or EABs.)

#### altera\_io\_powerup

You can use this attribute to define the power-up value of an I/O register that has no set or reset. This attribute takes a string value (**high | low**) and applies it to ports that have I/O registers.

#### altera io opendrain

Use this attribute to specify open-drain mode I/O ports. This attribute takes a boolean value and applies it to outputs or bidirectional ports for devices that support open-drain mode.

# Exporting Designs to the Quartus II Software Using NativeLink Integration

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 other EDA design entry or synthesis, simulation, and timing analysis tools automatically from within the Quartus II software. After a design is synthesized in the Synplify software, a VQM (or EDIF) file and Tcl files are used to import the design into the Quartus II software for place-and-route. You can run the Quartus II software from within the Synplify software or as a standalone application. Once you have imported the design into the Quartus II software, you can specify different options to further optimize the design.



When you are using NativeLink integration, the path to your project must not contain white space. The Synplify software uses Tcl scripts to communicate with the Quartus II software, and the Tcl language does not accept arguments with white space in the path.

You can use NativeLink integration to integrate the Synplify software and Quartus II software with a single GUI for both the synthesis and place-and-route operations. NativeLink integration allows you to run the Quartus II software from within the Synplify software GUI or to run the Synplify software from within the Quartus II software GUI.

## Running the Quartus II Software from within the Synplify Software

To use the Quartus II software from within the Synplify software, you must first verify that the QUARTUS\_ROOTDIR environment variable contains the Quartus II software installation directory. This environment variable is required to use the Synplify and Quartus II software together.

Under each Implementation in the Synplify software, you can create a place-and-route implementation called **pr**\_<*number*> (Altera Place & Route). You can create new place and route implementations using the New P&R button in the GUI. To run the Quartus II software in command-line mode after each synthesis run, use the text box to turn on the place-and-route implementation. The results of the place and route are written to a log file in the **pr**\_<*number*> directory under the current implementation directory.

You can also use the commands in the Quartus II menu to run the Quartus II software at any time following a successful completion of synthesis. Use one of the following commands from the **Quartus II** submenu under the Options menu in the Synplify software:

- Launch Quartus—Opens the Quartus II software GUI and creates a Quartus II project with the synthesized output file, forward-annotated timing constraints, and pin assignments. You can use this to configure options for the project and execute any Ouartus II commands.
- Run Background Compile—Runs the Quartus II software in command-line mode with the project settings from the synthesis run. The results of the place-and-route are written to a log file.

The cons.tcl file is used to set up the Quartus II project
and calls the cons.tcl file to pass constraints from the Synplify
software to the Quartus II software. The cproject\_name.tcl file contains
device, timing, and location assignments.

#### Using the Quartus II Software to Launch the Synplify Software

You can set up the Quartus II software to run the Synplify software for synthesis using NativeLink integration. This feature allows you to use the Synplify software to synthesize a design as part of a normal compilation in the Quartus II software.

To set up Synplify in Quartus II, on the Tools menu, click **Options**. In the **Options** window, click **EDA Tool Options** and specify the path of Synplify software, as shown in Figure 8–2.



Figure 8–2. Specifying the Path to the Symplify Software



For detailed information about using NativeLink integration with the Synplify software, refer to the Quartus II Help.



Running the Synplify software with NativeLink integration requires a floating network license (as opposed to a node-locked single-PC license), because batch mode compilation is supported only with floating licenses.

#### Running the Quartus II Software Manually Using the Synplify-Generated Tcl Script

You can also use the Quartus II software separately from the Synplify software. To run the Tcl script generated by the Synplify software to set up your project, perform the following steps:

- Ensure the VQM and Tcl files are located in the same directory (they should both be located in the implementation directory by default).
- 2. In the Quartus II software, on the View menu, point to **Utility Windows** and click **Tcl Console**. The Quartus II Tcl Console opens.

3. At the Tcl Console command prompt, type:

```
source <path>/<project name> cons.tcl ←
```

#### **Passing Constraints to the Quartus II Software**

This section describes how Synplify constraints are converted to the equivalent Quartus II assignments and are forward-annotated to the Quartus II software with Tcl commands.

#### Default or Global Clock Frequency

Use the following Synplify command to set the Synplify default or global clock frequency that applies to the entire project:

```
set option -frequency < frequency >
```

The *<frequency>* is specified in MHz. If a global frequency is not specified, the software uses the default global clock frequency of 1 MHz.

The set\_option Symplify constraint is passed to the Quartus II software with the following command:

```
set_global_assignment -name FMAX_REQUIREMENT
<frequency> MHz
```

If a frequency is not specified in the Quartus II software, the software uses the default global clock frequency of 1 GHz.

#### Individual Clocks & Frequencies

You can specify clock frequencies for individual clocks with the following Synplify commands:

#### Example 8-6. Specifying Clock Frequencies for Individual Clocks

```
define_clock -name {<clock_name>} -freq <frequency> -clockgroup <clock_group>
-rise <rise_time> -fall <fall_time>
define_clock -name {<clock_name>} -period <period> -clockgroup <clock_group>
-rise <rise_time> -fall <fall_time>
```

Table 8–3 shows the command arguments.

| Table 8–3. Command Arguments |                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Argument                     | Description                                                                                                                                                                                                                                                                                                                                                              |
| -name                        | The < <i>clock_name</i> > specifies a design port name or a register output signal name, and, after synthesis, corresponds to a < <i>mapped_clock_name</i> >.                                                                                                                                                                                                            |
| -freq (1)                    | The <frequency> is specified in MHz.</frequency>                                                                                                                                                                                                                                                                                                                         |
| -period <i>(2)</i>           | The <period> is specified in ns.</period>                                                                                                                                                                                                                                                                                                                                |
| -clockgroup                  | If the <clock_group> is not specified, it defaults to default_clkgroup. Synplify assumes all clocks belonging to the same clock group are related. If you do not specify a clock group, the clock belongs to the default clock group. Therefore, if you do not specify any clock groups, all the clocks are considered related by default in the software.</clock_group> |
| -rise<br>-fall               | The <rise_time> and <fall_time> specify a non-default duty cycle. By default, the Synplify synthesis tool assumes that the clock is a 50% duty cycle clock, with the rising edge at 0 and the falling edge at period/2. If you have another duty clock cycle, you can specify the appropriate Rise At and Fall At values.</fall_time></rise_time>                        |

#### Notes to Table 8-3:

- (1) When the <frequency> is specified, the Synplify software uses <fall\_time> and <frequency> to calculate the duty cycle with the following formula: duty cycle = (<fall\_time> <rise\_time>) × <frequency> ÷ 10.
- (2) When the /period is specified, the Synplify software uses <fall\_time</pre> and /period to calculate the duty\_cycle with the following formula: duty\_cycle = 100 × (<fall\_time</pre> / / rise\_time) ÷ / + / period.

The equivalent Quartus II commands depend on how the clock groups are defined. In the Quartus II software, clocks that belong to the same or related clock settings are considered related clocks. Clocks assigned to unrelated clock settings are unrelated clocks. There is a one-to-one correspondence between each Quartus II clock setting and a Synplify clock group.



The following sections describe only the frequency constraints. You can use the corresponding constraints for period.

#### Virtual Clocks

The Quartus II software supports virtual clocks. If you use the virtual clock setting in Synplify, the setting is mapped to a constraint in the Quartus II software.

## Route Delay Option

The -route option in Synplify clock constraints is designed for use for synthesis only if you do not meet timing goals because the routing delay after placement and routing exceeds the delay predicted by the Synplify software. This constraint does not have to be forward annotated to the Ouartus II software.

## Global Signals

The Synplify software automatically promotes clock signals to global routing lines and passes **Global Signal** assignments to the Quartus II software. The assignments ensure that the same global routing constraints are applied during placement and routing.

Note that the signals promoted to global routing can be different than the ones that the Quartus II software promotes to global routing by default. Synplify promotes only clock signals and not other control signals such as reset or enable. By default, without constraints from the Synplify software, the Quartus II software promotes control signals to global routing if they have high fan-out.

## Multiple Clocks in Different Clock Groups

You can specify clock frequencies for multiple clocks with the Synplify commands shown in Example 8–7.

## Example 8-7. Specifying Clock Frequencies for Multiple Clocks

```
define_clock -name { <clock_name1 > } -freq <frequency1 > \
-clockgroup <clock_group1 > -rise <rise_time1 > -fall <fall_time1 > \
define_clock -name { <clock_name2 > } -freq <frequency2 > \
-clockgroup <clock_group2 > -rise <rise_time2 > -fall <fall_time2 > \
```

<clock\_group1> and <clock\_group2> are unique names defined in the
Synplify software for base clock settings in the Quartus II software.

If the clock *<rise\_time>* is zero ("0"), multiple separate clocks are passed to the Quartus II software with the commands shown in Example 8–8:

## Example 8–8. Quartus II Assignments for Multiple Clocks if the Clock Rise Time is Zero

```
create_base_clock -fmax <frequency1>MHz -duty_cycle <duty_cycle1> \
-target mapped_clock_name1 <base_clock_setting1>
create_base_clock -fmax <frequency2>MHz -duty_cycle <duty_cycle2> \
-target mapped clock name2 <base_clock setting2>
```

If the clock <*rise\_time*> is non-zero, multiple separate clocks are passed to the Quartus II software with the following commands shown in Example 8–9:

## Example 8-9. Quartus II Assignments for Multiple Clocks if the Clock Rise Time is Not Zero

```
create_base_clock -fmax <frequency1>MHz -duty_cycle <duty cycle1> \
-no_target <base clock setting1>

create_base_clock -fmax <frequency2>MHz -duty_cycle <duty cycle2> \
-no_target <base clock setting2>

create_relative_clock -base_clock <base clock setting1> -offset <rise time1>ns \
-duty_cycle <duty cycle1> -multiply <multiply by> -divide <divide by> \
-target <mapped clock name1> <derived clock setting2> -offset <rise time2>ns \
-duty_cycle <duty cycle2> -multiply <multiply by> -divide <divide by> \
-target <mapped clock -base_clock <base clock setting2> -offset <rise time2>ns \
-duty_cycle <duty cycle2> -multiply <multiply by> -divide <divide by> \
-target <mapped clock name2> <derived clock_setting2>
```

## Multiple Clocks with Different Frequencies in the Same Clock Group

You can specify multiple clocks with relative clock settings in the same clock group in Synplify with different frequencies with the commands shown in Example 8–10:

#### Example 8–10. Specifying Multiple Clocks with Different Frequencies in the Same Clock Group

```
define_clock -name { <clock_name1 > } -freq < frequency1 > -clockgroup < clock_group1 > \
-rise < rise_time1 > -fall < fall_time1 >

define_clock -name { <clock_name2 > } -freq < frequency2 > -clockgroup < clock_group1 > \
-rise < rise_time2 > -fall < fall_time2 >
```



When you specify clocks with different frequencies in the same clock group, the software calculates the *<multiply\_by>* and the *<divide\_by>* factors for relative clock settings from *<frequency1>* and *<frequency2>* in the clock group settings.

If the clock *<rise\_time>* is zero ("0"), multiple clocks with relative clock settings in the same clock group with different frequencies are passed to the Quartus II software with the commands shown in Example 8–11:

## Example 8–11. Quartus II Assignments for Multiple Clocks with Different Frequencies in the Same Clock Group, if the Clock Rise Time is Zero

```
create_base_clock -fmax <frequency1>MHz -duty_cycle <duty_cycle1> \
-target <mapped_clock_name1> <base_clock_setting1>

create_relative_clock -base_clock <base_clock_setting1> \
-duty_cycle <duty_cycle2> -multiply <multiply_by> -divide <divide_by> \
-target <mapped_clock_name2> <derived_clock_setting2>
```

Inter-Clock Relationships—Delays & False Paths between Clocks

You can set a clock-to-clock delay constraint in Synplify with the commands in Example 8–12.

## Example 8-12. Specifying Clock-to-Clock Delay Constraints

```
define_clock_delay -fall <clock_name1> -rise <clock_name2> <delay_value>
define_clock_delay -rise <clock_name1> -fall <clock_name2> <delay_value>
define_clock_delay -rise <clock_name1> -rise <clock_name2> <delay_value>
define_clock_delay -fall <clock_name1> -fall <clock_name2> <delay_value>
```

If <delay\_value> is set to false, these constraints in Synplify indicate a false path between the two clocks. If all four rise/fall clock-edge pairs are specified in the Synplify software, the Synplify constraints are mapped to the following constraint in the Quartus II software:

```
set_timing_cut_assignment -from <clock_name1> \
-to <clock name2>
```

If all four clock-edge pairs are not specified in Synplify, the constraint cannot be mapped to a constraint in the Quartus II software.

If <delay\_value> is set to a value other than false, these constraints in Synplify is not mapped to a constraint in the Quartus II software. The Quartus II software does not support clock-edge to clock-edge delay constraints.

#### False Paths

You can specify the false path constraint in Synplify with the command shown below.

```
define_false_path -from <sig_name1> -to <sig_name2>
```

The signals <*sig\_name1*> and <*sig\_name1*> can be design port names or register instance names.

The **define\_false\_path** constraint in Synplify is mapped to the constraint in the Quartus II software, as shown below.

```
set_timing_cut_assignment -from <sig_name1> \
-to <sig_name2>
```

Synplify can identify pairs of signal sets such that every member of the cross-product of these two sets is a valid false path constraint. Signal groups can be defined in the Quartus II software with the commands shown below.

```
timegroup -add_member sig_name1_i <sig_group1>
(for every signal in <sig_group1>)

timegroup -add_member sig_name2_i <sig_group2>
(for every signal in <sig_group2>)

set_timing_cut_assignment -from <sig_group1> \
-to <sig_group2>
```

If the signals <sig\_name1> or <sig\_name2> represent multiple signals such as a wildcard, group, or bus, the constraints you can expand appropriately for representation in the Quartus II software. The Quartus II software supports wildcard signal names, and signal groups for timing assignments. The Quartus II software does not support bus notation, such as A[7:4].

## False Path from a Signal

You can specify a false path constraint from a signal in Synplify with the following command:

```
define_false_path -from <sig_name>
```

The Quartus II software does not support "from-only" path specifications. You must also include a "to-path" specification. However, you can specify a wildcard for the -to signal. This constraint in Synplify is mapped to the following constraint in the Quartus II software:

```
set timing cut assignment -from <sig_name> -to {*}
```

## False Path to a Signal

You can specify a false path constraint to a signal in Synplify with the following command:

```
define false path -to <sig_name>
```

The Quartus II software does not support **to-only** path specifications. You must include a **from-path** specification." However, you can specify a wildcard for the -from signal. This constraint in Synplify is mapped to the following constraint in the Quartus II software:

```
set timing cut assignment -from {*} -to <sig_name>
```

## False Path Through a Signal

You can specify a false path constraint through a signal in Synplify with the following command:

```
define_false_path -from <sig_name1> -to <sig_name2> \
-through <sig_name3>
```

The Quartus II software does not currently support false paths with a "through path" specification. Any constraint in Synplify with a -through specification is not mapped to a constraint in the Quartus II software.

## Multicycle Paths

You can specify a multicycle path constraint in Synplify with the following command:

```
define_multicycle_path -from <sig_name1> \
-to <sig_name2> <clock_cycles>
```

This constraint in Synplify is mapped to the following constraint in the Quartus II software:

```
set_multicycle_assignment -from <sig_name1> \
-to <sig_name2> <clock_cycles>
```

If the signals <sig\_name1> or <sig\_name2> represent multiple signals such as a wildcard, group, or bus, the constraints can be appropriately expanded for representation in the Quartus II software as described in "False Paths" on page 8–9.



<clock\_cycles> is the number of clock cycles for the multicycle
path.

## Multicycle Path from a Signal

You can specify a multicycle path constraint from a signal in Synplify with the following command:

```
define multicycle path -from <sig_name> <clock_cycles>
```

This constraint is mapped using a wildcard for the -to value in the Quartus II software, similar to the false path constraints:

```
set_multicycle_assignment -from <sig_name> \
-to {*} <clock cycles>
```

## Multicycle Path to a Signal

You can specify a multicycle path constraint to a signal in Synplify with the following command:

```
define multicycle path -to <sig_name> <clock_cycles>
```

This constraint is mapped using a wildcard for the -from value in the Quartus II software, similar to the false path constraints:

```
set_multicycle_assignment -from {*} <sig_name> \
<clock_cycles>
```

### Multicycle Path Through a Signal

You can specify a multicycle path constraint through a signal in Synplify using the following command:

```
define_multicycle_path -from <sig_name1> -to <sig_name2> \
   -through <sig_name3> <clock_cycles>
```

The Quartus II software does not currently support multicycle paths with a **through path** specification. Any constraint in Synplify with a -through specification is not mapped to a constraint in the Quartus II software.

## Maximum Path Delays

You can specify the maximum path delay relationships between signals in Synplify with the following command:

```
define_path_delay -from <sig_name1> -to <sig_name2> \
-max <delay_value>
```

This constraint in Synplify is mapped to the following constraint in the Ouartus II software:

```
set_instance_assignment -from <sig_name1> \
-to <sig_name2> -name SETUP_RELATIONSHIP <delay_value>ns
```

The Quartus II software does not support signal groups or bus notation, and supports only register names for this constraint.

## Maximum Path Delay from a Signal

You can specify the maximum path delay constraint from a signal in Synplify with the following command:

```
define path delay -from <sig_name> -max <delay_value>
```

This constraint is mapped using a wildcard for the -to value in the Quartus II software, similar to false path constraints:

```
set_instance_assignment -from <sig_name> -to {*} \
-name SETUP RELATIONSHIP <delay_value>ns
```

## Maximum Path Delay to a Signal

You can specify the maximum path delay constraint to a signal in Synplify with the following command:

```
define path delay -to <sig_name> -max <delay_value>
```

This constraint is mapped using a wildcard for the -from value in the Quartus II software, similar to the false path constraints.

```
set_instance_assignment -from {*}<sig_name> \
-to <sig_name> -name SETUP_RELATIONSHIP <delay_value>ns
```

## Maximum Path Delay through a Signal

You can specify the maximum path delay constraint through a signal in Synplify with the following command:

```
define_path_delay -from <sig_name1> -to <sig_name2> \
-through <sig_name3> -max <delay_value>
```

The Quartus II software does not currently support maximum path delay constraints with a "through path" specification. Any constraint in Synplify with a -through specification is not mapped to a constraint in the Quartus II software.

### **Register Input & Output Delays**

These register input delay and register output delay constraints in Synplify are for use in synthesis only, and therefore are not forward-annotated to the Quartus II software.

#### **Default External Input Delay**

You can specify the default input delay constraint in Synplify with the following command:

```
define_input_delay -default <delay_value>
```

This constraint is mapped to the following constraint in the Quartus II software:

```
set_input_delay -clock {*} <delay_value> {*}
```

### Port-Specific External Input Delay

You can specify a port-specific input delay constraint in Synplify with the following command:

```
define_input_delay <input_port_name> <delay_value> \
-ref <clock_name>:<clock_edge>
```

The  $\langle clock\_edge \rangle$  can be set to r (rising edge) or f (falling edge).

When the clock edge is r (rising edge), this constraint is mapped to the following constraint in the Quartus II software:

```
set_input_delay -clock <clock_name> <delay_value> \
<input_port_name>
```

When the clock\_edge is f (falling edge), this constraint is not mapped to a constraint in the Quartus II software. The Quartus II software does not support the specification of input delays with respect to the falling edge of the clock.

#### **Default External Output Delay**

You can specify the default output delay constraint in Synplify with the following command:

```
define_output_delay -default <delay_value>
```

This constraint is mapped to the following constraint in the Quartus II software:

```
set_output_delay -clock {*} <delay_value> {*}
```

### Port-Specific External Output Delay

You can specify a port-specific input delay constraint in Synplify with the following command:

define\_output\_delay <output\_port\_name> <delay\_value> \
-ref <clock\_name>: <clock\_edge>

The < clock\_edge> can be set to r (rising edge) or f (falling edge). When the clock edge is r (rising edge), this constraint is mapped to the following constraint in the Quartus II software:

set\_output\_delay -clock <clock\_name> <delay\_value> \
<output\_port\_name>

When the clock\_edge is f (falling edge), this constraint is not mapped to a constraint in the Quartus II software. The Quartus II software does not support the specification of output delays with respect to the falling edge of the clock.

## Guidelines for Altera Megafunctions & Architecture-Specific Features

Altera provides parameterizable megafunctions including the LPMs, device-specific Altera megafunctions, intellectual property (IP) available as Altera MegaCore® functions, and IP available through the Altera Megafunction Partners Program (AMPPSM). You can use megafunctions by instantiating them in your HDL code or inferring them from generic HDL code.

If you want to instantiate a megafunction in your HDL code, you can do so by using the MegaWizard Plug-In Manager to parameterize the function or instantiating the function using the port and parameter definition. The MegaWizard Plug-In Manager provides a graphical interface within the Quartus II software for customizing and parameterizing any available megafunction for the design. "Instantiating Altera Megafunctions Using the MegaWizard Plug-In Manager" on page 8–30 describes the MegaWizard Plug-In Manager flow with the Synplify software.



For more information about specific Altera megafunctions, refer to the Quartus II Help. For more information about IP functions, refer to the appropriate IP documentation.

The Synplify software also automatically recognizes certain types of HDL code and infers the appropriate megafunction when a megafunction provides optimal results. The Synplify software provides options to control inference of certain types of megafunctions, as described in "Inferring Altera Megafunctions from HDL Code" on page 8–35.



For a detailed discussion about instantiating versus inferring megafunctions, refer to the *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook*. The *Recommended HDL Coding Styles* chapter also provides details on using the MegaWizard Plug-In Manager in the Quartus II software and explains the files generated by the wizard, as well as providing coding style recommendations and HDL examples for inferring megafunctions in Altera devices.

# Instantiating Altera Megafunctions Using the MegaWizard Plug-In Manager

When you use the MegaWizard Plug-In Manager to set up and parameterize a megafunction, the MegaWizard Plug-In Manager creates a VHDL or Verilog HDL wrapper file that instantiates the megafunction (a black box methodology). Some megafunctions also support the generation of a fully synthesizeable netlist for improved results with EDA synthesis tools such as Synplify (a clear box methodology). Clear- and black-box methodologies are described in the following sections.

## Clear Box Methodology

You can use the MegaWizard Plug-In Manager to generate a fully synthesizeable netlist. This flow is referred to as a clear box methodology because the Synplify software can "see" into the megafunction file. The clear box feature enables the synthesis tool to report more accurate timing estimates and resource utilization, and to take better advantage of timing driven optimization than a black box methodology.

For certain megafunctions, the clear box feature is enabled by turning the Generate clear box netlist file instead of a default wrapper file (for use with supported EDA synthesis tools only) option on in the MegaWizard Plug-In Manager. If the option does not appear, then clear box models are not supported for the selected megafunction. The Synplify software supports clear box models for Stratix and Cyclone™ devices. Turning this option on causes the Quartus II MegaWizard Plug-In Manager to generate a synthesizeable clear box netlist instead of the megafunction wrapper file described in "Black Box Methodology" on page 8–31.

## Using MegaWizard Plug-In Manager-Generated Verilog HDL Files for Clear Box Megafunction Instantiation

If you turn on the <code><output file>\_inst.v</code> option on the last page of the wizard, the MegaWizard Plug-In Manager generates a Verilog HDL instantiation template file for use in your Synplify design. This file can help you instantiate the megafunction clear box netlist file, <code><output file>.v</code>, in your top-level design. Include the megafunction clear-box netlist file in your Synplify Project. Also include the <code>stratix.v</code> library file from the

**lib/altera** directory of the Synplify installation directory; this file provides the port and parameter definitions of the clear box primitives. Finally, include the megafunction clear box netlist file, *<output file>.v*, along with your Synplify-generated VQM netlist in your Quartus II project.



The Synplify software reads the clear box description for the <code>alt\_pll</code> megafunction and writes the netlist for the phase-locked loop (PLL) into the resulting VQM output netlist. Therefore, for <code>alt\_pll</code> instantiations, do not include the megafunction clear box netlist file <code><output file>.v</code> in your Quartus II project. Reading the PLL function allows the Synplify software to interpret the multiplication and division factors in the PLL instantiation to make the correct timing assignment.

# Using MegaWizard Plug-In Manager-Generated VHDL Files for Clear Box Megafunction Instantiation

If you check the <code><output file>.cmp</code> and <code><output file>\_inst.vhd</code> options on the last page of the wizard, the MegaWizard Plug-In Manager generates a VHDL Component declaration file and a VHDL Instantiation template file for use in your design. These files help to instantiate the megafunction clear box netlist file, <code><output file>.vhd</code>, in your top-level design. Include the megafunction clear box netlist file in your Synplify Project. Finally, include the megafunction clear box netlist file, <code><output file>.vhd</code>, along with your Synplify-generated VQM netlist in your Quartus II project.



The Synplify software reads the clear box description for the alt\_pll megafunction and writes the netlist for the PLL into the resulting VQM output netlist. Therefore, for alt\_pll instantiations, do not include the megafunction clear box netlist file <output file>.vhd in your Quartus II project. Reading the PLL function allows the Synplify software to interpret the multiplication and division factors in the PLL instantiation to make the correct timing assignment.

## Black Box Methodology

Using the MegaWizard Plug-In Manager-generated wrapper file is referred to as a black-box methodology because the megafunction is treated as a black box in the Synplify software. The black box wrapper file is generated by default in the MegaWizard Plug-In Manager and is available for all megafunctions.

The black box methodology does not allow the synthesis tool any visibility into the function module and therefore does not take full advantage of the synthesis tool's timing driven optimization. For better timing optimization, especially if the black box does not have registered

inputs and outputs, add timing models to black boxes. Refer to "Other Synplify Software Attributes for Creating Black Boxes" on page 8–34 for details.

## Using MegaWizard Plug-In Manager-Generated Verilog HDL Files for Black Box Megafunction Instantiation

If you check the <code><output file>\_inst.v</code> and <code><output file>\_bb.v</code> options on the last page of the wizard, the MegaWizard Plug-In Manager generates a Verilog HDL instantiation template file and a hollow-body black-box module declaration for use in your Synplify design. The instantiation template file helps to instantiate the megafunction variation wrapper file, <code><output file>.v</code>, in your top-level design. Do not include the megafunction variation wrapper file in your Synplify Project, but add it, with your Synplify-generated VQM netlist, to your Quartus II project. Add the hollow-body black-box module declaration <code><output file>\_bb.v</code> to your Synplify Project to describe the port connections of the black box.

You can use the syn\_black\_box compiler directive to declare a module as a black box. The top-level design files must contain the megafunction port mapping and hollow-body module declaration, as described above. You can apply the syn\_black\_box directive to the module declaration in the top-level file or a separate file included in the project (such as the <output file>\_bb.v file) to instruct the Synplify software that this is a black box. The software compiles successfully without this directive, but reports an additional warning message. Using this directive allows you to add other directives as discussed in "Other Synplify Software Attributes for Creating Black Boxes" on page 8–34.

Example 8–13 shows a sample top-level file that instantiates **verilogCount.v**, which is a customized variation of the lpm\_counter generated by the MegaWizard Plug-In Manager.

#### Example 8-13. Top-Level Verilog HDL Code with Black Box Instantiation of Ipm\_counter

```
module topCounter (clk, count);
   input clk;
   output[7:0] count;
   verilogCounter verilogCounter inst (
       .clock ( clk ),
       .q (count)
);
endmodule
// Module declaration found in verilogCounter bb.v
// The following attribute is added to create a
// black box for this module.
module verilogCounter (
   clock,
   q) /* synthesis syn black box */;
   input clock;
   output[7:0] q;
endmodule
```

## Using MegaWizard Plug-In Manager-Generated VHDL Files for Black Box Megafunction Instantiation

If you check the <code><output file>.cmp</code> and <code><output file>\_inst.vhd</code> options on the last page of the wizard, the MegaWizard Plug-In Manager generates a VHDL component declaration file and a VHDL instantiation template file for use in your Synplify design. These files can help you instantiate the megafunction variation wrapper file, <code><output file>.vhd</code>, in your top-level design. Do not include the megafunction variation wrapper file in your Synplify Project, but add it, along with your Synplify-generated VQM netlist, to your Quartus II project.

You can use the <code>syn\_black\_box</code> compiler directive to declare a component as a black box. The top-level design files must contain the megafunction variation component declaration and port mapping, as described above. Apply the <code>syn\_black\_box</code> directive to the component declaration in the top-level file. The software compiles successfully without this directive, but reports an additional warning message. Using this directive allows you to add other directives such as the ones in the "Other Synplify Software Attributes for Creating Black Boxes" section.

Example 8–14 shows a sample top-level file that instantiates **vhdlCount.vhd**, which is a customized variation of the lpm\_counter generated by the MegaWizard Plug-In Manager.

#### Example 8–14. Top-level VHDL Code with Black Box Instantiation of Ipm\_counter

```
LIBRARY ieee:
USE ieee.std logic_1164.all;
ENTITY testCounter IS
   PORT
   (
      clk: IN STD LOGIC;
      count: OUT STD LOGIC VECTOR (7 DOWNTO 0)
   );
   END testCounter;
ARCHITECTURE top OF testCounter IS
component vhdlCount
   PORT (
      clock: IN STD LOGIC ;
      q: OUT STD LOGIC VECTOR (7 DOWNTO 0)
   );
end component;
attribute syn_black_box : boolean;
attribute syn_black_box of vhdlCount: component is true;
BEGIN
   vhdlCount inst : vhdlCount PORT MAP (
      clock => clk,
      q => count
   );
END top;
```

## Other Synplify Software Attributes for Creating Black Boxes

The black box methodology does not allow the synthesis tool any visibility into the function module. Thus, it does not take full advantage of the synthesis tool's timing-driven optimization. For better timing optimization, especially if the black box does not have registered inputs and outputs, add timing models to black boxes. This can be done with a "gray box" methodology by adding the syn\_tpd, syn\_tsu, and syn tco attributes. Refer to Example 8–15 for a Verilog HDL example.

### Example 8-15. Verilog HDL Example

```
module ram32x4(z,d,addr,we,clk);
/* synthesis syn_black_box syn_tcol="clk->z[3:0]=4.0"
    syn_tpdl="addr[3:0]->z[3:0]=8.0"
    syn_tsul="addr[3:0]->clk=2.0"
    syn_tsu2="we->clk=3.0" */
output[3:0]z;
input[3:0]d;
input[3:0]addr;
input we
input clk
endmodule
```

The following additional attributes are supported by the Synplify software to communicate details about the characteristics of the black box module within the HDL code:

- syn\_resources—Specifies the resources used in a particular black
- black\_box\_pad\_pin—Prevents mapping to I/O cells
- black box tri pin—Indicates a tri-stated signal



For more information about applying these attributes, refer to the *Tasks* & *Tips* chapter of the *Synplify User Guide*.

## **Inferring Altera Megafunctions from HDL Code**

The Synplify software uses Behavior Extraction Synthesis Technology (BEST) algorithms to infer high-level structures such as RAMs, ROMs, operators, FSMs, and so forth. It then keeps the structures abstract for as long as possible in the synthesis process. This allows the use of technology-specific resources to implement these structures by inferring the appropriate Altera megafunction when a megafunction provides optimal results. The following sections outline some of the Synplify-specific details when inferring Altera megafunctions. The Synplify software provides options to control inference of certain types of megafunctions, which is also described in the following sections.



For coding style recommendations and examples for inferring megafunctions in Altera devices, refer to the *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook*.

## Inferring Multipliers

Figure 8–3 shows the RTL view of an unsigned 8×8 multiplier with two pipeline stages after synthesis as seen in HDL Analyst in the Synplify software. This multiplier is converted into an lpm\_mult megafunction. For devices with DSP blocks, the software may implement the lpm\_mult function in a DSP block instead of logic elements (LEs), depending on device utilization.

Figure 8–3. HDL Analyst View of Ipm\_mult Megafunction (Unsigned 8×8 Multiplier with Pipeline=2)



#### **Resource Balancing**

While mapping multipliers to DSP blocks, the Synplify software performs resource balancing for optimum performance.

Altera devices have a fixed number of DSP blocks, which include a fixed number of embedded multipliers. If the design uses more multipliers than are available, the Synplify software automatically maps the extra multipliers to logic (logic elements (LEs), or adaptive logic modules (ALMs)).

If a design uses more multipliers than are available in the DSP blocks, the Synplify software maps the multipliers in the critical paths to DSP blocks. Next, any wide multipliers, which may or may not be in the critical paths, are mapped to DSP blocks. Smaller multipliers and multipliers that are not in the critical paths may then be implemented in logic (LEs or ALMs). This ensures that the design fits successfully in the device.

### Controlling the Inferring of DSP Blocks

Multipliers can be implemented in DSP blocks or in logic in Altera devices that contain DSP blocks. You can control this implementation through attribute settings in the Synplify software.

## Signal Level Attribute

You can control the implementation of individual multipliers by using the syn multstyle attribute as shown below:

<signal\_name> /\* synthesis syn multstyle = "logic" \*/

where signal\_name is the name of the signal.



This setting applies to wires only; it cannot be applied to registers.

Table 8–4 shows the values for the signal level attribute in the Synplify software that controls the implementation of the multipliers in the DSP blocks or LEs.

| Table 8–4. Attribute Settings for DSP Block in the Synplify Software |          |                                                                                    |  |
|----------------------------------------------------------------------|----------|------------------------------------------------------------------------------------|--|
| Attribute Name                                                       | Value    | Description                                                                        |  |
| syn_multstyle                                                        | lpm_mult | LPM Function inferred and multipliers implemented in DSP block                     |  |
| syn_multstyle                                                        | logic    | LPM function not inferred and multipliers implemented LEs by the Synplify software |  |

The following examples show simple Verilog HDL and VHDL code using the syn\_multstyle attribute.

## Example 8–16. Signal Attributes for Controlling DSP Block Inference in Verilog HDL Code

```
module mult(a,b,c,r,en);
input [7:0] a,b;
output [15:0] r;
input [15:0] c;
input en;
wire [15:0] temp /* synthesis syn_multstyle="logic" */;
assign temp = a*b;
assign r = en ? temp : c;
endmodule
```

#### Example 8–17. Signal Attributes for Controlling DSP Block Inference in VHDL Code

```
library ieee;
use ieee.std logic 1164.all;
use ieee.std logic unsigned.all;
entity onereg is port (
   r : out std_logic_vector(15 downto 0);
   en : in std logic;
   a : in std logic vector(7 downto 0);
   b : in std_logic_vector(7 downto 0);
   c : in std logic vector(15 downto 0)
   );
end onereg;
architecture beh of onereg is
signal temp : std_logic_vector(15 downto 0);
attribute syn multstyle : string;
attribute syn multstyle of temp : signal is "logic";
begin
temp <= a * b;
   r <= temp when en='1' else c;
end beh;
```

## Inferring RAM

Follow the guidelines below for the Synplify software to successfully infer RAM in a design:

- The address line must be at least 2 bits wide.
- Resets on the memory are not supported. Refer to the device family documentation for information about whether read and write ports must be synchronous.
- Some Verilog HDL statements with blocking assignments may not be mapped to RAM blocks, so avoid blocking statements when modeling RAMs in Verilog HDL.

For certain device families, the syn\_ramstyle attribute specifies the implementation to use for an inferred RAM. You can apply syn\_ramstyle globally, to a module, or to a RAM instance, to specify registers or block\_ram values. To turn off RAM inference, set the attribute value to registers.

When inferring RAM for certain Altera device families, the Synplify software generates additional bypass logic. This logic is generated to resolve a half-cycle read/write behavior difference between the RTL and post-synthesis simulations. The RTL simulation shows the memory being updated on the positive edge of the clock, and the post-synthesis

simulation shows the memory being updated on the negative edge. To eliminate the bypass logic, the output of the RAM must be registered. By adding this register, the output of the RAM is seen after a full clock cycle, by which time the update has occurred; thus, eliminating the need for the bypass logic.

For Stratix II, Stratix, Cyclone II, and Cyclone series devices, you can disable the creation of glue logic by setting the syn\_ramstyle value to no\_rw\_check. Use syn\_ramstyle with a value of no\_rw\_check to disable the creation of glue logic in dual-port mode.

Example 8–18 shows sample VHDL code for inferring dual-port RAM.

#### Example 8-18. VHDL Code for Inferred Dual-Port RAM

```
LIBRARY ieee;
USE ieee.std logic 1164.all;
USE ieee.std logic signed.all;
ENTITY dualport ram IS
PORT ( data out: OUT STD LOGIC VECTOR (7 DOWNTO 0);
   data in: IN STD LOGIC VECTOR (7 DOWNTO 0);
   wr addr, rd addr: IN STD LOGIC VECTOR (6 DOWNTO 0);
   we: IN STD LOGIC;
   clk: IN STD LOGIC);
END dualport ram;
ARCHITECTURE ram infer OF dualport ram IS
TYPE Mem Type IS ARRAY (127 DOWNTO 0) OF STD LOGIC VECTOR (7 DOWNTO 0);
SIGNAL mem: Mem_Type;
SIGNAL addr reg: STD_LOGIC_VECTOR (6 DOWNTO 0);
BEGIN
   data out <= mem (CONV INTEGER(rd addr));</pre>
   PROCESS (clk, we, data in) BEGIN
      IF (clk='1' AND clk'EVENT) THEN
          IF (we='1') THEN
          mem(CONV INTEGER(wr addr)) <= data in;</pre>
      END IF;
   END PROCESS;
END ram infer;
```

Example 8–19 shows an example of the VHDL code preventing bypass logic for inferring dual-port RAM. The extra latency behavior stems from the inferring methodology and is not required when instantiating a megafunction.

### Example 8–19. VHDL Code for Inferred Dual-Port RAM Preventing Bypass Logic

```
LIBRARY ieee;
USE ieee.std logic 1164.all;
USE ieee.std logic signed.all;
ENTITY dualport ram IS
PORT ( data out: OUT STD LOGIC VECTOR (7 DOWNTO 0);
   data in : IN STD LOGIC VECTOR (7 DOWNTO 0);
   wr addr, rd addr : IN STD LOGIC VECTOR (6 DOWNTO 0);
   we : IN STD_LOGIC;
   clk : IN STD LOGIC);
END dualport ram;
ARCHITECTURE ram infer OF dualport ram IS
TYPE Mem Type IS ARRAY (127 DOWNTO 0) OF STD LOGIC VECTOR (7 DOWNTO 0);
SIGNAL mem : Mem Type;
SIGNAL addr reg : STD LOGIC VECTOR (6 DOWNTO 0);
SIGNAL tmp_out : STD_LOGIC_VECTOR(7 DOWNTO 0); --output register
BEGIN
   tmp out <= mem (CONV INTEGER(rd addr));</pre>
   PROCESS (clk, we, data in) BEGIN
      IF (clk='1' AND clk'EVENT) THEN
          IF (we='1') THEN
          mem(CONV INTEGER(wr addr)) <= data in;</pre>
          END IF;
          data_out <= tmp_out; --registers output preventing</pre>
                            -- bypass logic generation.
      END IF;
   END PROCESS;
END ram infer;
```

## Inferring ROM

Follow the guidelines below for the Synplify software to successfully infer ROM in a design:

- The address line must be at least 2 bits wide.
- ROM must be at least half full.
- A CASE or IF statement must make 16 or more assignments using constant values of the same width.

## Inferring Shift Registers

The software infers shift registers for sequential shift components so that they can be placed in dedicated memory blocks in supported device architectures using the altshift\_taps megafunction.

If it is required, set the implementation style with the syn\_srlstyle attribute. If you do not want the components automatically mapped to shift registers, set the value to registers. You can set the value globally or on individual modules or registers.

For some designs, turning off shift register inference can improve the design performance.

## Incremental Compilation & Block-Based Design

As designs become more complex and designers work in teams, a block-based hierarchical or incremental design flow is often an effective design approach. In an incremental compilation flow, you can make changes to part of the design while maintaining the placement and performance of unchanged parts of the design. Design iterations are made dramatically faster by focusing new compilations on a particular design partitions and merging results with previous compilation results of other partitions. In a bottom-up or team-based approach, you can perform optimization on individual subblocks and then preserve the results before you integrate the blocks into a final design and optimize it at the top level.

MultiPoint synthesis, which is available for certain device technologies in the Synplify Pro software, provides an automated block-based incremental synthesis flow. The MultiPoint feature manages a design hierarchy to let you design incrementally and synthesize designs that take too long for top-down synthesis of the entire project. MultiPoint synthesis allows different netlist files to be created for different sections of a design hierarchy, and supports Quartus II incremental compilation and LogicLock<sup>TM</sup> design methodologies. It also ensures that only those sections of a design that have been updated are resynthesized when the design is compiled, reducing synthesis run time and preserving the results for the unchanged blocks. You can change and resynthesize one section of a design without affecting other sections of the design.

You can also partition your design and create different netlist files manually with the Synplify software (basic Synplify and Synplify Pro) by creating a separate project for the logic in each partition of the design. Creating different netlist files for each partition of the design means that each partition is independent of the others. When synthesizing the entire project, only portions of a design that have been updated have to be

resynthesized when you compile the design. You can make changes and resynthesize one partition of a design to create a new netlist file without affecting the synthesis results and placement of other partitions.

Hierarchical design methodologies can improve the efficiency of your design process, providing better design reuse opportunities and fewer integration problems when working in a team environment. When you use these incremental synthesis methodologies, you can take advantage of the incremental compilation and methodologies in the Quartus II software. You can perform placement and routing on only the changed partitions of the design, reducing place-and-route time and preserving your fitting results. Following the guidelines in this section can help you achieve good results with these methodologies.

The following list shows the general top-down compilation flow when using these features of the Quartus II software:

- Create Verilog HDL or VHDL design files as in the regular design flow.
- Determine which hierarchical blocks are to be treated as separate partitions in your design.
- Set up your design using the MultiPoint feature or separate projects so that a separate netlist file is created for each partition of the design.
- 4. If using separate projects, disable I/O pad insertion in the implementations for lower-level partitions.
- Compile and technology-map each partition in the Synplify Pro or Synplify software, making constraints as you would in the regular design flow.
- Import the VQM or EDIF netlist and the Tcl file for each partition into the Quartus II software and set up the Quartus II project(s) to use incremental compilation.
- Compile your design in the Quartus II software and preserve the compilation results using the post-fit netlist in incremental compilation.
- 8. When you make design or synthesis optimization changes to part of your design, resynthesize only the changed partition to generate new netlist and Tcl file. Do not regenerate netlist files for the unchanged partitions.

Import the new netlist and Tcl file into the Quartus II software and recompile the design in the Quartus II software using incremental compilation.

For more information about creating partitions and using the incremental compilation in the Quartus II software, refer to the *Quartus II Incremental Compilation for Hierarchical & Team-Based Design* chapter in volume 1 of the *Quartus II Handbook*. For more information about using the LogicLock feature in the Quartus II software, refer to the *LogicLock Design Methodology* chapter in volume 2 of the *Quartus II Handbook*.

## Hierarchy & Design Considerations with Multiple VQM Files

To ensure the proper functioning of the synthesis flow, you can create separate netlist files only for modules and entities. In addition, each module or entity should have its own design file. If two different modules are in the same design file but are defined as being part of different partitions, you cannot maintain incremental compilation since both partitions would have to be recompiled when you change one of the modules.

Altera recommends that you register all inputs and outputs of each partition. This makes logic synchronous and avoids any delay penalty on signals that cross partition boundaries.

If you use boundary tri-states in a lower-level block, the Synplify software pushes (or "bubbles") the tri-states through the hierarchy to the top level to make use of the tri-state drivers on output pins of Altera devices. Because bubbling tri-states requires optimizing through hierarchies, lower-level tri-states are not supported with a block-based compilation methodology. You should use tri-state drivers only at the external output pins of the device and in the top-level block in the hierarchy.

For more tips on design partitioning, refer to the *Design Recommendations* for Altera Devices chapter in volume 1 of the *Quartus II Handbook*.

## **Creating a Design with Separate Netlist Files**

The first stage of a hierarchical or incremental design flow is to ensure that different parts of your design do not affect each other. Ensure that you have separate netlists for each partition in your design so that you can take advantage of the incremental compilation and LogicLock design flows in the Quartus II software. If the whole design is in one netlist file, changes in one partition affect other partitions because of possible node name changes when you resynthesize the design.

You can generate multiple VQM files either by using the MultiPoint synthesis flow and LogicLock attributes in the Synplify Pro software, or by manually creating separate Synplify projects and creating a black box for each block that you want to be considered as a separate design partition.

In the MultiPoint synthesis flow (Synplify Pro only), you create multiple VQMs from one easy-to-manage top-level synthesis project. By using the manual black box method (Synplify or Synplify Pro), you have multiple synthesis projects, which may be required for certain team-based or bottom-up designs where a single top-level project is not desired.

Once you have created multiple VQM files using one of these two methods, you need to create the appropriate Quartus II projects to place-and-route the design.

## Creating a Design with Multiple VQM Files Using Synplify Pro MultiPoint Synthesis

This section describes how to generate multiple VQM files using the Synplify Pro MultiPoint synthesis flow. You must first set up your compile points, constraint files, and Synplify Pro options, then apply Altera-specific attributes to write multiple VQM files and create LogicLock region assignments.

## Set Compile Points & Create Constraint Files

The MultiPoint flow lets you segment a design into smaller synthesis units, called Compile Points. The synthesis software treats each Compile Point as a partition for incremental mapping, which allows you to isolate and work on individual Compile Point modules as independent segments of the larger design without impacting other design modules. A design can have any number of Compile Points, and Compile Points can be nested. The top-level module is always treated as a Compile Point.

Compile Points are optimized in isolation from their parent, which can be another Compile Point or a top-level design. Each block created with a Compile Point is unaffected by critical paths or constraints on its parent or other blocks. A Compile Point is independent, with its own individual constraints. During synthesis, any Compile Points that have not yet been synthesized are synthesized before the top level. Nested Compile Points are synthesized before the parent Compile Points in which they are contained. When you apply the appropriate Synplify Pro LogicLock constraints to a Compile Point module, then a separate netlist is created for that Compile Point, isolating that logic from any other logic in the design.

Figure 8–6 on page 8–52 shows an example of a design hierarchy that can be split into multiple partitions. The top-level block of each partition can be synthesized as a separate Compile Point.

In this case, modules A, B, and F are Compile Points. The top-level Compile Point consists of the top-level block in the design (that is, block A in this example), including the logic that is not defined under another Compile Point. In this example, the design for top-level Compile Point A also includes the logic in one of its subblocks, C. Because block F is defined as its own Compile Point, it is not treated as part of the top-level Compile Point A. Another separate Compile Point B contains the logic in blocks B, D, and E. One netlist is created for the top-level module A and submodule C, another netlist is created for B and its submodules D and E, while a third netlist is created for F.

Apply Compile Points to the module or architecture in the Synplify Pro SCOPE spreadsheet or in the SDC file. You cannot set a Compile Point in the Verilog HDL or VHDL source code. You can set the constraints manually using Tcl or by editing the SDC file. You can also use the GUI which provides two methods, manual or automated, as shown below.

## **Defining Compile Points Using Tcl or SDC**

To set Compile Points using Tcl or an SDC file, use the define\_compile\_point command, as shown in Example 8–20.

## Example 8-20. The define\_compile\_point Command

define\_compile\_point [-disable] [-comment <comment>] <objname> \
[-type <compile point type>]

In the syntax statement above, *objname* represents any module in the design. Currently, locked is the only Compile Point type supported.

Each Compile Point has a set of constraint files that begin with the define\_current\_design command to set up the SCOPE environment.

define current design {<my\_module>}

### Manually Defining Compile Points from the GUI

The manual method requires you to separately create constraint files for the top-level and the lower-level Compile Points. To use the manual method:

- From the top level, select the Compile Points tab in the SCOPE spreadsheet.
- Select the modules that you want to define as Compile Points.

Currently, locked Compile Points are the only type supported. All Compile Points must be defined from the top level because the **Compile Points** tab is not available in the SCOPE spreadsheet from lower level modules.

3. Manually create a constraint file for each module.

To ensure that changes to a Compile Point do not affect the top-level parent module, disable the **Update Compile Point Timing Data** option on the **Implementation Options** dialog box. If this option is enabled, updates to a child module can impact the top-level module.

#### Automatically Defining Compile Points from the GUI

When you use the automated process, the lower-level constraint file is created automatically. This eliminates the manual step necessary to do to set up each Compile Point. To use the automated method, perform the following steps:

- On the File menu, select New. Click to create a new Constraint File, or click the SCOPE icon in the tool bar.
- From the Select File Type tab of the Create a New SCOPE File dialog box, select Compile Point.
- Select the module you want to designate as a Compile Point. The software automatically sets the Compile Points in the top-level constraint file and creates a lower-level constraint file for each Compile Point.

To ensure that changes to a Compile Point do not affect the top-level parent module, disable the **Update Compile Point Timing Data** option on the **Implementation Options** dialog box. If this option is enabled, updates to a child module can impact the top-level module.

When using Compile Points with the incremental compilation or LogicLock design flow, keep the following restrictions in mind:

- To use Compile Points effectively, you must provide timing constraints (timing budgeting) for each Compile Point; the more accurate the constraints, the better your results are. Constraints are not automatically budgeted, so manual time budgeting is essential. Altera recommends that you register all inputs and outputs of each partition. This avoids any logic delay penalty on signals that cross partition boundaries.
- When using the Synplify Pro attribute syn\_useioff to pack registers in the I/O Elements (IOEs) of Altera devices, these registers must be in the top-level module, not a lower level. Otherwise, you must allow the Quartus II software to perform I/O register packing instead of the syn\_useioff attribute. You can use the Fast Input Register or Fast Output Register options, or set I/O timing constraints and turn on Optimize I/O cell register placement for timing on the Fitter Settings page of the Settings dialog box in the Quartus II software.
- There is no incremental synthesis support for top-level logic; any logic in the top-level is resynthesized during every compilation in the Synplify Pro software.



For more information about Compile Points, refer to the *Synplify Pro User Guide and Reference Manual* on the Synplicity web site at **www.synplicity.com/literature/index.html**.

## Apply the LogicLock Attributes

To instruct the Synplify Pro software to create a separate VQM netlist file for each Compile Point, you must indicate that the Compile Point is being used with LogicLock regions in the incremental compilation or LogicLock design methodology. Since separate netlist files are required for incremental compilation, you must use the LogicLock attributes if you plan to use the incremental compilation feature in the Quartus II software. When you apply the appropriate LogicLock attributes, the Synplify Pro software also writes out Tcl commands for the Quartus II software to create a LogicLock region for each netlist.

LogicLock regions in the Quartus II software have size and location properties. The region's size is defined by the height and width of the rectangular area. If the region is specified as auto-size, then the Quartus II software determines the appropriate size to fit the logic assigned to the region. When you specify the size, you must include enough device resources to accommodate the assigned logic. The location of a region is defined by its origin, which is the position of its bottom-left corner or top-left corner, depending on the target device family. In the Quartus II

software, this location can be specified as locked or floating. If the location is floating, the Quartus II software determines the location during its optimization process.



Floating locations are the only type currently supported in the Synplify Pro software.

When you use incremental compilation in the Quartus II software, you should lock down the size and location of the region in the Quartus II software after the first compilation to achieve the best quality of results.

Table 8–5 shows the valid combinations of the LogicLock attributes.

| Table 8–5. LogicLock Location & Size Properties |                                    |                                                                                                                                |  |
|-------------------------------------------------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|--|
| altera_logiclock_location<br>Attribute          | altera_logiclock_size<br>Attribute | Description                                                                                                                    |  |
| Floating                                        | Auto                               | The most flexible type of LogicLock constraint. Allows the Quartus II software to choose appropriate region size and location. |  |
| Floating                                        | Fixed                              | Assumes size of LogicLock constraint area is already optimal in existing Quartus II project.                                   |  |

You can apply these attributes to the top-level constraint file or to the individual constraint files for each lower-level Compile Point. You can use the **Attribute** tab of the SCOPE spreadsheet to set attributes.

Symplify Pro offers another attribute, syn\_allowed\_resources, which restricts the number of resources for a given module. You can apply the syn allowed resources attribute to any Compile Point view.



For specific information regarding these attributes, refer to the Synplify Pro online help or reference manual.

## Creating a Quartus II Project for Multiple VQM Files

During compilation, the Synplify Pro software creates a *<top-level project>.tcl* file that provides the Quartus II software with the appropriate constraints and LogicLock assignments, creating a region for each VQM file along with the information to set up a Quartus II project.

The Tcl file contains the following commands for each LogicLock region. Example 8–21 is for module A (instance u1) in the project named top where the region name cpll\_1 was selected by Synplify Pro for the Compile Point.

#### Example 8–21. Commands for Each LogicLock Region in a Tcl File

```
\label{local_section_id_taps_region} $$-name\{LL\_AUTO_SIZE\}\{ON\}$    set_global_assignment -section_id\{taps_region\} -name\{LL\_STATE\}\{FLOATING\}$    set_instance_assignment -section_id\{taps_region\} -to\{|taps:u1\} \\ -name\{LL\_MEMBER\_OF\} $$\{taps\_region\}$$    $$
```

These commands create a LogicLock region with Auto Size and Floating Origin properties. This flexible LogicLock region allows the Quartus II Compiler to select the size and location of the region.



For more information about Tcl commands, refer to the *Tcl Scripting* chapter in volume 2 of the *Quartus II Handbook*.

Depending on your design methodology, you can create one Quartus II project for all netlists (a top-down placement and routing flow) or a separate Quartus II project for each netlist (a bottom-up placement and routing flow). In a top-down incremental compilation design flow, you create design partition assignments and LogicLock floorplan location assignments for each partition in the design within a single Quartus II project. This methodology allows for the best quality of results and performance preservation during incremental changes to your design. You may require a bottom-up design flow if each partition must be optimized separately, such as in certain team-based design flows. To perform a bottom-up compilation in the Quartus II software, create separate Quartus II projects and import each design partition into a top-level design using the incremental compilation export and import features to maintain placement results.

The following sections describe how to create the Quartus II projects for these two design flows.

## Creating a Single Quartus II Project for a Top-Down Incremental Compilation Flow

Use the <top-level project>.tcl file that contains the Synplify Pro assignments for all partitions within the project. This method allows you to import all the partitions into one Quartus II project and optimize all modules within the project at once, taking advantage of the performance preservation and compilation-time reduction incremental compilation offers. Figure 8–4 shows a visual representation of the design flow for the example design in Figure 8–6.



Figure 8-4. Design Flow Using Multiple VQM Files with One Quartus II Project

# Creating Multiple Quartus II Projects for a Bottom-Up LogicLock Design Flow

Generate multiple Quartus II projects, one for each partition and netlist in the design. Each designer in the project can optimize their partition separately within the Quartus II software and export the placement for their partitions. Figure 8–5 shows a visual representation of the design flow for the example design in Figure 8–6. The optimized sub-designs can be brought into one top-level Quartus II project using incremental compilation.



Figure 8-5. Design Flow Using Multiple VQM Files with Multiple Quartus II Projects

## Generating a Design with Multiple VQM Files Using Black Boxes

This section describes how to manually generate multiple VQM files using black boxes. This manual flow is supported in versions of the Synplify software that do not include the MultiPoint Synthesis feature.

## Manually Creating Multiple VQM Files Using Black Boxes

To create multiple VQM files manually in the Synplify software, create a separate project for each low-level module and the top-level design that you want to maintain as a separate VQM file. Implement black box instantiations of lower-level partitions in your top-level project. When synthesizing the projects for the lower-level modules, perform the following steps.

- In the Implementation Options dialog box, turn on Disable I/O Insertion for the target technology.
- 2. Read the HDL files for the modules.



Modules may include black box instantiations of lower-level modules that are also maintained as separate VQM files.

- 3. Add constraints with the SCOPE constraint editor.
- 4. Enter the clock frequency to ensure that the sub-design is correctly optimized.
- 5. In the **Attributes** tab, set **syn\_netlist\_hierarchy** to **0**.

When synthesizing the top-level design project, perform the following steps:

- 1. Turn off **Disable I/O Insertion** for the target technology.
- 2. Read the HDL files for top-level designs.
- 3. Create black boxes using lower-level modules in the top-level design.
- 4. Add constraints with the SCOPE constraint editor.
- Enter the clock frequency to ensure that the design is correctly optimized.
- 6. In the **Attributes** tab, set **syn\_netlist\_hierarchy** to **0**.

The following sections describe an example of black box implementation to create separate VQM files. Figure 8–6 shows an example of a design hierarchy that is split up into multiple partitions.

Partition Top

A

C

D

E

Partition B

Partition F

Figure 8-6. Partitions in a Hierarchical Design

In Figure 8–6, the partition top contains the top-level block in the design (block A) and the logic that is not defined as part of another partition. In this example, the partition for top-level block A also includes the logic in one of its subblocks, C. Because block F is contained in its own partition, it is not treated as part of the top-level partition A. Another separate partition, B, contains the logic in blocks B, D, and E. In a team-based design, different engineers may work on the logic in different partitions. One netlist is created for the top-level module A and its submodule C, another netlist is created for B and its submodules D and E, while a third netlist is created for F. To create multiple VQM files for this design, follow these steps:

- Generate a VQM file for module B. Use B.v/.vhd, D.v/.vhd, and E.v/.vhd as the source files.
- 2. Generate a VQM file for module F. Use F.v/.vhd as the source files.
- 3. Generate a top-level VQM file for module A. Use **A.v/.vhd** and **C.v/.vhd** as the source files. Ensure that you use black box modules B and F, which were optimized separately in the previous steps.

### Creating Black Boxes in Verilog HDL

Any design block that is not defined in the project or included in the list of files to be read for a project are treated as a black box by the software. Use the syn\_black\_box attribute to indicate that you intend to create a black box for the given module. In Verilog HDL, you must provide an empty module declaration for the module that is treated as a black box.

Example 8–22 shows an example of the **A.v** top-level file. Follow the same procedure below for lower-level files which also contain a black box for any module beneath the current level hierarchy.

## Example 8-22. Verilog HDL Black Box for Top-Level File A.v

```
module A (data_in, clk, e, ld, data_out);
   input data_in, clk, e, ld;
   output [15:0] data out;
   wire [15:0] cnt out;
   B U1 (.data in (data_in),.clk(clk), .ld (ld),.data_out(cnt_out));
   F U2 (.d(cnt out), .clk(clk), .e(e), .q(data out));
   // Any other code in A.v goes here.
endmodule
// Empty Module Declarations of Sub-Blocks B and F follow here.
// These module declarations (including ports) are required for black
boxes.
module B (data in, clk, ld, data out) /* synthesis syn black box */;
   input data in, clk, ld;
   output [15:0] data_out;
endmodule
module F (d, clk, e, q) / *synthesis syn_black box */;
   input [15:0] d;
   input clk, e;
   output [15:0] q;
endmodule
```

### Creating Black Boxes in VHDL

Any design block that is not defined in the project or included in the list of files to be read for a project are treated as a black box by the software. Use the syn\_black\_box attribute to indicate that you intend to treat the given component as a black box. In VHDL, you need a component declaration for the black box just like any other block in the design.



Although VHDL is not case-sensitive, VQM (a subset of Verilog HDL) is case-sensitive. Entity names and their port declarations are forwarded to the VQM. Black box names and port declarations are also passed to the VQM. To prevent case-based mismatches between VQM, use the same capitalization for black box and entity declarations in VHDL designs.

Example 8–23 shows an example of the **A.vhd** top-level file. Follow this same procedure for any lower-level files that contain a black box for any block beneath the current level of hierarchy.

### Example 8-23. VHDL Black Box for Top-Level File A.vhd

```
LIBRARY ieee;
USE ieee.std logic 1164.all;
LIBRARY symplify;
use symplify.attributes.all;
ENTITY A IS
PORT ( data in : IN INTEGER RANGE 0 TO 15;
   clk, e, ld : IN STD LOGIC;
   data out : OUT INTEGER RANGE 0 TO 15 );
END A:
ARCHITECTURE a arch OF A IS
COMPONENT B PORT (
   data in : IN INTEGER RANGE 0 TO 15;
   clk, ld : IN STD LOGIC;
   d out : OUT INTEGER RANGE 0 TO 15 );
END COMPONENT;
COMPONENT F PORT (
   d : IN INTEGER RANGE 0 TO 15;
   clk, e: IN STD LOGIC;
   q : OUT INTEGER RANGE 0 TO 15 );
END COMPONENT;
attribute syn black box of B: component is true;
attribute syn black box of F: component is true;
-- Other component declarations in A.vhd go here
```

```
signal cnt out : INTEGER RANGE 0 TO 15;
BEGIN
U1 : B
PORT MAP (
   data in => data in,
   clk => clk,
   ld => ld,
   d out => cnt out );
U2 : F
PORT MAP (
   d => cnt out,
   clk => clk,
   e \Rightarrow e,
   q => data_out );
-- Any other code in A.vhd goes here
END a_arch;
```

After you have completed the steps described in this section, you have a netlist file for each partition of the design. These files are ready for use with incremental compilation in the Quartus II software.

## Creating a Quartus II Project for Multiple VQM Files

The Synplify software creates a Tcl file for each VQM file, that provide the Quartus II software with the appropriate constraints and information to set up a project. For details on using the Tcl script generated by the Synplify software to set up your Quartus II project and pass your constraints, refer to "Running the Quartus II Software Manually Using the Synplify-Generated Tcl Script" on page 8–18.

Depending on your design methodology, you can create one Quartus II project for all netlists (a top-down placement and routing flow) or a separate Quartus II project for each netlist (a bottom-up placement and routing flow). In a top-down incremental compilation design flow, you create design partition assignments and LogicLock floorplan location assignments for each partition in the design within a single Quartus II project. This methodology allows for the best quality of results and performance preservation during incremental changes to your design. You may require a bottom-up design flow where each partition must be optimized separately, such as in certain team-based design flows. To perform a bottom-up compilation in the Quartus II software, create

separate Quartus II projects and import each design partition into a toplevel design using the incremental compilation export and import features to maintain placement results.

The following sections describe how to create the Quartus II projects for these two design flows.

## Creating Compile Points in Single Quartus II Project for a Top-Down Incremental Compilation Flow

Use the <top-level project>.tcl file that contains the Synplify assignments for the top-level design. This method allows you to import all the partitions into one Quartus II project and optimize all modules within the project at once, taking advantage of the performance preservation and compilation time reduction offered by incremental compilation. Figure 8–7 shows a visual representation of the design flow for the example design in Figure 8–6.

All the constraints from the top-level project will be passed to the Quartus II software in the top-level Tcl file, but any constraints made in the lower-level projects within the Synplify software is not forward-annotated. Enter these constraints manually in your Quartus II project.

Use a.tcl to import top-level
Synplify Pro assignment.
Enter any lower-level
asignments manually.

b.vqm

f.vqm

Figure 8–7. Design Flow Using Multiple VQM Files with One Quartus II Project

Creating Multiple Quartus II Projects for a Bottom-Up Design Flow Use the Tcl file that is created for each VQM file by the Synplify software for each Synplify Project. This method generates multiple Quartus II projects, one for each block in the design. Each designer in the project can optimize their block separately within the Quartus II software and export the placement of their blocks. Figure 8–8 on page 8–57 shows a visual representation of the design flow for the example in Figure 8–6 on

page 8–52. Designers should create a LogicLock region for each block; the top-level designer should then import all the blocks and assignments into the top-level project. This method allows each block in the design to be treated separately; each block can then be imported into one top-level project.

Quartus II Project

Use a.tcl to Import
Synplify Assignments

Use b.tcl to Import
Synplify Assignments

Use f.tcl to Import
Synplify Assignments

Figure 8–8. Design Flow Using Multiple Symplify Projects & Multiple Quartus II Projects

# **Conclusion**

Advanced synthesis is an important part of the design flow. Taking advantage of the Synplicity Synplify and Quartus II design flows allows you to control how your design files are prepared for the Quartus II place-and-route process, as well as improve performance and optimize a design for use with Altera devices. Several of the methodologies outlined in this chapter can help optimize a design to achieve performance goals and save design time.



# 9. Mentor Graphics Precision RTL Synthesis Support

QII51011-6.0.0

# Introduction

As programmable logic device (PLD) designs become more complex and require increased performance, advanced synthesis has become an important part of the design flow. This chapter documents support for the Mentor Graphics® Precision RTL Synthesis software in the Quartus® II software design flow, as well as key design methodologies and techniques for improving your results for Altera® devices. This chapter includes the following sections:

- General design flow with the Precision RTL Synthesis software and the Quartus II software
- Creating a project and compiling the design
- Setting constraints to achieve optimal results
- Synthesizing the design and evaluating the results
- Exporting designs to the Quartus II software using NativeLink<sup>®</sup> integration
- Guidelines for Altera megafunctions and the library of parameterized modules (LPM) functions, instantiating them in a clear-box or black-box flow using the MegaWizard<sup>®</sup> Plug-In manager, and tips for inferring them from HDL code
- Incremental compilation and block-based design

This chapter assumes that you have installed and licensed the Precision RTL Synthesis software and the Quartus II software.



To obtain and license the Precision RTL Synthesis software, refer to the Mentor Graphics web site at **www.mentor.com**. To install and run the Precision RTL Synthesis software and to set up your work environment, refer to the *Precision RTL Synthesis User's Manual* in the Precision Manuals Bookcase in the Help menu.

# **Design Flow**

The basic steps in a Quartus II design flow using the Precision RTL Synthesis software are as follows:

- Create Verilog HDL or VHDL design files in the Quartus II design software, the Precision RTL Synthesis software, or with a text editor.
- 2. Create a project in the Precision RTL Synthesis software that contains the HDL files for your design, select your target device, and set global constraints. For best results when using Altera megafunctions, Mentor Graphics recommends using the clear box option which enables synthesis to report more accurate resource utilization and timing estimates. Refer to "Clear-Box Methodology" on page 9–20 for details.
- 3. Compile the project in the Precision RTL Synthesis software.
- 4. Add specific timing constraints, optimization attributes, and compiler directives to optimize the design during synthesis.



For best results, Mentor Graphics recommends specifying constraints that are as close as possible to actual operating requirements. Properly setting clock and I/O constraints, assigning clock domains, and indicating false and multicycle paths guide the synthesis algorithms more accurately toward a suitable solution in the shortest synthesis time.

- Synthesize the project in the Precision RTL Synthesis software. With the design analysis capabilities and cross-probing of Precision RTL Synthesis software, you can identify and improve circuit area and performance issues using pre-layout timing estimates.
- 6. Create a Quartus II project and import the technology-specific EDIF (.edf) netlist and the tool command language (.tcl) file generated by the Precision RTL Synthesis software into the Quartus II software for placement and routing, and for performance evaluation using actual post-layout timing data.
- 7. After obtaining place-and-route results that meet your needs, configure or program the Altera device.

These steps are described in detail throughout this chapter. Figure 9–1 shows the Quartus II design flow using Precision RTL Synthesis as described in the steps above.



Figure 9–1. Design Flow Using the Precision RTL Synthesis Software & Quartus II Software

If your area or timing requirements are not met, you can change the constraints and resynthesize the design in the Precision RTL Synthesis software, or you can change constraints to optimize the design during place and route in the Quartus II software. Repeat the process until the area and timing requirements are met (Figure 9–1).

You can use other options and techniques in the Quartus II software to meet area and timing requirements. One such option is the **WYSIWYG Primitive Resynthesis** option, which can perform optimizations on your EDIF netlist in the Quartus II software.



For information about netlist optimizations, refer to the *Netlist Optimizations and Physical Synthesis* chapter in volume 2 of the *Quartus II Handbook*. For more recommendations on how to optimize your design, refer to the *Area & Timing Optimization* chapter in volume 2 of the *Quartus II Handbook*.

While simulation and analysis can be performed at various points in the design process, final timing analysis should be performed after placement and routing is complete.

During the synthesis process, the Precision RTL Synthesis software produces several intermediate and output files. Table 9–1 lists these files with a short description of each file type.

| Table 9–1. Precision RTL Synthesis Software Intermediate & Output Files |                                                                            |  |
|-------------------------------------------------------------------------|----------------------------------------------------------------------------|--|
| File Extension(s)                                                       | File Description                                                           |  |
| .sdc                                                                    | Design constraints file in Synopsys Design Constraints File                |  |
| .psp                                                                    | Precision RTL Synthesis Software Project File                              |  |
| .xdb                                                                    | Mentor Graphics Design Database File                                       |  |
| .rep (1)                                                                | Synthesis Area & Timing Report File                                        |  |
| .edf                                                                    | Technology-specific netlist in electronic design interchange format (EDIF) |  |
| .acf/.tcl (2)                                                           | Forward-annotated constraints file containing constraints and assignments  |  |

### Notes to Table 9-1:

- (1) The timing report file includes performance estimates that are based on preplace-and-route information. Use the f<sub>MAX</sub> reported by the Quartus II software after place-and-route for accurate post-place-and-route timing information. The area report file includes post-synthesis device resource utilization statistics that may differ from the resource usage after place-and-route due to black-boxes or further optimizations performed during placement and routing. Use the device utilization reported by the Quartus II software after place-and-route for final resource utilization results. See "Synthesizing the Design & Evaluating the Results" on page 9–11 for details.
- (2) An Assignment & Configuration File (.acf) file is created only for ACEX® 1K, FLEX® 10K, FLEX 10KA, FLEX 6000, FLEX 8000, MAX® 7000, MAX 9000, and MAX 3000 devices. The Assignment & Configuration File is generated for backward compatibility with the MAX+PLUS® II software. A Tcl file for the Quartus II software is created for all devices, which also contains Tcl commands to create and compile a Quartus II project.

# Creating a Project & Compiling the Design

After creating your design files, create a project in the Precision RTL Synthesis software that contains the basic settings for compiling the design.

# Creating a Project

Set up your design files as follows:

- 1. In the Precision RTL Synthesis software, click the **New Project** icon in the Design Bar on the left side of the GUI.
- 2. Set the **Project Name** and the **Project Folder**. The implementation name of the design corresponds to this project name.
- 3. Add input files to the project with the **Add Input Files** icon in the Design Bar. Precision RTL Synthesis software automatically detects the top-level module/entity of the design. It uses the top-level module/entity to name the current implementation directory, logs, reports, and netlist files.
- 4. In the Design Bar, click the **Setup Design** icon.
- To specify a target device family, expand the Altera entry, and choose the target device and speed grade.
- 6. If desired, set a global design frequency and/or default input and output delays. This constrains all clock paths and all I/O pins in your design. Modify the settings for individual paths or pins that do not require such a setting. All timing constraints are forward-annotated to the Quartus II software using Tcl scripts.

To generate additional netlist files (for example, an HDL netlist for simulation), on the Tools menu, point to **Set Options > Output** and click **Additional Output Netlist**. The Precision RTL Synthesis software generates a separate file for each selected type of file: EDIF, Verilog HDL, and VHDL.

# **Compiling the Design**

To compile the design into a technology-independent implementation, click the **Compile** icon in the Design Bar.

# Setting Constraints

In the next steps, you set constraints and map the design to technology-specific cells. The Precision RTL Synthesis software maps the design by default to the fastest possible implementation that meets your timing constraints. To accomplish this, you must specify timing requirements for the automatically determined clock sources. With this information, the Precision RTL Synthesis software performs static timing analysis to determine the location of the critical timing paths. The Precision RTL Synthesis software achieves the best results for your design when you set as many realistic constraints as possible. Ensure to set constraints for timing, mapping, false paths, multicycle paths, and others that control the structure of the implemented design.

Mentor Graphics recommends creating a Synopsys Design Constraint file (.sdc) and adding this file to the Constraint Files section of the Project Files list. You can create this file with a text editor or use the Precision RTL Synthesis software to generate one automatically for you on the first synthesis run. To create an initial constraint file manually, set constraints on design objects (such as clocks, design blocks, or pins) in the Design Hierarchy browser. By default, the Precision RTL Synthesis software saves all timing constraints and attributes in two files: precision\_rtl.sdc and precision\_tech.sdc. The precision\_rtl.sdc file contains constraints set on the RTL-level database (after compilation) and precision\_tech.sdc file contains constraints set on the gate-level database (after synthesis) located in the current implementation directory.

You can also enter constraints at the command line. After adding constraints at the command line, update the SDC file with the **update constraint file** command.



You can add constraints that change infrequently directly to the HDL source files with HDL attributes or pragmas.



For more details and examples, refer to the Attributes chapter in the *Precision Synthesis Reference Manual* in the Precision Manual Bookcase in the Help menu.

# **Setting Timing Constraints**

Timing constraints, based on the industry-standard Synopsys Design Constraint file format, help the Precision RTL Synthesis software to deliver optimal results. Missing timing constraints can result in incomplete timing analysis and may prevent timing errors from being detected. Precision RTL Synthesis software provides constraint analysis prior to synthesis to ensure that designs are fully and accurately constrained. All timing constraints are forward-annotated to the Quartus II software using Tcl scripts.



Because the Synopsys Design Constraint file format requires that timing constraints must be set relative to defined clocks, you must specify your clock constraints before applying any other timing constraints.

You also can use multicycle path and false path assignments to relax requirements or exclude nodes from timing requirements. Doing so can improve area utilization and allow the software optimizations to focus on the most critical parts of the design.



For details about the syntax of Synopsys Design Constraint commands, refer to the *Precision RTL Synthesis Users Manual* and the *Precision Synthesis Reference Manual* available in the Precision Manual Bookcase in the Help menu.

# **Setting Mapping Constraints**

Mapping constraints affect how your design is mapped into the target Altera device. You can set mapping constraints in the user interface, in HDL code, or with the **set\_attribute** command in the constraint file.

# Assigning Pin Numbers & I/O Settings

The Precision RTL Synthesis software supports assigning device pin numbers, I/O standards, drive strengths, and slew-rate settings to top-level ports of the design. You can set these timing constraints with the **set\_attribute** command, the GUI, or by specifying synthesis attributes in your HDL code. These constraints are written into the Tcl file that is read by the Quartus II software during place-and-route and do not affect synthesis.

You can use the **set\_attribute** command in the Synopsys Design Constraint file to specify pin number constraints, I/O standards, drive strengths, and slow slew-rate settings. Table 9–2 outlines the format to use for entries in the Synopsys Design Constraint file.

| Table 9–2. Constraint File Settings |                                                                                                         |  |
|-------------------------------------|---------------------------------------------------------------------------------------------------------|--|
| Constraint                          | Entry Format for Synopsys Design Constraint File                                                        |  |
| Pin number                          | set_attribute -name PIN_NUMBER -value " <pin number="">" -port <port name=""></port></pin>              |  |
| I/O standard                        | set_attribute -name IOSTANDARD -value " <i o="" standard="">" -port <port name=""></port></i>           |  |
| Drive<br>strength                   | set_attribute -name DRIVE -value " <drive in="" ma="" strength="">" -port <port name=""></port></drive> |  |
| Slew rate                           | set_attribute -name SLEW -value "TRUE   FALSE" -port <pre></pre>                                        |  |

You can also specify these options in the GUI. To specify a pin number or other I/O setting in the Precision RTL Synthesis GUI, follow these steps:

- After compiling the design, expand the Ports entry in the Design Hierarchy Browser.
- 2. Under **Ports**, expand the **Inputs** or **Outputs** entry.



You also can assign I/O settings by right-clicking the pin in the Schematic Viewer.

- 3. Right-click the desired pin name and select the **Set Input Constraints** option under **Inputs** or **Set Output Constraints** option under **Outputs**.
- 4. Enter the desired pin number on the Altera device in the **Pin Number** box (**Port Constraints** dialog box).
- 5. Select the I/O standard from the **IO\_STANDARD** list.
- For output pins, you can also select a drive strength setting and slew rate setting using the DRIVE and SLOWSLEW lists.

You also can use synthesis attributes or pragmas in your HDL code to make these assignments. The following code samples show you how to make a pin assignment in your HDL code.

### Example 9-1. Verilog HDL Pin Assignment

//pragma attribute clk pin number P10;

### Example 9–2. VHDL Pin Assignment

```
attribute pin_number : string attribute pin number of clk : signal is "P10";
```

You can use the same syntax to assign the I/O standard using the attribute IOSTANDARD, drive strength using the attribute DRIVE, and slew rate using the attribute SLEW.



For more details about attributes and how to set them in your HDL code, refer to the *Precision Synthesis Reference Manual*.

# Assigning I/O Registers

The Precision RTL Synthesis software performs timing-driven I/O register mapping by default. It moves registers into an I/O element (IOE) when it does not negatively impact the register-to-register performance of your design, based on the timing constraints.

You can force a register to the device's IOE using the Complex I/O constraint. This option does not apply if you turn off I/O pad insertion. Refer to "Disabling I/O Pad Insertion" for more information.

To force an I/O register into the device's IOE using the GUI, follow these steps:

- After compiling the design, expand the **Ports** entry in the Design Hierarchy browser.
- 2. Under **Ports**, expand the **Inputs** or **Outputs** entry, as desired.
- Under Inputs or Outputs, right-click the desired pin name and select Force Register into IO.



You also can make the assignment by right-clicking on the pin in the Schematic Viewer.

For Stratix $^{\otimes}$  II, Cyclone  $^{TM}$  II, MAX $^{\otimes}$  II, Stratix, and Cyclone families of devices, the Precision RTL Synthesis software can move an internal register to an I/O register without any restrictions on design hierarchy.

For more mature devices, the Precision RTL Synthesis software can move an internal register to an I/O register only when the register exists in the top level of the hierarchy. If the register is buried in the hierarchy, you must flatten the hierarchy so that the buried registers are moved to the top level of the design.

# Disabling I/O Pad Insertion

The Precision RTL Synthesis software assigns I/O pad atoms (device primitives used to represent the I/O pins and I/O registers used) to all ports in the top level of a design by default. In certain situations, you may not want the software to add I/O pads to all I/O pins in the design. The Quartus II software can compile a design without I/O pads; however, including I/O pads provides the Precision RTL Synthesis software with the most information about the top-level pins in the design.

Preventing the Precision RTL Synthesis Software from Adding I/O Pads

If you are compiling a subdesign as a separate project, I/O pins cannot be primary inputs or outputs of the device and therefore should not have an I/O pad associated with them. To prevent the Precision RTL Synthesis software from adding I/O pads, perform the following steps:

- 1. On the Tools menu, click **Set Options**.
- On the Optimization page of the Options dialog box, turn off Add IO Pads, then click Apply.

This procedure adds the following command to the project file:

```
setup design -addio=false
```

Preventing the Precision RTL Synthesis Software from Adding an I/O Pad on an Individual Pin

To prevent I/O pad insertion on an individual pin when you are using a black box, such as Double Data Rate (DDR) or a Phase-Locked Loop (PLL), at the external ports of the design, follow these steps:

- 1. After compiling the design, in the Design Hierarchy browser, expand the **Ports** entry by clicking the +.
- 2. Under **Ports**, expand the **Inputs** or **Outputs** entry.
- 3. Under **Inputs** or **Outputs**, right-click the desired pin name and click **Set Input Constraints**.
- In the Port Constraints dialog box for the selected pin name, turn off Insert Pad.



You also can make the assignment by right-clicking on the pin in the Schematic Viewer or by attaching the nopad attribute to the port in the HDL source code.

# **Controlling Fan-Out on Data Nets**

Fan-out is defined as the number of nodes driven by an instance or top-level port. High fan-out nets can have significant delays which can result in an unroutable net. On a critical path, high fan-out nets can cause larger delay in a single net segment which can result in the timing constraints not being met. To prevent this behavior, each device family has a global fan-out value set in the Precision RTL Synthesis software

library. In addition, the Quartus II software automatically routes high fan-out signals on global routing lines in the Altera device whenever possible.

To eliminate routability and timing issues associated with high fan-out nets, the Precision RTL Synthesis software also allows you to override the library default value on a global or individual net basis. You can override the library value by setting a max fanout attribute on the net.

# Synthesizing the Design & Evaluating the Results

To synthesize the design for the target device, click on the **Synthesize** icon in the Precision RTL Synthesis Design Bar. During synthesis, the Precision RTL Synthesis software optimizes the compiled design, then writes out netlists and reports to the implementation subdirectory of your working directory after the implementation is saved, using the naming convention:

cproject name> impl <number>

After synthesis is complete, you can evaluate the results in terms of area and timing. The *Precision RTL Synthesis User's Manual* on the Mentor Graphics web site describes different results that can be evaluated in the software.

There are several schematic viewers available in the Precision RTL Synthesis software: RTL schematic, Technology-mapped schematic, and Critical Path schematic. These analysis tools allow you to quickly and easily isolate the source of timing or area issues, and to make additional constraint or code changes, if needed, to optimize the design.

# **Obtaining Accurate Logic Utilization & Timing Analysis Reports**

Historically, designers have relied on post-synthesis logic utilization and timing reports to determine how much logic their design requires, how big a device they need, and how fast the design will run. However, today's FPGA devices provide a wide variety of advanced features in addition to basic registers and look-up tables. The Quartus II software has advanced algorithms to take advantage of these features, as well as optimization techniques to both increase performance and reduce the amount of logic required for a given design. In addition, designs may contain black boxes and functions that take advantage of specific device features. Because of these advances, synthesis tool reports provide post-synthesis area and timing estimates, but the place-and-route software should be used to obtain final logic utilization and timing reports.

# Exporting Designs to the Quartus II Software Using NativeLink Integration

The NativeLink feature in the Quartus II software facilitates the seamless transfer of information between the Quartus II software and EDA tools, which allows you to run other EDA design entry/synthesis, simulation, and timing analysis tools automatically from within the Quartus II software.

After a design is synthesized in the Precision RTL Synthesis software, the technology-mapped design is written to the current implementation directory as an EDIF netlist file, along with a Quartus II Project Configuration File and a Place-and-Route Constraints File, written as Tcl scripts. You can use the Project Configuration script, cproject name.tcl, to create and compile a Quartus II project for your EDIF netlist. This script makes basic project assignments, such as assigning the target device specified in the Precision RTL Synthesis software, and makes timing assignments. For many devices, the Project Configuration script calls the place-and-route constraints script, project namepnr\_constraints.tcl, to make your timing constraints.

# Running the Quartus II Software from within the Precision RTL Software

Precision RTL Synthesis software also has a built-in place-and-route environment that allows you to run the Quartus II Fitter and view the results in the Precision RTL Synthesis GUI. This feature is useful when performing an initial compilation of your design to view post-place-and-route timing and device utilization results, but not all the advanced Quartus II options that control the compilation process are available.

After you specify an Altera device as the target, set the Quartus II options. On the Tools menu, click **Set Options**. On the **Integrated Place and Route** page, specify the path to the Quartus II executables in the **Path to Ouartus II installation** box.

To automate the place-and-route process, click the **Run Quartus** icon in the **Quartus II** window of the Precision RTL Synthesis Toolbar. The Quartus II software uses the current implementation directory as the Quartus II project directory and runs a full compilation in the background (that is, no user interface appears).

Two primary Precision RTL Synthesis software commands control the place-and-route process. Place-and-route options are set by the **setup\_place\_and\_route** command. The process is started with the **place\_and\_route** command.

Precision RTL Synthesis software versions 2004a and later support using individual Quartus II executables, such as analysis and synthesis (quartus\_map), Fitter (quartus\_fit), and Timing Analyzer (quartus\_tan), for improved runtime and memory utilization during place and route. This flow is referred to as the Quartus II Modular flow option in Precision RTL Synthesis software and is compatible with Quartus II software versions beginning with version 4.0. By default, the Precision RTL Synthesis software generates this Quartus II Project Configuration File (Tcl file) for Stratix II, Stratix, Stratix GX, MAX II, Cyclone II, and Cyclone device families. When using this flow, all timing constraints that you set during synthesis are exported to the Quartus II place-and-route constraints file (cyprict name>\_pnr\_constraints.tcl

For other device families, Precision RTL Synthesis software uses the **Quartus II** flow option, which enables the Quartus II compilation flow that existed in Precision RTL Synthesis software versions earlier than 2004a. The Quartus II Project Configuration File (Tcl file) written when using the **Quartus II** flow option includes supported timing constraints that you specified during synthesis. This Tcl file is compatible with all versions of the Quartus II software; however, the format and timing constraints do not take full advantage of the features in the Quartus II software introduced with version 4.0.

To force the use of a particular flow when it is not the default for a certain device family, use the following command to set up the integrated place-and-route flow:

```
setup place and route -flow "<Altera Place-and-Route flow>"
```

Depending on the device family, you can use one of the following flow options in the command above:

- Quartus II Modular
- Quartus II
- MAX+PLUS II

For example, for the Stratix II or MAX II device families (which were not supported in Quartus II software versions earlier than 4.0), you can use only the **Quartus II Modular** flow. For the Stratix device family you can use either the **Quartus II Modular** or **Quartus II** flows. The FLEX 8000 device family, which is not supported in the Quartus II software, is supported only by the **MAX+PLUS II** flow.

After the design is compiled in the Quartus II software from within the Precision RTL Synthesis software, you can invoke the Quartus II GUI manually and then open the project using the generated Quartus II project file. You can view reports, run analysis tools, specify options, and run the various processing flows available in the Quartus II software.

# Running the Quartus II Software Manually Using the Precision RTL Synthesis-Generated Tcl Script

You can use the Quartus II software separately from the Precision RTL Synthesis software. To run the Tcl script generated by the Precision RTL Synthesis software to set up your project and start a full compilation, perform the following steps:

- Ensure the EDIF and Tcl files are located in the same directory (they should both be located in the implementation directory by default).
- In the Quartus II software, on the View menu, point to Utility Windows and click Tcl Console.
- 3. At the Tcl Console command prompt, type the command:

```
source <path>/<project name>.tcl ←
```

- 4. On the File menu, click **Open Project**. Browse to the project name, and click **Open**.
- 5. Compile the project in the Quartus II software.

# Using Quartus II Software to Launch the Precision RTL Synthesis Software

Using NativeLink integration, you can set up the Quartus II software to run the Precision RTL Synthesis software. This feature allows you to use the Precision RTL Synthesis software to synthesize a design as part of a normal compilation.



For detailed information about using NativeLink integration with the Precision RTL Synthesis software, go to *Specifying EDA Tool Settings* in the Quartus II Help index.

# Passing Constraints to the Quartus II Software

The place-and-route constraints script forward-annotates timing constraints that you made in the Precision RTL Synthesis software. This integration allows you to enter these constraints once in the Precision RTL Synthesis software, and then pass them automatically to the Quartus II software.

The following constraints are translated by the Precision RTL Synthesis software:

- create clock
- set\_input\_delay
- set output delay
- set false path
- set\_multicycle\_path

# create clock

You can specify a clock in the Precision RTL Synthesis software as shown in Example 9–3.

# Example 9-3. Specifying a Clock using create\_clock

create\_clock -name <clock\_name> -period <period in ns> -waveform {<edge\_list>} -domain <ClockDomain> <pin>

The Precision RTL Synthesis software passes the clock definitions to the Quartus II software with the create base clock command.

The following list describes some differences in the clock properties supported by the Precision RTL Synthesis software and the Quartus II software:

- The Quartus II software supports only clock waveforms with two edges in a clock cycle. If the Precision RTL Synthesis software finds a multi-edge clock, it passes to the Quartus II software and issues an error message.
- Clocks in the same clock -domain are annotated with the create\_relative\_clock command to create related clocks in the Quartus II software.
- The Quartus II software assumes the first clock edge to be at time 0.0. If the Precision RTL Synthesis software waveform has a first transition at a time different than time zero (0.0), the Precision RTL Synthesis software creates a base clock without any target, then uses this to create a relative clock with an offset set to the first clock edge.

set\_input\_delay

This port-specific input delay constraint is specified in the Precision RTL Synthesis software as shown in Example 9–4.

# Example 9-4. Specifying set\_input\_delay

set\_input\_delay <delay\_value port\_pin\_list> -clock <clock\_name> -rise
-fall -add\_delay

This constraint is mapped to the set\_input\_delay setting in the Quartus II software.

When the reference clock <*clock\_name*> is not specified, all clocks are assumed to be the reference clocks for this assignment. The input pin name for the assignment can be an input pin name of a time group. The software can use the option clock\_fall to specify delay relative to the falling edge of the clock.



Although the Precision RTL Synthesis software allows you to set input delays on pins inside the design, these constraints are not sent to the Quartus II software, and a message is displayed.

set output delay

This port-specific output delay constraint is specified in the Precision RTL Synthesis software as shown in Example 9–5.

# Example 9-5. Using the set\_output\_delay Constraint

set\_output\_delay <delay\_value> <port\_pin\_list> -clock <clock\_name> -rise -fall
-add\_delay

This constraint is mapped to the set\_output\_delay setting in the Quartus II software.

When the reference clock *<clock\_name>* is not specified, all clocks are assumed to be the reference clocks for this assignment. The output pin name for the assignment can be an output pin name of a time group.



Although the Precision RTL Synthesis software allows you to set output delays on pins inside the design, these constraints are not sent to the Quartus II software, and a message is displayed.

set false path

The false path constraint is specified in the Precision RTL Synthesis software as shown in Example 9–6.

# Example 9-6. Using the set\_false\_path Constraint

set false path -to <to node list> -from <from node list> -reset path

The node lists can be a list of clocks, ports, instances, and pins. Multiple elements in the list can be represented using wildcards such as "\*" and "?."

This setting in the Precision RTL Synthesis software is mapped to a set timing cut assignment setting in the Quartus II software.

The node lists for this assignment represents top-level ports and/or nets connected to instances (end points of timing assignments). The node lists can contain wildcards. The Quartus II software does not support bus notation such as A[7:4] in the node lists.

The Quartus II software does not support any setup, hold, rise, or fall options for this assignment.

The Quartus II software does not support false paths with the through path specification. Any setting in the Precision RTL Synthesis software with a -through specification cannot be mapped to a setting in the Quartus II software.

If you use the from or to option without using both options, the Precision RTL Synthesis command is converted to a Quartus II command using wildcards. Table 9–3 lists these set\_false\_path constraints in the Precision RTL Synthesis software and the Quartus II software equivalent.

| Table 9–3. set_false_path Constraints                  |                                                                 |  |
|--------------------------------------------------------|-----------------------------------------------------------------|--|
| Precision RTL Synthesis Assignment                     | Quartus II Equivalent                                           |  |
| set_false_path -from <from_node_list></from_node_list> | set_timing_cut_assignment -to {*} -from <node_list></node_list> |  |
| set_false_path -to <to_node_list></to_node_list>       | set_timing_cut_assignmet -to < node_list> -from {*}             |  |

set\_multicycle\_path

This multi-cycle path constraint is specified in the Precision RTL Synthesis software as shown in Example 9–7.

# Example 9-7. Using the set\_multicycle\_path Constraint

set\_multicycle\_path <multiplier\_value> [-start] [-end] -to <to\_node\_list> -from <from\_node\_list> -reset\_path

The node lists can contain clocks, ports, instances, and pins. Multiple elements in the list can be represented using wildcards such as "\*" and "?." Paths without multicycle path definitions are identical to paths with multipliers of 1. To add one additional cycle to the datapath, use a multiplier value of 2. The option start is to indicate that source clock cycles should be considered for the multiplier. The option end is to indicate that destination clock cycles should be considered for the multiplier. The default is to reference the end clock.

This setting in Precision RTL Synthesis software is mapped to a set\_multicycle\_assignment setting in the Quartus II software.

The node lists represent top-level ports and/or nets connected to instances (end points of timing assignments). The node lists can contain wildcards; the Quartus II software automatically expands all wildcards. The Quartus II software does not support bus notation as A[7:4] in the node list.

If you use the from or to option without using both options, the Precision RTL Synthesis command is converted to a Quartus II command using wildcards. Table 9–4 lists the set\_multicycle\_path constraints in the Precision RTL Synthesis software and the Quartus II software equivalent

| Table 9-4. set_multicycle_path Constraints                                  |                                                                                 |
|-----------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| Precision RTL Synthesis Assignment                                          | Quartus II Equivalent                                                           |
| set_multicycle_path -from <from_node_list> <value></value></from_node_list> | set_multicycle_assignment -to {*} -from <node_list> <value></value></node_list> |
| set_multicycle_path -to <to_node_list> <value></value></to_node_list>       | set_multicycle_assignmet -to <node_list> -from {*} <value></value></node_list>  |

The Quartus II software does not support the rise or fall options on this assignment.

The Quartus II software does not support multicycle path with a through path specification. Any setting in Precision RTL Synthesis software with a -through specification cannot be mapped to a setting in the Quartus II software.

# Megafunctions & Architecture-Specific Features

Altera provides parameterizable megafunctions including LPM, device-specific Altera megafunctions, intellectual property (IP) available as Altera MegaCore functions, and IP available through the Altera Megafunction Partners Program (AMPPSM). You can use megafunctions by instantiating them in your HDL code or inferring them from generic HDL code.



For more details about specific Altera megafunctions, refer to the Quartus II Help. For more information about IP functions, consult the appropriate IP documentation.

If you want to instantiate a megafunction in your HDL code, you can use the MegaWizard Plug-In Manager to parameterize the function or you can instantiate the function using the port and parameter definition. The MegaWizard Plug-In Manager provides a graphical interface for customizing and parameterizing any available megafunction for the design. The "Instantiating Altera Megafunctions Using the MegaWizard Plug-In Manager" section describes the MegaWizard flow with the Precision RTL Synthesis software.

The Precision RTL Synthesis software automatically recognizes certain types of HDL code and infers the appropriate megafunction when a megafunction will provide optimal results. The Precision RTL Synthesis

software also provides options to control inference of certain types of megafunctions, as described in the "Inferring Altera Megafunctions from HDL Code" section.



For a detailed information about instantiating versus inferring megafunctions, refer to the *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook*. This chapter also provides details about using the MegaWizard Plug-In Manager in the Quartus II software and explains the files generated by the wizard. In addition, the chapter provides coding style recommendations and examples for inferring megafunctions in Altera devices.

# Instantiating Altera Megafunctions Using the MegaWizard Plug-In Manager

When you use the MegaWizard Plug-In Manager to set up and parameterize a megafunction and to create a custom megafunction variation, the MegaWizard creates either a VHDL or Verilog HDL wrapper file. This file instantiates the megafunction (a black-box methodology) or, for some megafunctions, generates a fully synthesizeable netlist for improved results using EDA synthesis tools such as the Precision RTL Synthesis software (a clear-box methodology).

# Clear-Box Methodology

You can use the MegaWizard Plug-In Manager to generate a fully synthesizable netlist. This flow is referred to as a clear-box methodology because the Precision RTL Synthesis software can "see" into the megafunction file. The clear box feature enables the synthesis tool to report more accurate resource utilization and timing estimates, taking better advantage of timing driven optimization.

This clear-box feature of the MegaWizard Plug-In Manager is turned on by choosing the **Generate clear box body (for EDA tools only)** in the **MegaWizard Plug-In Manager** for certain megafunctions. If the option does not appear, then clear box models are not supported for the selected megafunction. Turning on this option causes the MegaWizard Plug-In Manager to generate a synthesizable clear box netlist instead of the megafunction wrapper file described in the "Black-Box Methodology" section.

# Using MegaWizard-Generated Verilog HDL Files for Clear Box Megafunction Instantiation

The MegaWizard Plug-In Manager generates a Verilog HDL instantiation template file <code><output>\_inst.v</code> for use in your Precision RTL Synthesis design. This file can help you instantiate the megafunction clear box netlist file, <code><output file>.v</code>, in your top-level design. Include the megafunction clear box netlist file in your Precision RTL Synthesis project and the information gets passed to the Quartus II software in the Precision RTL Synthesis-generated EDIF output file.

# Using MegaWizard-Generated VHDL Files for Clear Box Megafunction Instantiation

The MegaWizard Plug-In Manager generates a VHDL Component declaration file <code><output file>.cmp</code> and a VHDL Instantiation template file <code><output file>\_inst.vhd</code> for use in your design. These files help to instantiate the megafunction clear box netlist file, <code><output file>.vhd</code>, in your top-level design. Include the megafunction clear box netlist file in your Precision RTL Synthesis project and the information gets passed to the Quartus II software in the Precision RTL Synthesis-generated EDIF output file.

# Black-Box Methodology

Using the MegaWizard Plug-In Manager-generated wrapper file is referred to as a black-box methodology because the megafunction is treated as a black box in the Precision RTL Synthesis software. The black-box wrapper file is generated by default in the MegaWizard Plug-In Manager and is available for all megafunctions.

The black-box methodology does not allow the synthesis tool any visibility into the function module and so does not take full advantage of the synthesis tool's timing driven optimization.

# Using MegaWizard Plug-In Manager-Generated Verilog HDL Files for Black-Box Megafunction Instantiation

The MegaWizard Plug-In Manager generates a Verilog HDL instantiation template file <code><output file>\_inst.v</code> and a hollow-body black-box module declaration <code><output file>\_bb.v</code> for use in your Precision RTL Synthesis design. The instantiation template file helps to instantiate the megafunction variation wrapper file, <code><output file>.v</code>, in your top-level design. Add the hollow-body black-box module declaration <code><output file>\_bb.v</code> to your Precision RTL Synthesis project to describe the port connections of the black box.

You do not have to include the megafunction variation wrapper file *<output file>.v* in your Precision RTL Synthesis project, but you must add it to your Quartus II project along with your Precision RTL synthesisgenerated EDIF netlist. Alternately, you can include the file in your Precision project and then right-click on the file in the input file list, and select **Properties**. In the input file properties dialog, turn on **Exclude file from Compile Phase** and click **OK**. When this option is on, the Precision RTL Synthesis software does not compile this file and the tool makes a copy of the file in the appropriate directory so that the Quartus II software can compile the design during placement and routing.

# Using MegaWizard Plug-In Manager-Generated VHDL Files for Black-Box Megafunction Instantiation

The MegaWizard Plug-In Manager generates a VHDL Component declaration file *<output file>.cmp* and a VHDL Instantiation template file *<output file>\_inst.vhd* for use in your Precision RTL Synthesis design. These files can help you instantiate the megafunction variation wrapper file, *<output file>.vhd*, in your top-level design.

You do not have to include the megafunction variation wrapper file, <output file>.vhd, in your Precision RTL synthesis project, but you must add it to your Quartus II project with your Precision RTL synthesis-generated EDIF netlist. Alternately, you can include the file in your Precision project and then right-click on the file in the input file list, and select Properties. In the input file properties dialog, turn on Exclude file from Compile Phase and click OK. When this option is on, the Precision RTL Synthesis software does not compile this file and the tool makes a copy of the file in the appropriate directory so that the Quartus II software can compile the design during placement and routing.

# Inferring Altera Megafunctions from HDL Code

The Precision RTL Synthesis software automatically recognizes certain types of HDL code and maps arithmetic and relational operators, and memory (RAM and ROM), to efficient technology-specific implementations. This allows for the use of technology-specific resources to implement these structures by inferring the appropriate Altera megafunction when a megafunction will provide optimal results. In some cases, the Precision RTL Synthesis software has options that you can use to disable or control inference.



For coding style recommendations and examples for inferring megafunctions in Altera devices, refer to the *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook*, and the *Precision Synthesis Style Guide* in the Precision RTL Synthesis Manuals Bookcase in the Help menu.

# Multipliers

The Precision RTL Synthesis software detects multipliers in HDL code and maps them directly to device atoms to implement the multiplier in the appropriate type of logic. The Precision RTL Synthesis software also allows you to control the device resources that are used to implement individual multipliers, as described in the following section.

# **Controlling DSP Block Inference for Multipliers**

By default, the Precision RTL Synthesis software uses DSP blocks available in the Stratix series of devices to implement multipliers. The default setting is **AUTO**, to allow Precision RTL Synthesis software the flexibility to choose between logic look-up tables (LUTs) and DSP blocks, depending on the size of the multiplier. You can use the Precision RTL Synthesis GUI or HDL attributes to direct the mapping to only logic elements or to only DSP blocks. The options for multiplier mapping in the Precision RTL Synthesis software are shown in Table 9–5.

| Table 9–5. Options for DEDICATED_MULT Parameter to Control Multiplier Implementation in Precision RTL Synthesis |                                                                                                    |  |
|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|--|
| Value                                                                                                           | Description                                                                                        |  |
| ON                                                                                                              | Use only DSP blocks to implement multipliers, regardless of the size of the multiplier.            |  |
| OFF                                                                                                             | Use only logic (LUTs) to implement multipliers.                                                    |  |
| AUTO                                                                                                            | Use logic (LUTs) and DSP blocks to implement multipliers depending on the size of the multipliers. |  |

# Using the GUI

Perform the following steps to set the **Use Dedicated Multiplier** option in the Precision RTL Synthesis GUI:

- 1. Compile the design.
- 2. In the Design Hierarchy browser, right-click the operator for the desired multiplier and click **Use Dedicated Multiplier**.

# Using Attributes

To control the implementation of a multiplier in your HDL code, use the dedicated\_mult attribute with the appropriate value from Table 9–5 as shown in Example 9–8 and Example 9–9.

### Example 9-8. Setting the dedicated\_mult Attribute in Verilog HDL

//synthesis attribute <signal name> dedicated mult <value>

# Example 9-9. Setting the dedicated\_mult Attribute in VHDL

```
ATTRIBUTE dedicated_mult: STRING;
ATTRIBUTE dedicated mult OF <signal name>: SIGNAL IS <value>;
```

The dedicated\_mult attribute can be applied to signals and wires; it does not work when applied to a register. This attribute can be applied only to simple multiplier code such as a = b \* c.

Some signals for which dedicated\_mult attribute is set may be synthesized away by the Precision RTL Synthesis software because of design optimization. In such cases, if you want to force the implementation, you should preserve the signal by setting the preserve\_signal attribute to TRUE as shown in Example 9–10.

### Example 9–10. Setting the preserve\_signal Attribute in Verilog HDL

//synthesis attribute < signal name > preserve signal TRUE

# Example 9-11. Setting the preserve\_signal Attribute in VHDL

```
ATTRIBUTE preserve_signal: BOOLEAN;
ATTRIBUTE preserve signal OF <signal name>: SIGNAL IS TRUE;
```

Example 9–12 and Example 9–13 are examples in Verilog HDL and VHDL of using the dedicated\_mult attribute to implement the given multiplier in regular logic in the Quartus II software.

### Example 9-12. Verilog HDL Multiplier Implemented in Logic

```
module unsigned_mult (result, a, b);
  output [15:0] result;
  input [7:0] a;
  input [7:0] b;
  assign result = a * b; //synthesis attribute result dedicated_mult OFF
endmodule
```

# Example 9-13. VHDL Multiplier Implemented in Logic

```
LIBRARY ieee:
USE ieee.std logic 1164.ALL;
USE ieee.std logic arith.ALL;
USE ieee.std logic unsigned.ALL;
ENTITY unsigned mult IS
   PORT (
      a: IN std logic vector (7 DOWNTO 0);
      b: IN std_logic_vector (7 DOWNTO 0);
      result: OUT std logic vector (15 DOWNTO 0));
ATTRIBUTE dedicated mult: STRING;
END unsigned mult;
ARCHITECTURE rtl OF unsigned mult IS
   SIGNAL a int, b int: UNSIGNED (7 downto 0);
   SIGNAL pdt int: UNSIGNED (15 downto 0);
ATTRIBUTE dedicated mult OF pdt int: SIGNAL IS "OFF";
BEGIN
   a int <= UNSIGNED (a);
   b int <= UNSIGNED (b);
   pdt_int <= a_int * b_int;</pre>
   result <= std logic vector(pdt int);
END rtl;
```

# Multiplier-Accumulators & Multiplier-Adders

The Precision RTL Synthesis software detects multiply-accumulators or multiply-adders in HDL code and infers an altmult\_accum or altmult\_add megafunction so that the logic can be placed in DSP blocks, or maps directly to device atoms to implement the multiplier in the appropriate type of logic.



The Precision RTL Synthesis software supports inference for these functions only if the target device family has dedicated DSP blocks.

The Precision RTL Synthesis software also allows you to control the device resources used to implement multiply-accumulators or multiply-adders in your project or in a particular module. Refer to the "Controlling DSP Block Inference" on page 9–26 section for more information.



For more information about DSP blocks in Altera devices, refer to the appropriate Altera device family handbook and device-specific documentation. For details about which functions a given DSP block can implement, refer to the DSP Solutions Center on the Altera web site.



For more information about inferring Multiply-Accumulator and Multiply-Adder megafunctions in HDL code, refer to the *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook*, and the *Precision Synthesis Style Guide* in the Precision RTL Synthesis Manuals Bookcase in the Help menu.

# Controlling DSP Block Inference

By default the Precision RTL Synthesis software infers the altmult\_add or altmult\_accum megafunction as appropriate for your design. These megafunctions allow the Quartus II software the flexibility to choose regular logic or DSP blocks depending on the device utilization and the size of the function.

You can use the extract\_mac attribute to prevent the inference of an altumult\_add or altmult\_accum megafunction in a certain module or entity. The options for this attribute are shown in Table 9–6.

| Table 9–6. Options for EXTRACT_MAC Attribute Controlling DSP Implementation |                                                               |  |
|-----------------------------------------------------------------------------|---------------------------------------------------------------|--|
| Value                                                                       | Description                                                   |  |
| TRUE                                                                        | The altmult_add or altmult_accum megafunction is inferred     |  |
| FALSE                                                                       | The altmult_add or altmult_accum megafunction is not inferred |  |

To control inference, use the extract\_mac attribute with the appropriate value from Table 9–6 in your HDL code as shown in Example 9–14 and Example 9–15.

### Example 9–14. Setting the extract mac Attribute in Verilog HDL

//synthesis attribute < module name > extract mac < value >

### Example 9-15. Setting the extract mac Attribute in VHDL

ATTRIBUTE extract\_mac: BOOLEAN;
ATTRIBUTE extract\_mac OF <entity name>: ENTITY IS <value>;

To control the implementation of the multiplier portion of a multiply-accumulator or multiply-adder, you must use the dedicated\_mult attribute as described in the "Controlling DSP Block Inference" section. See that section for syntax details.

Example 9–16 and Example 9–17 use the extract\_mac, dedicated\_mult, and preserve\_signal attributes (in Verilog HDL and VHDL) to implement the given DSP function in logic in the Quartus II software.

# Example 9-16. Use of extract\_mac, dedicated\_mult & preserve\_signal in Verilog HDL

```
module unsig altmult accum1 (dataout, dataa, datab, clk, aclr, clken);
   input [7:0] dataa, datab;
   input clk, aclr, clken;
   output
            [31:0] dataout;
             [31:0] dataout;
   req
   wire
              [15:0] multa;
   wire
             [31:0] adder out;
   assign multa = dataa * datab;
   //synthesis attribute multa preserve signal TRUE
   //synthesis attribute multa dedicated mult OFF
   assign adder out = multa + dataout;
   always @ (posedge clk or posedge aclr)
   begin
      if (aclr)
      dataout <= 0;
   else if (clken)
      dataout <= adder out;</pre>
   end
   //synthesis attribute unsig altmult accum1 extract mac FALSE
endmodule
```

### Example 9-17. Use of extract mac. dedicated mult, and preserve signal in VHDL

```
LIBRARY ieee;
USE ieee.std_logic_1164.all;
USE ieee.std_logic_arith.all;
USE ieee.std_logic_signed.all;

ENTITY signedmult_add IS
    PORT(
        a, b, c, d: IN STD_LOGIC_VECTOR (7 DOWNTO 0);
        result: OUT STD_LOGIC_VECTOR (15 DOWNTO 0)
);

ATTRIBUTE preserve_signal: BOOLEAN;
ATTRIBUTE dedicated_mult: STRING;
ATTRIBUTE extract_mac: BOOLEAN;
ATTRIBUTE extract_mac OF signedmult_add: ENTITY IS FALSE;
END signedmult_add;
```

```
ARCHITECTURE rtl OF signedmult add IS
   SIGNAL a_int, b_int, c_int, d_int : signed (7 DOWNTO 0);
   SIGNAL pdt int, pdt2 int : signed (15 DOWNTO 0);
   SIGNAL result int: signed (15 DOWNTO 0);
   ATTRIBUTE preserve_signal OF pdt int: SIGNAL IS TRUE;
   ATTRIBUTE dedicated mult OF pdt int: SIGNAL IS "OFF";
   ATTRIBUTE preserve signal OF pdt2_int: SIGNAL IS TRUE;
   ATTRIBUTE dedicated mult OF pdt2 int: SIGNAL IS "OFF";
BEGIN
   a int <= signed (a);
   b int <= signed (b);
   c int <= signed (c);
   d int <= signed (d);
   pdt int <= a int * b int;</pre>
   pdt2 int <= c int * d int;
   result int <= pdt int + pdt2 int;
   result <= STD LOGIC VECTOR(result int);</pre>
END rtl;
```

### RAM & ROM

The Precision RTL Synthesis software detects memory structures in HDL code and converts them to an operator that infers an altsyncram or lpm\_ram\_dp megafunction, depending on the device family. The software then places these functions in memory blocks.

The software supports inference for these functions only if the target device family has dedicated memory blocks.



For more information about inferring RAM and ROM megafunctions in HDL code, refer to the *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook*, and the *Precision Synthesis Style Guide* in the Precision RTL Synthesis Manuals Bookcase in the Help menu.

# Incremental Compilation & Block-Based Design

As designs become more complex and designers work in teams, a block-based hierarchical or incremental design flow is often an effective design approach. In an incremental compilation flow, you can make changes to part of the design while maintaining the placement and performance of unchanged parts of the design. Design iterations can be made dramatically faster by focusing new compilations on particular design partitions and merging results with the results of previous compilations of other partitions. In a bottom-up or team-based approach, you can perform optimization on individual blocks and then integrate them into a final design and optimize it at the top level.

Using the Precision RTL Synthesis software, you can create different netlist files for different partitions of a design hierarchy. Doing this makes each partition independent of the others for either a top-down or a bottom-up incremental compilation or LogicLock design flow. In either case, only the portions of a design that have been updated must be recompiled during design iterations. You can make changes and resynthesize one partition in a design to create a new netlist without affecting the synthesis results or fitting of other partitions. The following steps show the general top-down compilation flow when using these features of the Ouartus II software:

- Create Verilog HDL or VHDL design files as you do in the regular design flow.
- 2. Determine which hierarchical blocks you want to treat as separate partitions in your design.
- 3. Create a project with multiple implementations (or create multiple projects) in the Precision RTL Synthesis software, one for each partition in the design.
- 4. Disable I/O pad insertion in the implementations for lower-level partitions.
- 5. Compile and synthesize each implementation or each project in the Precision RTL Synthesis software, and make constraints as in the regular design flow.
- 6. Import the EDIF netlist and the Tcl file for each partition into the Quartus II software and set up the Quartus II project(s) to use the incremental compilation or LogicLock methodology.
- Compile your design in the Quartus II software and preserve the compilation results using the post-fit netlist type in incremental compilation or back-annotation in the LogicLock methodology.
- 8. When you make design or synthesis optimization changes to part of your design, resynthesize only the changed partition to generate the new EDIF netlist and Tcl file. Do not resynthesize the implementations or projects for the unchanged partitions.
- Import the new EDIF netlist and Tcl file into the Quartus II software and recompile the design in the Quartus II software using the incremental compilation or LogicLock methodology.



For more information about creating partitions and using the incremental compilation in the Quartus II software, refer to the Quartus II Incremental Compilation for Hierarchical & Team-Based Design chapter in volume 1 of the Quartus II Handbook. For more information about using the LogicLock feature in the Quartus II software, refer to the LogicLock Design Methodology chapter in volume 2 of the Quartus II Handbook.

# **Hierarchy & Design Considerations**

To ensure the proper functioning of the synthesis flow, you can create separate partitions only for modules, entities, or existing netlist files. In addition, each module or entity must have its own design file. If two different modules are in the same design file but are defined as being part of different partitions, you cannot maintain incremental synthesis because both regions must be recompiled when you change one of the modules.

Altera recommends that you register all inputs and outputs of each partition. This makes logic synchronous and avoids any delay penalty on signals that cross partition boundaries.

If you use boundary tri-states in a lower level block, the Precision RTL Synthesis software pushes the tri-states through the hierarchy to the top level to make use of the tri-state drivers on output pins of Altera devices. Because pushing tri-states requires optimizing through hierarchies, lower level tri-states are not supported with a block-based compilation methodology. You should use tri-state drivers only at the external output pins of the device and in the top-level block in the hierarchy.



For more tips on design partitioning, refer to the *Design Recommendations* for *Altera Devices* chapter in volume 1 of the *Quartus II Handbook*.

# Creating a Design with Separate Netlist Files

The first step in a hierarchical or incremental design flow is to ensure that different parts of your design do not affect each other. Ensure that you have separate netlists for each partition in your design so that you can take advantage of the incremental compilation and LogicLock design flows in the Quartus II software. If the whole design is in one netlist file, changes in one partition affect other partitions because of possible node name changes when you resynthesize the design.

You can create different implementations for each partition in your Precision RTL project, which allows you to switch between partitions without leaving the current project file, or you can create a separate project for each partition if you need separate projects for a bottom-up or team-based design flow.

Create a separate implementation or a separate project for each lower level module and for the top-level design that you want to maintain as a separate EDIF netlist file. Implement black-box instantiations of lower level modules in your top-level implementation or project.



For more information about managing implementations and projects, refer to the *Precision RTL Synthesis User's Manual* in the Precision Manuals Bookcase in the Help menu.

When synthesizing the implementations for lower level modules, perform these steps:

- Turn off Add IO Pads on the Optimization page under Set Options (Tools menu).
- 2. Read the HDL files for the modules.



Modules may include black-box instantiations of lower level modules that are also maintained as separate EDIF files.

3. Add constraints for all partitions in the design.

When synthesizing the top-level design implementation, perform these steps:

- 1. Read the HDL files for top-level designs.
- 2. Create black boxes for lower level modules in the top-level design.
- 3. Add constraints.



In a top-down incremental compilation flow, constraints made on lower level modules are not passed to the Quartus II software. Ensure that appropriate constraints are made in the top-level Precision RTL Synthesis project, or in the Quartus II project.

The following sections describe an example of implementing black boxes to create separate EDIF netlists. Figure 9–2 shows an example of a design hierarchy separated into various partitions.



Figure 9–2. Partitions in a Hierarchical Design

In Figure 9–2, the top-level partition contains the top-level block in the design (block A) and the logic that is not defined as part of another partition. In this example, the partition for top-level block A also includes the logic in the C subblock. Because block F is contained in its own partition, it is not treated as part of the top-level partition A. Another separate partition, B, contains the logic in blocks B, D, and E. In a team-based design, different engineers may work on the logic in different partitions. One netlist is created for the top-level module A and its submodule C, another netlist is created for B and its submodules D and E, while a third netlist is created for F. To create multiple EDIF netlist files for this design, follow these steps:

- Generate an EDIF file for module B. Use B.v/.vhd, D.v/.vhd, and E.v/.vhd as the source files.
- 2. Generate an EDIF file for module F. Use F.v/.vhd as the source file.
- Generate a top-level EDIF file for module A. Use A.v/.vhd and C.v/.vhd as the source files. Ensure that you create black boxes for modules B and F, which were optimized separately in the previous steps.

# Creating Black Boxes in Verilog HDL

Any design block that is not defined in the project or included in the list of files to be read for a project is treated as a black box by the software. In Verilog HDL, you must provide an empty module declaration for any module that is treated as a black box.

A black-box example for top-level file **A.v** follows. Use this same procedure for any lower level files, which also contain a black box for any module beneath the current level of hierarchy.

# Example 9-18. Verilog HDL Black Box for Top-Level File A.v

```
module A (data in, clk, e, ld, data out);
   input data in, clk, e, ld;
   output [15:0] data out;
   wire [15:0] cnt_out;
   B U1 (.data_in (data_in),.clk(clk), .ld (ld),.data_out(cnt_out));
   F U2 (.d(cnt out), .clk(clk), .e(e), .q(data out));
// Any other code in A.v goes here.
endmodule
// Empty Module Declarations of Sub-Blocks B and F follow here.
// These module declarations (including ports) are required for black
// boxes.
module B (data in, clk, ld, data out);
   input data in, clk, ld;
   output [15:0] data out;
endmodule
module F (d, clk, e, q);
   input [15:0] d;
   input clk, e;
   output [15:0] q;
endmodule
```

# Creating Black Boxes in VHDL

Any design block that is not defined in the project or included in the list of files to be read for a project is treated as a black box by the software. In VHDL, you need a component declaration for the black box just like any other block in the design.

A black box for the top-level file **A.vhd** is shown in the following example. Follow this same procedure for any lower level files that also contain a black box or for any block beneath the current level of hierarchy.

# Example 9-19. VHDL Black Box for Top-Level File A.vhd

```
LIBRARY ieee;
USE ieee.std logic 1164.all;
ENTITY A IS
PORT ( data in : IN INTEGER RANGE 0 TO 15;
   clk, e, ld : IN STD LOGIC;
   data out : OUT INTEGER RANGE 0 TO 15);
END A;
ARCHITECTURE a arch OF A IS
COMPONENT B PORT (
   data in : IN INTEGER RANGE 0 TO 15;
   clk, ld : IN STD LOGIC;
   d out : OUT INTEGER RANGE 0 TO 15);
END COMPONENT;
COMPONENT F PORT (
   d : IN INTEGER RANGE 0 TO 15;
   clk, e: IN STD_LOGIC;
   q : OUT INTEGER RANGE 0 TO 15);
END COMPONENT;
-- Other component declarations in A.vhd go here
signal cnt_out : INTEGER RANGE 0 TO 15;
BEGIN
U1 : B
PORT MAP (
   data in => data in,
   clk => clk,
   ld => ld,
   d_out => cnt_out);
U2 : F
PORT MAP (
   d => cnt out,
   clk => clk,
   e => e,
   q => data out);
-- Any other code in A.vhd goes here
END a arch;
```

After you complete the steps outlined in this section, you have different EDIF netlist files for each partition of the design. These files are ready for use in the incremental compilation or LogicLock design methodologies in the Ouartus II software.

#### **Creating Quartus II Projects for Multiple EDIF Files**

The Precision RTL Synthesis software creates a Tcl file for each EDIF file, and provides the Quartus II software with the appropriate constraints and information to set up a project. For details about using the Tcl script generated by the Precision RTL software to set up your Quartus II project and to pass your top-level constraints, refer to "Running the Quartus II Software Manually Using the Precision RTL Synthesis-Generated Tcl Script" on page 9–14.

Depending on your design methodology, you can create one Quartus II project for all EDIF netlists (a top-down flow), or a separate Quartus II project for each EDIF netlist (a bottom-up flow). In a top-down compilation design flow, you create design partition assignments and floorplan location assignments for each partition in the design within a single Quartus II project. This methodology provides the best quality of results and performance preservation during incremental changes to your design. You may need to use a bottom-up design flow when each partition must be optimized separately, such as in certain team-based design flows.

To perform a bottom-up compilation in the Quartus II software, create separate Quartus II projects and import each design partition into a top-level design using the incremental compilation export and import features to maintain placement results. Alternately, you can use the LogicLock design methodology to import each lower-level partition and maintain placement results.

The following sections describe how to create the Quartus II projects for these two design flows.

### Creating a Single Quartus II Project for a Top-Down Incremental Compilation Flow

Use the *<top-level project>.tcl* file generated for the top-level partition to create your Quartus II project and import all the netlists into this one Quartus II project for an incremental compilation flow. You can optimize all partitions within the single Quartus II project and take advantage of the performance preservation and compilation time reduction that incremental compilation provides. Figure 9–3 shows the design flow for the example design in Figure 9–2.

All the constraints from the top-level implementation are passed to the Quartus II software in the top-level Tcl file, but any constraints made only in the lower level implementations within the Precision RTL Synthesis software are not forward-annotated. Enter these constraints manually in your Quartus II project.

Use a.tcl to import top-level Precsion RTL synthesis software assignments.
Enter any lower level assignments manually.

Figure 9–3. Design Flow Using Multiple EDIF Files with One Quartus II Project

#### Creating Multiple Quartus II Projects for a Bottom-Up Flow

Use the Tcl files generated by the Precision RTL Synthesis software for each Precision RTL Synthesis software implementation or project to generate multiple Quartus II projects, one for each partition in the design. Each designer in the project can optimize their block separately in the Quartus II software and export the placement of their blocks using the incremental compilation or LogicLock design methodology. Designers should create a LogicLock region for each block; the top-level designer should then import all the blocks and assignments into the top-level project. Figures 9–4 shows the design flow for the example design in Figure 9–2.



Figure 9-4. Design Flow: Using Multiple EDIF Files with Multiple Quartus II Projects

#### Conclusion

Advanced synthesis is an important part of the design flow. The Mentor Graphics Precision RTL Synthesis software and Quartus II design flow allows you to control how to prepare your design files for the Quartus II place-and-route process. This allows you to improve performance and optimize a design for use with Altera devices. Several of the methodologies outlined in this chapter can help you optimize a design to achieve performance goals and save design time.



## 10. Mentor Graphics LeonardoSpectrum Support

QII51010-6.0.0

#### Introduction

As programmable logic devices (PLDs) become more complex and require increased performance, advanced synthesis has become an important part of the design flow. Combining HDL coding techniques, Mentor Graphics LeonardoSpectrum<sup>TM</sup> software constraints, and Quartus<sup>®</sup> II options provide the performance increase needed for today's system-on-a-programmable-chip (SOPC) designs.

The LeonardoSpectrum software is a mature synthesis tool supporting legacy devices and many current devices. The LeonardoSpectrum software version 2005b supports the Stratix® II, Stratix, Stratix GX, Cyclone<sup>TM</sup> II, Cyclone, MAX® II, MAX series, APEX<sup>TM</sup> series, FLEX® series, and ACEX® series device families. Altera® recommends using the advanced Precision Synthesis software for new designs in new device families.



For more information about Precision RTL Synthesis, refer to the *Mentor Graphics Precision RTL Synthesis Support* chapter in volume 1 of the *Quartus II Handbook*.

This chapter documents key design methodologies and techniques for achieving better performance in Altera devices using the LeonardoSpectrum and Quartus II design flow.



This chapter assumes that you have set up, licensed, and are familiar with the LeonardoSpectrum software.



To obtain and license the LeonardoSpectrum software, refer to the Mentor Graphics web site at **www.mentor.com**. For information about installing the LeonardoSpectrum software and setting up your working environment, refer to the *LeonardoSpectrum Installation Guide* and the *LeonardoSpectrum User's Manual*.

#### **Design Flow**

Following are the basic steps in a LeonardoSpectrum-Quartus II design flow:

- Create Verilog HDL or VHDL design files in the LeonardoSpectrum software or a text editor.
- 2. Import the Verilog HDL or VHDL design files into the LeonardoSpectrum software for synthesis.
- 3. Select a target device and add timing constraints and compiler directives to help optimize the design during synthesis.
- 4. Synthesize the project in the LeonardoSpectrum software.
- Create a Quartus II project and import the technology-specific EDIF Input File (.edf) netlist and the Tcl Script File (.tcl) generated by the LeonardoSpectrum software into the Quartus II software for placement and routing, and for performance evaluation.
- After obtaining place-and-route results that meet your needs, configure or program the Altera device.

Figure 10–1 shows the recommended design flow using the LeonardoSpectrum and Quartus II software.

If your area and timing requirements are satisfied, use the programming files generated from the Quartus II software to program or configure the Altera device. As shown in Figure 10–1, if the area or timing requirements are not met, change the constraints in the LeonardoSpectrum software and re-run the synthesis. Repeat the process until the area and timing requirements are met. You can also use other Quartus II software options and techniques to meet the area and timing requirements.



Figure 10-1. Recommended Design Flow Using LeonardoSpectrum & Quartus II Software

The LeonardoSpectrum software supports both VHDL and Verilog HDL source files. With the appropriate license, it also supports mixed synthesis, allowing a combination of VHDL and Verilog HDL source files.

After synthesis, the LeonardoSpectrum software produces several intermediate and output files. Table 10–1 lists these file extensions with a short description of each file.

| Table 10–1. LeonardoSpectrum Intermediate & Output Files |                                                                                                                           |  |
|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|--|
| File<br>Extension(s)                                     | File Description                                                                                                          |  |
| .xdb                                                     | Technology-independent register transfer level (RTL) netlist file that can only be read by the LeonardoSpectrum software. |  |
| .edf                                                     | Technology-specific output netlist in electronic design interchange format (EDIF).                                        |  |
| .acf/.tcl (1)                                            | Forward-annotated constraint file containing constraints and assignments.                                                 |  |

#### Note to Table 10-1:

(1) An assignment and configuration (.acf) file is created only for ACEX 1K, FLEX series, and MAX series devices. The assignment and configuration file is generated for backward compatibility with the MAX+PLUS® II software. A Tcl Script File (.tcl) is generated for the Quartus II software which also contains Tcl commands to create a Quartus II project.



Altera recommends that you do not use project directory names that include spaces. Some file operations in the LeonardoSpectrum software do not work correctly if the path name contains spaces.

Specify timing constraints and compiler directives for the design in the LeonardoSpectrum software, or in a constraint file (.ctr). Many of these constraints are forward-annotated in the Tcl file for use by the Quartus II software.

The LeonardoInsight<sup>™</sup> Schematic Viewer is an add-on graphical tool for schematic views of the technology-independent RTL netlist (.xdb) and the technology-specific gate-level results. You can use the Schematic Viewer to visually analyze and debug the design. It also supports cross probing between the RTL and gate-level schematics, the design browser, and the source code in the HDLInventor<sup>™</sup> text editor.

## Optimization Strategies

You can configure most general settings in the **Quick Setup** tab in the LeonardoSpectrum user interface. Other Flow tabs provide additional options, and some Flow tabs include multiple Power tabs (at the bottom of the screen) with still more options. Advanced optimization options in the LeonardoSpectrum software include timing-driven synthesis, encoding style, resource sharing, and mapping I/O registers.

#### **Timing-Driven Synthesis**

The LeonardoSpectrum software supports timing-driven synthesis through user-assigned timing constraints to optimize the performance of the design. Setting constraints in the LeonardoSpectrum software are straightforward. Constraints such as clock frequency can be specified globally or for individual clock signals. The following sections describe how to set the various types of timing constraints in the LeonardoSpectrum software.

The timing constraints described in the "Global Power Tab" section are set in the **Constraints** Flow tab. In this tab, there are Power tabs at the bottom, such as **Global** and **Clock**, for setting various constraints.

#### Global Power Tab

The **Global** tab is the default Power tab in the **Constraints** Flow tab. Specify the global clock frequency here. The **Clock Frequency** on the **Quick Setup** tab is equivalent to the **Registers to Registers** delay setting. You can also specify the following: **Input Ports to Registers, Registers to Output Ports**, and **Inputs to Outputs** delays that correspond to global  $t_{SU}$ ,  $t_{CO}$ , and  $t_{PD}$  requirements, respectively, in the Quartus II software. The timing diagram on this tab reflects the settings you have made.

#### Clock Power Tab

You can set various constraints for each clock in your design. First, select the clock name in the **Clock(s)** window. The clock names appear after the design is read from the **Input** Flow tab. Configure settings for that particular clock and click **Apply**. If necessary, you can also set the **Duty Cycle** to a value other than the default 50%. The timing diagram shows these settings.

If a clock has an **Offset** from the main clock, which is considered to be time "0", this constraint corresponds to the OFFSET\_FROM\_BASE\_CLOCK setting in the Quartus II software.

You can specify the pin number for the clock input pin in the **Pin Location** field. This pin number is passed to the Quartus II software for place-and-route, but does not affect synthesis in the LeonardoSpectrum software.

#### Input & Output Power Tabs

Configure settings for individual input or output pins in the **Input** and **Output** tabs. First, select a name in the **Input Ports** or **Output Ports** window. The names appear after the design is read from the **Input** Flow tab. Then make the setting for that pin as described below.

The **Arrival Time** setting indicates that the input signal arrives a specified time after the rising clock edge (time "0"). This setting constrains the path from the pin to the first register by including the arrival time in the total delay, and corresponds to the EXTERNAL\_INPUT\_DELAY assignment in the Quartus II software.

The **Required Time** setting indicates the maximum delay after time "0" that the output signal should arrive at the output pin. This setting directly constrains the register to output delay, and corresponds with the EXTERNAL OUTPUT DELAY assignment in the Quartus II software.

Specify the pin number for the I/O pin in the **Pin Location** field. This pin number is passed to the Quartus II software for place-and-route, but does not affect synthesis in the LeonardoSpectrum software.

#### Other Constraints

The following sections describe other constraints that can be set with the LeonardoSpectrum user interface.

#### Encoding Style

The LeonardoSpectrum software encodes state machines during the synthesis process. To improve performance when coding state machines, separate state machine logic from all arithmetic functions and data paths. Once encoded, a design cannot be re-encoded later in the optimization process. You must follow a particular VHDL or Verilog HDL coding style for the LeonardoSpectrum software to identify the state machine.

Table 10-2 shows the state machine encoding styles supported by the LeonardoSpectrum software.

| Table 10–2. State Machine Encoding Styles in the LeonardoSpectrum Software |                                                                                                                                                                                                                                            |  |  |
|----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Style                                                                      | Description                                                                                                                                                                                                                                |  |  |
| Binary                                                                     | Generates state machines with the fewest possible flipflops. Binary state machines are useful for area-critical designs when timing is not the primary concern.                                                                            |  |  |
| Gray                                                                       | Generates state machines where only one flipflop changes during each transition. Gray-encoded state machines tend to be glitchless.                                                                                                        |  |  |
| One-hot                                                                    | Generates state machines containing one flipflop for each state. One-hot state machines provide the best performance and shortest clock-to-output delays. However, one-hot implementations are usually larger than binary implementations. |  |  |
| Random                                                                     | Generates state machines using random state machine encoding. Only use random state machine encoding when no other implementation achieves the desired results.                                                                            |  |  |
| Auto (default)                                                             | Implements binary or one-hot encoding, depending on the size of enumerated types in the state machine.                                                                                                                                     |  |  |

The **Encoding Style** setting is created in the **Input** Flow tab. It instructs the software to use a particular state machine encoding style for all state machines. The default **Auto** selection implements binary or one-hot encoding, depending on the size of enumerated types in the state machine.



To ensure proper recognition and improve performance when coding state machines, refer to the *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook* for design guidelines.

#### Resource Sharing

You can also enable the **Resource Sharing** setting in the **Input** Flow tab. This setting allows optimization to reduce device resources. You should generally leave this setting turned on.

#### Mapping I/O Registers

The **Map I/O Registers** option is located in the **Technology** Flow tab. The **Map I/O Registers** option applies to Altera FPGAs containing I/O cells (IOCs) or I/O elements (IOE). If the option is turned on, input or output registers are moved into the device's I/O cells for faster setup or clock-to-output times.

# Timing Analysis with the Leonardo-Spectrum Software

The LeonardoSpectrum software reports successful synthesis with an information message in the **Transcript** or **Information** window. Estimated device usage and timing results are reported in the Device Utilization section of this window. Figure 10–2 shows an example of a LeonardoSpectrum compilation report.

Figure 10–2. LeonardoSpectrum Compilation Report

| *****                                 | *********   | *****   | ******               | *****       |
|---------------------------------------|-------------|---------|----------------------|-------------|
| Device Utilization for EP20K200EQC208 |             |         |                      |             |
| *************                         |             |         |                      |             |
| Resour                                | De          | Used    | Avail                | Utilization |
| IOs                                   |             | 22      | <br>136              | 16.18%      |
| LCs                                   |             |         | 8320                 |             |
| Memory                                | Bits        | ō       |                      | 0.00%       |
|                                       |             |         |                      |             |
|                                       |             | Clock 1 | Frequency            | Report      |
|                                       | Clock       | :       | Frequenc             | у<br>——     |
|                                       | olk<br>olk2 |         | 52.2 MHz<br>149.5 MH |             |
|                                       |             | Critica | al Path R            | eport       |

The LeonardoSpectrum software estimates the timing results based on timing models. The LeonardoSpectrum software has no information about how the design is placed and routed in the Quartus II software, so it cannot report accurate routing delays. Additionally, if the design includes any black-boxed Altera-specific functions, the LeonardoSpectrum software does not report timing information for these functions.

Final timing results are generated by the Quartus II software and are reported separately in the **Transcript** or **Information** window if the **Run Integrated Place and Route** option is turned on. Refer to "Integration with the Quartus II Software" on page 10–10 for more information.

## Exporting Designs Using NativeLink Integration

You can use NativeLink® integration to integrate the LeonardoSpectrum software and the Quartus II software with a single GUI for both the synthesis and place-and-route operations. NativeLink integration allows you to run the Quartus II software from within the LeonardoSpectrum software GUI, or to run the LeonardoSpectrum software from within the Quartus II software GUI for device families supported in the Quartus II software.

#### **Generating Netlist Files**

The LeonardoSpectrum software generates an EDIF netlist file readable as an input file in the Quartus II software for place-and-route. Select the EDIF file option name in the **Output** Flow tab. The EDIF netlist is also generated if the **Auto** option is turned on in the **Output** Flow tab.

#### **Including Design Files for Black-Boxed Modules**

If the design has black-boxed megafunctions, be sure to include the MegaWizard® Plug-In Manager-generated custom megafunction variation design file in the Quartus II project directory, or add it to the list of project files for place-and-route.

#### **Passing Constraints with Scripts**

The LeonardoSpectrum software can write out a Tcl file called <project name>.tcl. This file contains commands to create a Quartus II project along with constraints and other assignments. To output a Tcl script, turn on the Write Vendor Constraint Files option in the Output Flow tab.

To create and compile a Quartus II project using the Tcl file generated from the LeonardoSpectrum software, perform the following steps in the Quartus II software:

- 1. Place the EDIF netlist files and Tcl scripts in the same directory.
- 2. On the View menu, point to Utility, and click **Tcl Console** to open the Quartus II Tcl Console.
- 3. Type source <path>/<project name>.tcl ←, at a Tcl Console command prompt.
- 4. On the File menu, click **Open Project** to open the new project. On the Processing menu, click **Start Compilation**.

#### Integration with the Quartus II Software

The **Place And Route** section in the **Quick Setup** tab allows you to launch the Quartus II software from within the LeonardoSpectrum software. Turn on the **Run Integrated Place and Route** option to start the compilation using the Quartus II software to show the fitting and performance results. You can also run the place-and-route software by turning on the **Run Quartus** option on the **Physical** Flow tab and clicking **Run PR**.

To use integrated place-and-route software, on the Options menu, point to Place and Route Path and click **Tools**, and specify the location of the Quartus II software executable file (browse to *Quartus II software installation directory* >/bin).

#### Guidelines for Altera Megafunctions & LPM Functions

Altera provides parameterizable megafunctions ranging from simple arithmetic units, such as adders and counters, to advanced phase-locked loop (PLL) blocks, multipliers, and memory structures. These functions are performance-optimized for Altera devices. Megafunctions include the library of parameterized modules (LPM), device-specific megafunctions such as PLLs, LVDS, and digital signal processing (DSP) blocks, intellectual property (IP) available as Altera MegaCore® functions, and IP available through the Altera Megafunction Partners Program (AMPPsm).



Some IP cores require that you synthesize them in the LeonardoSpectrum software. Refer to the user guide for the specific IP.

There are two methods for handling megafunctions in the LeonardoSpectrum software: inference and instantiation.

The LeonardoSpectrum software supports inferring some of the Altera megafunctions, such as multipliers, DSP functions, and RAM and ROM blocks. The LeonardoSpectrum software supports all Altera megafunctions through instantiation.

#### Instantiating Altera Megafunctions

There are two methods of instantiating Altera megafunctions in the LeonardoSpectrum software. The first and least common method is to directly instantiate the megafunction in the Verilog HDL or VHDL code. The second method, to maintain target technology awareness, is to use the MegaWizard Plug-In Manager in the Quartus II software to setup and parameterize a megafunction variation. The megafunction wizard creates a wrapper file that instantiates the megafunction. The advantage of using the megafunction wizard in place of the instantiation method is the

megafunction wizard properly sets all the parameters and you do not need the library support required in the direct instantiation method. This is referred to as the black box methodology.



Altera recommends using the megafunction wizard to ensure that the ports and parameters are set correctly.



When directly instantiating megafunctions, see the Quartus II Help for a list of the ports and parameters.

#### Inferring Altera Memory Elements

The LeonardoSpectrum software can infer memory blocks from Verilog HDL or VHDL code. When the LeonardoSpectrum software detects a RAM or ROM from the style of the RTL code at a technology-independent level, it then maps the element to a generic module in the RTL database. During the technology-mapping phase of synthesis, the LeonardoSpectrum software maps the generic module to the most optimal primitive memory cells, or Altera megafunction, for the target Altera technology.



For more information about inferring RAM and ROM megafunctions, including examples of VHDL and Verilog HDL code, see the *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook*.

#### **Inferring RAM**

The LeonardoSpectrum software supports RAM inference for various device families. The restrictions for the LeonardoSpectrum software to successfully infer RAM in a design are listed below:

- The write process must be synchronous
- The read process can be asynchronous or synchronous depending on the target Altera architecture
- Resets on the memory are not supported

Table 10-3 shows a summary of the minimum memory sizes and minimum address widths for inferring RAM in various device families.

To disable RAM inference, set the extract\_ram and infer\_ram variables to "false." On the Tools menu, click **Variable Editor** to enter the value "false" when synthesizing in the user interface with the Advanced Flow tabs, or add the commands set extract\_ram false and set infer ram false to your synthesis script.

| Table 10–3. Inferring RAM Summary |                                                     |                                     |                     |  |
|-----------------------------------|-----------------------------------------------------|-------------------------------------|---------------------|--|
|                                   | Stratix II, Stratix, Stratix GX<br>& Cyclone Series | APEX Series, Excalibur &<br>Mercury | FLEX 10KE & ACEX 1K |  |
| RAM primitive                     | altsyncram                                          | altdpram                            | altdpram            |  |
| Minimum RAM size                  | 2 bits                                              | 64 bits                             | 128 bits            |  |
| Minimum address width             | 1 bit                                               | 4 bits                              | 5 bits              |  |

#### **Inferring ROM**

You can implement ROM behavior in HDL source code with CASE statements or specify the ROM as a table. The LeonardoSpectrum software infers both synchronous and asynchronous ROM depending on the target Altera device. For example, memory for the Stratix series devices must be synchronous to be inferred.

To disable ROM inference, set the extract\_rom variable to "false." To enter the value "false" when synthesizing in the user interface with the **Advanced Flow** tabs, on the Tools menu, click **Variable Editor**, or add the commands set extract rom false to your synthesis script.

#### **Inferring Multipliers & DSP Functions**

Some Altera devices include dedicated DSP blocks optimized for DSP applications. The following Altera megafunctions are used with DSP block modes:

- lpm mult
- altmult\_accum
- altmult add

You can instantiate these megafunctions in the design or have the LeonardoSpectrum software infer the appropriate megafunction by recognizing a multiplier, multiplier-accumulator (MAC), or multiplier-adder in the design. The Quartus II software maps the functions to the DSP blocks in the device during place-and-route.



For more information about inferring multipliers and DSP functions, including examples of VHDL and Verilog HDL code, refer to the *Recommended HDL Coding Styles* chapter in volume 1 of *The Quartus II Handbook*.

#### Simple Multipliers

The lpm\_mult megafunction implements the DSP block in the simple multiplier mode. The following functionality is supported in this mode:

- The DSP block includes registers for the input and output stages, and an intermediate pipeline stage
- Signed and unsigned arithmetic is supported

#### Multiplier Accumulators

The altmult\_accum megafunction implements the DSP block in the multiply-accumulator mode. The following functionality is supported in this mode:

- The DSP block includes registers for the input and output stages, and an intermediate pipeline stage
- The output registers are required for the accumulator
- The input and pipeline registers are optional
- Signed and unsigned arithmetic is supported



If the design requires input registers to be used as shift registers, use the black-boxing method to instantiate the altmult\_accum megafunction.

#### Multiplier Adders

The LeonardoSpectrum software can infer multiplier adders and map them to either the two-multiplier adder mode or the four-multiplier adder mode of the DSP blocks. The LeonardoSpectrum software maps the HDL code to the correct altmult add function.

The following functionality is supported in these modes:

- The DSP block includes registers for the input and output stages and an intermediate pipeline stage
- Signed and unsigned arithmetic is supported, but support for the Verilog HDL "signed" construct is limited

#### **Controlling DSP Block Inference**

In devices that include dedicated DSP blocks, multipliers, multiply-accumulators, and multiply-adders can be implemented either in DSP blocks or in logic. You can control this implementation through attribute settings in the LeonardoSpectrum software.

As shown in Table 10–4, attribute settings in the LeonardoSpectrum software control the implementation of the multipliers in DSP blocks or logic at the signal block (or module), and project level.

| Table 10 | Table 10-4. Attribute Settings for DSP Blocks in the LeonardoSpectrum Software Note (1) |       |                                                                                                                                                              |  |
|----------|-----------------------------------------------------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Level    | Attribute Name                                                                          | Value | Description                                                                                                                                                  |  |
| Global   | extract_mac (2)                                                                         | TRUE  | All multipliers in the project mapped to DSP blocks.                                                                                                         |  |
|          |                                                                                         | FALSE | All multipliers in the project mapped to logic.                                                                                                              |  |
| Module   | extract_mac (3)                                                                         | TRUE  | Multipliers inside the specified module mapped to DSP blocks.                                                                                                |  |
|          |                                                                                         | FALSE | Multipliers inside the specified module mapped to logic.                                                                                                     |  |
| Signal   | dedicated_mult                                                                          | ON    | LPM inferred and multipliers implemented in DSP block.                                                                                                       |  |
|          |                                                                                         | OFF   | LPM inferred, but multipliers implemented in logic by the Quartus II software.                                                                               |  |
|          |                                                                                         | LCELL | LPM not inferred, and multipliers implemented in logic by the LeonardoSpectrum software.                                                                     |  |
|          |                                                                                         | AUTO  | LPM inferred, but the Quartus II software automatically maps the multipliers to either logic or DSP blocks based on the Quartus II software place-and-route. |  |

#### Notes to Table 10-4:

- (1) The extract mac attribute takes precedence over the dedicated mult attribute.
- (2) For devices with DSP blocks, the extract mac attribute is set to "true" by default for the entire project.
- (3) For devices with DSP blocks, the extract mac attribute is set to "true" by default for all modules.

#### Global Attribute

You can set the global attribute extract\_mac to control the implementation of multipliers in DSP blocks for the entire project. You can set this attribute using the script interface. The script command is:

set extract\_mac <value>

#### Module Level Attributes

You can control the implementation of multipliers inside a module or component by setting attributes in the Verilog HDL source code. The attribute used is extract\_mac. Setting this attribute for a module affects only the multipliers inside that module. The command is:

//synthesis attribute <module name> extract mac <value>

The Verilog HDL and VHDL codes samples shown in Examples 10-1 and 10-2 show how to use the extract mac attribute.

#### Example 10-1. Using Module Level Attributes in Verilog HDL Code

```
module mult_add ( dataa, datab, datac, datad, result);
//synthesis attribute mult add extract mac FALSE
// Port Declaration
input [15:0] dataa;
input [15:0] datab;
input [15:0] datac;
input [15:0] datad;
output [32:0] result;
// Wire Declaration
wire [31:0] mult0 result;
wire [31:0] mult1_result;
// Implementation
// Each of these can go into one of the 4 mults in a
// DSP block
assign mult0 result = dataa * `signed datab;
//synthesis attribute mult0 result preserve signal TRUE
assign mult1 result = datac * datad;
// This adder can go into the one-level adder in a DSP
// block
assign result = (mult0 result + mult1 result);
endmodule
```

#### Example 10-2. Using Module Level Attributes in VHDL Code

```
library ieee ;
USE ieee.std logic 1164.all;
USE ieee.std logic arith.all;
entity mult acc is
   generic (size : integer := 4) ;
   port (
      a: in std logic vector (size-1 downto 0) ;
      b: in std logic vector (size-1 downto 0) ;
      clk : in std logic;
        accum out: inout std logic vector (2*size downto 0)
   ) ;
  attribute extract mac : boolean;
  attribute extract mac of mult acc : entity is FALSE;
end mult acc;
architecture synthesis of mult_acc is
    signal a_int, b_int : signed (size-1 downto 0);
    signal pdt int : signed (2*size-1 downto 0);
    signal adder out : signed (2*size downto 0);
begin
   a int <= signed (a);
   b_int <= signed (b);</pre>
   pdt int <= a int * b int;
   adder out <= pdt int + signed(accum out);
   process (clk)
   begin
       if (clk'event and clk = '1') then
          accum_out <= std_logic_vector (adder_out);</pre>
       end if;
    end process;
end synthesis ;
```

#### Signal Level Attributes

You can control the implementation of individual lpm\_mult multipliers by using the dedicated\_mult attribute as shown below:

//synthesis attribute <signal\_name> dedicated\_mult <value>



The dedicated\_mult attribute is only applicable to signals or wires; it is not applicable to registers.

Table 10--5 shows the supported values for the  $\texttt{dedicated\_mult}$  attribute.

| Table 1 | Table 10–5. Values for the dedicated_mult Attribute                                                                                          |  |  |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Value   | Description                                                                                                                                  |  |  |
| ON      | LPM inferred and multipliers implemented in DSP block.                                                                                       |  |  |
| OFF     | LPM inferred and multipliers synthesized, implemented in logic, and optimized by the Quartus II software. (1)                                |  |  |
| LCELL   | LPM not inferred and multipliers synthesized, implemented in logic, and optimized by the LeonardoSpectrum software. $(1)$                    |  |  |
| AUTO    | LPM inferred but the Quartus II software maps the multipliers automatically to either the DSP block or logic based on resource availability. |  |  |

#### Note to Table 10-5:

(1) Although both dedicated\_mult=OFF and dedicated\_mult=LCELLS result in logic implementations, the optimized results in these two cases may differ.



Some signals for which the dedicated\_mult attribute is set may get synthesized away by the LeonardoSpectrum software due to design optimization. In such cases, if you want to force the implementation, the signal is preserved from being synthesized away by setting the preserve\_signal attribute to "true."

The extract\_mac attribute must be set to "false" for the module or project level when using the dedicated\_mult attribute.

Examples 10-3 and 10-4 are samples of Verilog HDL and VHDL codes, respectively, using the <code>dedicated\_mult</code> attribute.

#### Example 10-3. Signal Attributes for Controlling DSP Block Inference in Verilog HDL Code

```
module mult (AX, AY, BX, BY, m, n, o, p);
input [7:0] AX, AY, BX, BY;
output [15:0] m, n, o, p;
wire [15:0] m_i = AX * AY; // synthesis attribute m_i dedicated_mult ON
// synthesis attribute m i preserve signal TRUE
//Note that the preserve_signal attribute prevents
// signal m i from getting synthesized away
wire [15:0] n i = BX * BY; // synthesis attribute n i dedicated mult OFF
wire [15:0] o_i = AX * BY; // synthesis attribute o_i dedicated_mult AUTO
wire [15:0] p_i = BX * AY; // synthesis attribute p_i dedicated_mult LCELL
// since n_i , o_i , p_i signals are not preserved,
// they may be synthesized away based on the design
assign m = m i;
assign n = n i;
assign o = o i;
assign p = p_i;
endmodule
```

#### Example 10–4. Signal Attributes for Controlling DSP Block Inference in VHDL Code

```
library ieee ;
USE ieee.std logic 1164.all;
USE ieee.std logic arith.all;
USE ieee.std logic unsigned.all;
USE ieee.std logic signed.all;
ENTITY mult is
PORT ( AX, AY, BX, BY: IN
   std logic vector (17 DOWNTO 0);
m,n,o,p: OUT
   std logic vector (35 DOWNTO 0));
attribute dedicated mult: string;
attribute preserve signal : boolean
END mult:
ARCHITECTURE struct of mult is
signal m i, n i, o i, p i : unsigned (35 downto 0);
attribute dedicated mult of m i:signal is "ON";
attribute dedicated mult of n i:signal is "OFF";
attribute dedicated mult of o i:signal is "AUTO";
attribute dedicated mult of p i:signal is "LCELL";
begin
m i <= unsigned (AX) * unsigned (AY);
n i <= unsigned (BX) * unsigned (BY);
o i <= unsigned (AX) * unsigned (BY);
p i <= unsigned (BX) * unsigned (AY);
m <= std logic vector(m i);
n <= std logic vector(n i);
o <= std logic vector(o i);
p <= std logic vector(p i);
end struct;
```

#### Guidelines for Using DSP Blocks

In addition to the guidelines mentioned earlier in this section, use the following guidelines while designing with DSP blocks in the LeonardoSpectrum software:

- To access all the control signals for the DSP block, such as sign A, sign B, and dynamic addnsub, use the black-boxing technique.
- While performing signed operations, ensure that the specified data width of the output port matches the data width of the expected result. Otherwise, the sign bit may be lost or data may be incorrect because the sign is not extended.

  For example, if the data widths of input A and B are width\_a and width\_b, respectively, then the maximum data width of the result can be (width a + width b + 2) for the four-multipliers adder

mode. Thus, the data width of the output port should be less than or

■ While using the accumulator, the data width of the output port should be equal to or greater than (width\_a + width\_b). The maximum width of the accumulator can be (width\_a + width\_b + 16). Accumulators wider than this are implemented in logic.

equal to (width a + width b + 2).

If the design uses more multipliers than are available in a particular device, you may get a no fit error in the Quartus II software. In such cases, use the attribute settings in the LeonardoSpectrum software to control the mapping of multipliers in your design to DSP blocks or logic.

#### Block-Based Design with the Quartus II Software

The incremental compilation and LogicLock™ block-based design flows enable users to design, optimize, and lock down a design one section at a time. You can independently create and implement each logic module into a hierarchical or team-based design. With this method, you can preserve the performance of each module during system integration and have more control over placement of your design. To maximize the benefits of the incremental compilation or LogicLock design methodology in the Quartus II software, you can partition a new design into a hierarchy of netlist files during synthesis in the LeonardoSpectrum software.

The LeonardoSpectrum software allows you to create different netlist files for different sections of a design hierarchy. Different netlist files mean that each section is independent of the others. When synthesizing the entire project, only portions of a design that have been updated have to be re-synthesized when you compile the design. You can make changes, optimize, and re-synthesize your section of a design without affecting other sections.

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*. For more information about the LogicLock feature, refer to the *LogicLock Design Methodology* chapter in volume 2 of the *Quartus II Handbook*.

#### **Hierarchy & Design Considerations**

You must plan your design's structure and partitioning carefully to use incremental compilation and LogicLock features effectively. Optimal hierarchical design practices include partitioning the blocks at functional boundaries, registering the boundaries of each block, minimizing the I/O between each block, separating timing-critical blocks, and keeping the critical path within one hierarchical block.

For more recommendations for hierarchical design partitioning, refer to the *Design Recommendations for Altera Devices* chapter in volume 1 of the *Quartus II Handbook*.

To ensure the proper functioning of the synthesis tool, you can apply the LogicLock option in the LeonardoSpectrum software only to modules, entities, or netlist files. In addition, each module or entity should have its own design file. If two different modules are in the same design file but are defined as being part of different regions, it is difficult to maintain incremental synthesis since both regions would have to be recompiled when you change one of the modules or entities.

If you use boundary tri-states in a lower-level block, the LeonardoSpectrum software pushes (or "bubbles") the tri-states through the hierarchy to the top-level to take advantage of the tri-state drivers on the output pins of the Altera device. Because bubbling tri-states requires optimizing through hierarchies, lower-level tri-states are not supported with a block-level design methodology. You should use tri-state drivers only at the external output pins of the device and in the top-level block in the hierarchy.

If the hierarchy is flattened during synthesis, logic is optimized across boundaries, preventing you from making LogicLock assignments to the flattened blocks. Altera recommends preserving the hierarchy when compiling the design. In the **Optimize** command of your script, use the **Hierarchy Preserve** command or in the user interface select **Preserve** in the **Hierarchy** section on the **Optimize** Flow tab.

If you are compiling your design with a script, you can use an alternative method for preventing optimization across boundaries. In this case, use the **Auto** hierarchy setting and set the auto\_dissolve attribute to false on the instances or views that you want to preserve (that is, the modules with LogicLock assignments) using the following syntax:

```
set_attribute -name auto_dissolve -value false
   .work.<br/>
.INTERFACE
```

This alternative method flattens your design according to the auto\_dissolve limits, but does not optimize across boundaries where you apply the attribute as described.



For more details on LeonardoSpectrum attributes and hierarchy levels, refer to the LeonardoSpectrum documentation in the Help menu.

#### Creating a Design with Multiple EDIF Files

The first stage of a hierarchical design flow is to generate multiple EDIF files, enabling you to take advantage of the incremental compilation flows in the Quartus II software. If the whole design is in one EDIF file, changes in one block affect other blocks because of possible node name changes. You can generate multiple EDIF files either by using the LogicLock option in the LeonardoSpectrum software, or by manually black boxing each block that you want to be part of a LogicLock region.

Once you have created multiple EDIF files using one of these methods, you must create the appropriate Quartus II project(s) to place-and-route the design.

#### Generating Multiple EDIF Files Using the LogicLock Option

This section describes how to generate multiple EDIF files using the LogicLock option in the LeonardoSpectrum software. When synthesizing a top-level design that includes LogicLock regions, use the following general steps:

- 1. Read in the Verilog HDL or VHDL source files.
- 2. Add LogicLock constraints.
- 3. Optimize and write output netlist files, or choose **Run** Flow.

To set the correct constraints and compile the design, use the following steps in the LeonardoSpectrum software:

- Switch to the Advanced Flow tab instead of the Quick Setup tab (Tools menu).
- Set the target technology and speed grade for the device on the Technology Flow tab.
- 3. Open the input source files on the **Input** Flow tab.
- 4. Click **Read** on the **Input** Flow tab to read the source files but not begin optimization.
- Select the Module Power tab located at the bottom of the Constraints Flow tab.
- Click on a module to be placed in a LogicLock region in the Modules section.
- 7. Turn on the **LogicLock** option.
- 8. Type the desired LogicLock region name in the text field under the **LogicLock** option.
- 9. Click Apply.
- Repeat steps 6-9 for any other modules that you want to place in LogicLock regions.



In some cases, you are prompted to save your LogicLock and other non-global constraints in a Constraints File (.ctr) when you click anywhere off the **Constraints** Flow tab. The default name is ctr. This file is added to your Input file list, and must be manually included later if you recreate the project.

The command written into the LeonardoSpectrum Information or Transcript Window is the Tcl command that gets written into the CTR file. The format of the "path" for the module specified in the command should be work.<module>.INTERFACE. To ensure that you don't see an optimized version of the module, do not perform a Run Flow on the Quick Setup tab prior to setting LogicLock constraints. Always use the Read command, as described in step 4.

11. Continue making any other settings as required on the **Constraints** tab.

- Select Preserve in the Hierarchy section on the Optimize tab to ensure that the hierarchy names are not flattened during optimization.
- 13. Continue making any other settings as required on the **Optimize** tab.
- 14. Run your synthesis flow using each Flow tab, or click **Run Flow**.

Synthesis creates an EDIF file for each module that has a LogicLock assignment in the **Constraints** Flow tab. You can now use these files with the incremental compilation flows in the Quartus II software.



You might occasionally see multiple EDIF files and LogicLock commands for the same module. An "unfolded" version of a module is created when you instantiate a module more than once and the boundary conditions of the instances are different. For example, if you apply a constant to one instance of the block, it might be optimized to eliminate unneeded logic. In this case, the LeonardoSpectrum software must create a separate module for each instantiation (unfolding). If this unfolding occurs, you see more than one EDIF file, and each EDIF file has a LogicLock assignment to the same LogicLock region. When you import the EDIF files to the Quartus II software, the EDIF files created from the module are placed in different LogicLock regions. Any optimizations performed in the Quartus II software using the LogicLock methodology must be performed separately for each EDIF netlist.

Creating a Quartus II Project for Multiple EDIF Files Including LogicLock Regions

The LeonardoSpectrum software creates Tcl files that provide the Quartus II software with the appropriate LogicLock assignments, creating a region for each EDIF file along with the information to set up a Quartus II project.

The Tcl file contains the commands shown in Example 10–5 for each LogicLock region. This example is for module taps where the name taps\_region was typed as the LogicLock region name in the Constraints Flow tab in the LeonardoSpectrum software.

#### Example 10-5. Tcl File for Module Taps with taps\_region as LogicLock Region Name

These commands create a LogicLock region with Auto-Size and Floating-Origin properties. This flexible LogicLock region allows the Quartus II Compiler to select the size and location of the region.



For more information about Tcl commands, refer to the *TCL Scripting* chapter in volume 2 of the *Quartus II Handbook*.

You can use the following methods to import the EDIF file and corresponding Tcl file into the Quartus II software:

Use the Tcl file that is created for each EDIF file by the LeonardoSpectrum software. This method allows you to generate multiple Quartus II projects, one for each block in the design. Each designer in the project can optimize their block separately in the Quartus II software and preserve their results. Altera recommends this method for bottom-up incremental and hierarchical design methodologies because it allows each block in the design to be treated separately. Each block can be brought into one top-level project with the import function.

or

Use the <top-level project>.tcl file that contains the assignments for all blocks in the project. This method allows the top-level designer to import all the blocks into one Quartus II project. You can optimize all modules in the project at once in a top-down design flow. If additional optimization is required for individual blocks, each designer can use their EDIF file to create a separate project at that time. You would then have to add new assignments to the top-level project using the import function.

In both methods, you can use the following steps to create the Quartus II project, import the appropriate LogicLock assignments, and compile the design:

- 1. Place the EDIF and Tcl files in the same directory.
- On the View menu, point to Utility Windows and click Tcl Console to open the Quartus II Tcl Console.

- 3. Type source <path>/<project name>.tcl ←.
- To open the new completed project, on the File menu, click Open Project. Browse to and select the project name, and click Open.



For more information about importing design using incremental compilation, refer to the *Quartus II Incremental Compilation for Hierarchical & Team-Based Design* chapter in volume 1 of the *Quartus II Handbook*. For more information about importing LogicLock assignments, see the *LogicLock Design Methodology* chapter in volume 2 of the *Quartus II Handbook*.

#### **Generating Multiple EDIF Files Using Black Boxes**

This section describes how to manually generate multiple EDIF files using the black-boxing technique. The manual flow, described below, was supported in older versions of the LeonardoSpectrum software. The manual flow is discussed here because some designers want more control over the project for each submodule.

To create multiple EDIF files in the LeonardoSpectrum software, create a separate project for each module and top-level design that you want to maintain as a separate EDIF file. Implement black-box instantiations of lower-level modules in your top-level project.

When synthesizing the projects for the lower-level modules and the top-level design, use the following general guidelines.

For lower-level modules:

- Turn off Map IO Registers for the target technology on the Technology Flow tab.
- Read the HDL files for the modules. Modules may include black-box instantiations of lower-level modules that are also maintained as separate EDIF files.
- Add constraints.
- Turn off **Add I/O Pads** on the **Optimize** Flow tab.

For the top-level design:

- Turn on Map IO Registers if you want to implement input and/or output registers in the IOEs for the target technology on the Technology Flow tab.
- Read the HDL files for the top-level design.
  - Black-box lower-level modules in the top-level design
- Add constraints (clock settings should be made at this time).

The following sections describe examples of black-box modules in a block-based and team-based design flow.

In Figure 10–3, the top-level design A is assigned to one engineer (designer 1), while two-engineers work on the lower levels of the design. Designer 2 works on B and its submodules D and E, while designer 3 works on C and its submodule F.



Figure 10-3. Block-Based & Team-Based Design Example

One netlist is created for the top-level module A, another netlist is created for B and its submodules D and E, while another netlist is created for C and its submodule F. To create multiple EDIF files, perform the following steps:

- Generate an EDIF file for module C. Use C.v and F.v as the source files.
- 2. Generate an EDIF file for module B. Use **B.v**, **D.v**, and **E.v** as the source files.
- Generate a top-level EDIF file A.v for module A. Ensure that your black-box modules B and C were optimized separately in steps 1 and 2.

#### Black Boxing in Verilog HDL

Any design block that is not defined in the project, or included in the list of files to be read for a project, is treated as a black box by the software. In Verilog HDL, you must also provide an empty module declaration for the module that you plan to treat as a black box.

Example 10–6 shows an example of the **A.v** top-level file. If any of your lower-level files also contain a black-boxed lower-level file in the next level of hierarchy, follow the same procedure.

#### Example 10-6. Verilog HDL Top-Level File Black-Boxing Example

```
module A (data in,clk,e,ld,data out);
    input data in, clk, e, ld;
   output [15:0] data out;
   reg [15:0] cnt_out;
   reg [15:0] reg a out;
   B U1 ( .data_in (data_in),.clk (clk), .e(e), .ld (ld),
            .data out(cnt out) );
   C U2 ( .d(cnt_out), .clk (clk), .e(e), .q (reg_out));
    // Any other code in A.v goes here.
endmodule
// Empty Module Declarations of Sub-Blocks B and C follow here.
// These module declarations (including ports) are required for blackboxing.
module B (data in,e,ld,data out );
   input data_in, clk, e, ld;
   output [15:0] data out;
endmodule
module C (d,clk,e,q);
   input d, clk, e;
   output [15:0] q;
endmodule
```



Previous versions of the LeonardoSpectrum software required an attribute statement //exemplar attribute U1 NOOPT TRUE, which instructs the software to treat the instance U1 as a black box. This attribute is no longer required, although it is still supported in the software.

#### Black Boxing in VHDL

Any design block that is not defined in the project, or included in the list of files to be read for a project, is treated as a black box by the software. In VHDL, you need a component declaration for the black box which is normal for any other block in the design.

Example 10–7 shows an example of the **A.vhd** top-level file. If any of your lower-level files also contain a black-boxed lower-level file in the next level of hierarchy, follow the same procedure.

#### Example 10-7. VHDL Top-Level File Black-Boxing Example

```
LIBRARY ieee;
USE ieee.std logic 1164.all;
ENTITY A IS
PORT ( data in : IN INTEGER RANGE 0 TO 15;
   clk : IN STD LOGIC;
   e : IN STD LOGIC;
   ld : IN STD LOGIC;
   data_out : OUT INTEGER RANGE 0 TO 15
);
END A;
ARCHITECTURE a_arch OF A IS
COMPONENT B PORT (
   data in : IN INTEGER RANGE 0 TO 15;
   clk : IN STD LOGIC;
   e : IN STD LOGIC;
   ld : IN STD_LOGIC;
   data out : OUT INTEGER RANGE 0 TO 15
);
END COMPONENT;
COMPONENT C PORT (
   d : IN INTEGER RANGE 0 TO 15;
   clk : IN STD LOGIC;
   e : IN STD LOGIC;
   q : OUT INTEGER RANGE 0 TO 15
);
END COMPONENT;
-- Other component declarations in A.vhd go here
signal cnt out : INTEGER RANGE 0 TO 15;
signal reg a out : INTEGER RANGE 0 TO 15;
BEGIN
CNT : C
PORT MAP (
   data_in => data_in,
   clk => clk,
   e => e,
   ld => ld,
   data out => cnt out
);
REG A : D
PORT MAP (
   d => cnt out,
   clk => clk,
   e => e,
   q => reg_a_out
);
-- Any other code in A.vhd goes here
END a arch;
```



Previous versions of the LeonardoSpectrum software required the attribute statement noopt of C: component is TRUE, which instructed the software to treat the component C as a black box. This attribute is no longer required, although it is still supported in the software.

After you have completed the steps outlined in this section, you have a different EDIF netlist file for each block of code. You can now use these files for incremental compilation flows in the Quartus II software.

#### Creating a Quartus II Project for Multiple EDIF Files

The LeonardoSpectrum software creates a Tcl file for each EDIF file, which provides the Quartus II software with the information to set up a project.

As in the previous section, there are two different methods for bringing each EDIF and corresponding Tcl file into the Quartus II software:

Use the Tcl file that is created for each EDIF file by the LeonardoSpectrum software. This method generates multiple Quartus II projects, one for each block in the design. Each designer in the project can optimize their block separately in the Quartus II software and preserve their results. Designers should create a LogicLock region for each block; the top-level designer should then import all the blocks and assignments into the top-level project. Altera recommends this method for bottom-up incremental and hierarchical design methodology because it allows each block in the design to be treated separately; each block can be imported into one top-level project.

or

Use the <top-level project>.tcl file that contains the information to set up the top-level project. This method allows the top-level designer to create LogicLock regions for each block and bring all the blocks into one Quartus II project. Designers can optimize all modules in the project at once in a top-down design flow. If additional optimization is required for individual blocks, each designer can take their EDIF file and create a separate Quartus II project at that time. New assignments would then have to be added to the top-level project manually or through the import function.



For more information about importing designs using incremental compilation, refer to the *Quartus II Incremental Compilation for Hierarchical & Team-Based Design* chapter in volume 1 of the *Quartus II Handbook*. For more information about importing LogicLock regions, refer to the *LogicLock Design Methodology* chapter in the volume 2 of the *Quartus II Handbook*.

In both methods, you can use the following steps to create the Quartus II project and compile the design:

- 1. Place the EDIF and Tcl files in the same directory.
- On the View menu, point to Utility Windows and click Tcl Console.
   The Ouartus II Tcl Console is shown.
- 3. At a Tcl prompt, type source <path>/<project name>.tcl ←.
- 4. On the File menu, click **Open Project**. In the **New Project** window, browse to and select the project name. Click **Open**.
- To create LogicLock assignments, on the Assignments menu, click LogicLock Regions Window.
- 6. On the Processing menu, click **Start Compilation**.

#### **Incremental Synthesis Flow**

If you make changes to one or more submodules, you can manually create new projects in the LeonardoSpectrum software to generate a new EDIF netlist file when there are changes to the source files. Alternatively, you can use incremental synthesis to generate a new netlist for the changed submodule(s). To perform incremental synthesis in the LeonardoSpectrum software, use the script described in this section to reoptimize and generate a new EDIF netlist for only the affected modules using the LeonardoSpectrum top-level project. This method applies only when you are using the LogicLock option in the LeonardoSpectrum software.

Modifications Required for the LogicLock\_Incremental.tcl Script File

There are three sets of entries in the file that must be modified before beginning incremental synthesis. The variables in the Tcl file are surrounded by angle brackets (< >).

1. Add the list of source files that are included in the project. You can enter the full path to the file or just the file name if the files are located in the working directory.

 Indicate which modules in the design have changed. These modules are the EDIF files that are regenerated by the LeonardoSpectrum software. These modules contain a LogicLock assignment in the original compilation.



Obtain the LeonardoSpectrum software path for each module by looking at the CTR file that contains the LogicLock assignments from the original project. Each LogicLock assignment is applied to a particular module in the design.

 Enter the target device family using the appropriate device keyword. The device keyword is written into the **Transcript** or **Information** window when you select a target Technology and click **Load Library** or **Apply** on the **Technology Flow** tab in the graphical user interface.

Example 10–8 shows the **LogicLock\_Incremental.tcl** file for the incremental synthesis flow. You must modify the Tcl file before you can use it for your project.

#### Example 10-8. LogicLock\_Interface.tcl Script File for Incremental Synthesis

```
#### LogicLock Incremental Synthesis Flow ####
## You must indicate which modules have changed (based on the source files
## that have changed) and provide the complete path to each module
## You must also specify the list of design files and the target Altera
## technology being used
# Read the design source files.
read < list of design files separated by spaces (such as block1.v block2.v)>
# Get the list of modified modules in bottom-up "depth first search" order
# where the lower-level blocks are listed first (these should be modules
# that had LogicLock assignments and separate EDIF netlist files in the
# first pass and had their source code modified)
set list of modified modules {.work.<block2>.INTERFACE .work.<block1>.INTERFACE}
foreach module $list of modified modules {
   set err rc [regexp \{ \langle . (.*) \rangle . (.*) \} $module unused lib module name arch]
   present design $module
   # Run optimization, preserving hierarchy. You must specify a technology.
   optimize -ta <technology> -hierarchy preserve
   # Ensure that the lower-level module is not optimized again when
   # optimizing higher-level modules.
   dont touch $module
foreach module $list of modified modules {
   set err rc [regexp \{ (.*, ...) ... (.*) \} $module unused lib module name arch]
   present design $module
   undont_touch $module
   auto write $module name.edf
   # Ensure that the lower-level module is not written out in the EDIF file
   # of the higher-level module.
   noopt $module
```

# Running the Tcl Script File in LeonardoSpectrum

Once you have modified the Tcl script, as described in the "Modifications Required for the LogicLock\_Incremental.tcl Script File" on page 10–31, you can compile your design using the script.

You can run the script in batch mode at the command line prompt using the following command:

spectrum -file <Tcl\_file> ←

To run the script from the interface, on the File menu, click **Run Script**, then browse to your Tcl file and click **Open**.

The LogicLock incremental design flow uses module-based design to help you preserve performance of modules and have control over placement. By tagging the modules that require separate EDIF files, you can make multiple EDIF files for use with the Quartus II software from a single LeonardoSpectrum software project.

# Conclusion

Advanced synthesis is an important part of the design flow. Taking advantage of the Mentor Graphics LeonardoSpectrum software and the Quartus II design flow allows you to control how your design files are prepared for the Quartus II place-and-route process, as well as to improve performance and optimize a design for use with Altera devices. The methodologies outlined in this chapter can help optimize a design to achieve performance goals and save design time.



# 11. Synopsys Design Compiler FPGA Support

QII51014-6.0.0

## Introduction

Programmable logic device (PLD) designs have reached the complexity and performance requirements of ASIC designs. As a result, advanced synthesis has taken on a more important role in the design process. This chapter documents the usage and design flow of the Synopsys Design Compiler FPGA (DC FPGA) synthesis software with Altera® devices and Quartus® II software. DC FPGA supports Stratix® II, Stratix, Stratix GX, Cyclone $^{\text{TM}}$  II, and Cyclone devices.

This chapter assumes that you have set up and licensed the DC FPGA software and Altera Quartus II software.

This chapter is primarily intended for ASIC designers experienced with the Design Compiler (DC) software who are now developing PLD designs, and experienced PLD designers who would like an introduction to the Synopsys DC FPGA software.



To obtain the DC FPGA software, libraries, and instructions on general product usage, go to the Synopsys web site at <a href="http://solvnet.synopsys.com/retrieve/012889.html">http://solvnet.synopsys.com/retrieve/012889.html</a>

The following areas are covered in this chapter:

- General design flow with the DC FPGA software and the Quartus II software
- Initialization procedure using the .synopsys\_dc.setup file for targeting Altera devices
- Using Altera megafunctions with the DC FPGA software
- Reading design files into the DC FPGA software
- Applying synthesis and timing constraints
- Reporting and saving design information
- Exporting designs to the Quartus II software

Design Flow
Using the
DC FPGA
Software & the
Quartus II
Software

A high-level overview of the recommended design flow for using the DC FPGA software with the Quartus II software is shown in Figure 11–1.

Figure 11–1. Design Flow Using the DC FPGA Software & the Quartus II Software



# Setup of the DC FPGA Software Environment for Altera Device Families

Altera recommends that you organize your project directory with several subdirectories. A recommended project hierarchy is shown in Figure 11–2.

Figure 11-2. Project Hierarchy



To use the DC FPGA software to synthesize HDL designs for use with the Quartus II software, the required settings should be included in your .synopsys\_dc.setup initialization file. This file is used to define global variables and direct the DC FPGA software to the proper libraries used for synthesis, as well as set internal assignments for synthesizing designs for Altera devices.

The .synopsys\_dc.setup file can reside in any one of three locations and be read by the DC FPGA software. The DC FPGA software automatically reads the .synopsys\_dc.setup file at startup in the following order of precedence:

- 1. Current directory where you run the DC FPGA software shell.
- 2. Home directory.
- 3. The DC FPGA software installation directory.

The DC FPGA software has vendor-specific setup files for each of the Altera logic families in the installation directory. These vendor-specific setup files are found where you have installed the libraries (<dcfpga\_rootdir>/libraries/fpga/altera) and are named in the form synopsys\_dc\_<logic family>.setup. For example, if you want to use the default setup for synthesizing an Altera Stratix device, you must link to or copy the synopsys\_dc\_stratix.setup to your home or current directory and rename the file .synopsys\_dc.setup.

Synopsys recommends using the vendor-specific setup files provided with each release of the DC FPGA software to ensure that you have all the correct settings and obtain the best quality results.

Example 11–1 contains the recommended synthesis settings for the Stratix II device architecture.

#### Example 11–1. Recommended Synthesis Settings for Stratix II Device Architecture

```
# Setup file for Altera Stratixii
# TCL style setup file but will work for original DC shell as well
# Need to define the root location of the libraries by chaning the variable
$dcfpga_lib_path

set dcfpga_lib_path "<dcfpga_rootdir>/libraries/fpga/altera"

set search_path ". $dcfpga_lib_path $dcfpga_lib_path/STRATIXII $search_path"

set target_library "stratixii.db"

set synthetic_library "tmg.sldb altera_mf.sldb lpm.sldb"

set link_library "* stratixii.db tmg.sldb altera_mf.sldb lpm.sldb stratixii_mf.sldb"

set fpga defaults altera stratixii
```

After generating your .synopsys\_dc.setup file, run the DC FPGA software in either the Tcl shell or in the Design Compiler software shell without Tcl support. Run the DC FPGA software shell at a command prompt by typing fpga\_shell-t or fpga\_shell -tcl for the Tcl shell version of the DC FPGA software. Run the non-Tcl version of the DC FPGA software with the fpga\_shell command. Altera recommends using the Tcl shell for all of your synthesis work.

If you have created a Tcl synthesis script for use in the DC FPGA software and wish to run it immediately at startup, you can start the DC FPGA software shell and run the script with the command shown in the example below:

```
fpga shell-t -f <path>/<script filename>.tcl ←
```

Otherwise, you can run your scripts at any time at the fpga\_shell-t> prompt with the source command. An example is shown below:

```
source <path>/<script filename>.tcl ←
```

# Megafunctions & Architecture-Specific Features

Altera provides parameterized megafunctions including library of parameterized modules (LPMs), device-specific Altera megafunctions, intellectual property (IP) available as Altera MegaCore® functions, and IP available through the Altera Megafunction Partners Program (AMPP). You can use megafunctions by instantiating them in your HDL code, or by inferring them from your HDL code during synthesis in the DC FPGA software.



For more details on specific Altera megafunctions, refer to the Quartus II Help.

The DC FPGA software automatically recognizes certain types of HDL code and infers the appropriate megafunction when a megafunction provides optimal results. The DC FPGA software also provides options to control inference of certain types of megafunctions, as described in the section "Instantiating Altera Megafunctions Using the MegaWizard Plug-In Manager" on page 11–6.



For a detailed discussion about instantiating versus inferring megafunctions, refer to the *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook*. This chapter also provides details about using the MegaWizard® Plug-In Manager in the Quartus II software and explains the files generated by the wizard. In addition, the chapter provides coding style recommendations and examples for inferring megafunctions in Altera devices.

If you instantiate a megafunction in your HDL code, you can use the MegaWizard Plug-In Manager to parameterize the function, or you can instantiate the function using the port and parameter definition. The MegaWizard Plug-In Manager provides a graphical interface in the Quartus II software for customizing and parameterizing megafunctions. "Instantiating Altera Megafunctions Using the MegaWizard Plug-In Manager" on page 11–6 describes the MegaWizard Plug-In Manager flow with the DC FPGA synthesis software.

# Instantiating Altera Megafunctions Using the MegaWizard Plug-In Manager

When you use the MegaWizard Plug-In Manager to set up and parameterize a megafunction, the MegaWizard Plug-In Manager creates a VHDL or Verilog HDL wrapper file that instantiates the megafunction (a black box methodology). The MegaWizard can also generate a fully elaborated netlist that is read by EDA synthesis tools, such as the DC FPGA (a clear box methodology). Both clear box and black box methodologies are described in the following sections.

# **Clear Box Methodology**

You can use the MegaWizard Plug-In Manager to generate a fully synthesizeable netlist. This flow is referred to as a clear box methodology because starting in V-2005.06, the DC FPGA software can look into the megafunction file. The clear box feature enables the synthesis tool to report more accurate timing estimates and resource utilization, while taking a better advantage of timing driven optimization than a black box methodology.

This clear box feature is enabled by turning on the Generate clear box netlist file instead of a default wrapper file (for use with supported EDA synthesis tools only) option in the MegaWizard Plug-In Manager for certain megafunctions. DC FPGA supports clear box megafunctions for altmult\_add, almult\_accum, altsyncram and altshift\_taps. If the option does not appear, then clear box models are not supported for the selected megafunction.



The library declarations in the MegaWizard generated VHDL output files need to be manually commented out to work properly with the DC FPGA.

Reading Megafunction Wizard-Generated Synthesizable Clear Box Netlist Files for Megafunction Instantiation

The DC FPGA software analyzes and elaborates the Megafunction Wizard-generated Verilog HDL <code><output file>.vo</code> or VHDL <code><output file>.vhd</code> netlist that contains the parameters needed by the Quartus II software to properly configure and instantiate your megafunction. Analyze the clear box netlist files along with the rest of the RTL files during synthesis in DC FPGA. The resulting netlist contains all the primitives that are part of the clear box netlist. There is no need to put the clear box netlist file in your Quartus II project along with your DC FPGA generated netlist file.

Using the clear box Megafunction Wizard-generated netlist files provides the DC FPGA software an understanding of their timing arcs and resource usage. The DC FPGA software uses timing information to optimize the surrounding circuits and resource data to better manage the overall resource usage for the whole design. The DC FPGA software takes the clear box netlist timing and area data into account when reporting the timing and resource utilization for the device.

Advanced Clear Box Support for the Direct-Instantiated or Inferred Clear Box Megafunctions

The DC FPGA provides advanced clear box support that enables a clear box implementation for the direct-instantiated or inferred megafunctions in your design. This methodology allows the DC FPGA to obtain the most accurate interface timing and area data for the megafunctions. Therefore, synthesis optimization is more effective, and timing and area reports are more accurate.

The following describes the setup and usage model for this advanced clear box support.

#### Design Compiler FPGA Setup

The advanced clear box flow will be enabled in the DC FPGA only when the **clearbox.sldb** synthetic library is added to the synthetic\_library variable. For example:

```
set synthetic_library [concat clearbox.sldb $synthetic_library]
set link library [concat clearbox.sldb $link library]
```

Specify the path to the clear box loader (executable) in one of the following ways:

- Set the synlib\_cbx\_exec\_path variable to the absolute path of the clear box loader before the compile command:
   set synlib\_cbx\_exec\_path < Quartus II installation directory /bin/clearbox>
- Set the UNIX environment variable CLEARBOX\_EXEC\_PATH to the absolute path of the clear box loader. For example:

  setenv CLEARBOX\_EXEC\_PATH < Quartus II installation directory /bin/clearbox>

By default, the advance clear box flow is turned off. To enable the clear box advanced flow, add the following to your DC FPGA script. Set it before the compile command:

```
set fpga_altera_clearbox_for_user_cells true
```

#### **UNIX Environment Setting**

For the DC FPGA to work with the clear box loader, the following setting is necessary for the LD\_LIBRARY\_PATH environment variable. Assume the QuartusII\_Path used below is set to the Quartus II installation directory.

#### On a Linux platform:

```
setenv LD LIBRARY PATH QuartusII Path/linux: $LD LIBRARY PATH
```

#### On a Solaris platform:

```
setenv LD LIBRARY PATH QuartusII Path/solaris:$LD LIBRARY PATH
```

#### **Error Message**

The only error message that you might encounter when trying to enable the advanced clear box flow is: DCFPGA\_UEGI-1

The DC FPGA reports this error when one of the following situations occurs:

- It cannot find the clear box loader path. For example, the defined path is incorrect.
- The Loader is not found in the specified path.
- The Loader specified is not executable.

#### Sample Design Compiler FPGA Clear Box Setup Script

The TCL script shown in Example 11–2 is a DC FPGA clear box setup script. Use it before compiling the design in DC FPGA.

### Example 11-2. Sample Clear Box Setup Script

```
set QuartusII_Path /tools/altera/qii51
set_unix_variable CLEARBOX_EXEC_PATH $QuartusII_Path/bin/clearbox
set old_llp [get_unix_variable LD_LIBRARY_PATH]
set platform [sh uname]

if { $platform == "Linux" } {
    set_unix_variable LD_LIBRARY_PATH $QuartusII_Path/linux: old_llp
} else {
    # Assume, if not linux, it is solaris
    set_unix_variable LD_LIBRARY_PATH $QuartusII_Path/solaris: old_llp

set synthetic_library [concat clearbox.sldb $synthetic_library]
set link_library [concat clearbox.sldb $link_library]
set fpga_altera_clearbox_for_user_cells true
```

## **Black Box Methodology**

Using the MegaWizard Plug-In Manager-generated wrapper file is referred to as a black box methodology because the megafunction is treated as a black box in the DCFPGA software. The black box wrapper file is generated by default in the MegaWizard Plug-In Manager and is available for all megafunctions. The black box methodology does not allow the synthesis tool any visibility into the function module and therefore, does not take full advantage of the synthesis tool's timing driven optimization.

There are two ways of instantiating Megafunction Wizard-generated functions in your design hierarchy loaded in the DC FPGA software. You can instantiate and compile the Verilog HDL or VHDL variation wrapper file description of your megafunction in the DC FPGA software, or you can instantiate a black box that just describes the ports of your megafunction variation wrapper file.



The library declarations in the MegaWizard generated VHDL output files need to be manually commented out to work properly with the DC FPGA.

## Reading Megafunction Wizard-generated Variation Wrapper Files

The DC FPGA software has the ability to analyze and elaborate the Megafunction Wizard-generated Verilog HDL <output file>.v or VHDL <output file>.vhd netlist that contains the parameters needed by the Quartus II software to properly configure and instantiate your megafunction. The DC FPGA software may take advantage of this variation wrapper file during the optimization of your design to reduce area utilization and improve path delays. DC FPGA also supports altpll in a non-black box flow (that is, the DC FPGA can automatically derive PLL output clocks when the user has specified only the PLL input clock).

Using the megafunction variation wrapper file *<output file>.v* or *<output file>.vhd* in the DC FPGA software synthesis provides good synthesis results for area estimates, but actual timing results are best predicted after place-and-route inside the Quartus II software. However, reading the megafunction variation wrapper allows the DC FPGA software to provide better synthesis estimates over a black box methodology.

Using Megafunction Wizard-Generated Variation Wrapper Files in a Black Box Methodology

Instantiating the megafunction wizard-generated wrapper file without reading it in the DC FPGA software is referred to as a black box methodology because the megafunction is treated as an unknown container in the DC FPGA software.

The black box methodology does not allow synthesis software to have any visibility into the module, thereby not taking full advantage of the timing driven optimization of the DC FPGA software and preventing the software from estimating logic resources for the black box design.

# Using Megafunction Wizard-Generated Verilog HDL Files for Black Box Megafunction Instantiation

By default, the MegaWizard Plug-In Manager generates the Verilog HDL instantiation template file <code><output file>\_inst.v</code> and the black box module declaration <code><output\_file>\_bb.v</code> for use in your design in the DC FPGA software. The instantiation template file helps to instantiate the megafunction variation wrapper file, <code><output file>.v</code>, in your top-level design. Do not include the megafunction variation wrapper file in the DC FPGA software project if you are following the black box methodology. Instead, add the wrapper file and your generated Verilog Quartus Mapping (.vqm) netlist in your Quartus II project. Add the hollow body black box module declaration <code><output file>\_bb.v</code> to your linked design files in the DC FPGA software to describe the port connections of the black box.

# Using Megafunction Wizard-Generated VHDL Files for Black Box Megafunction Instantiation

By default, the MegaWizard Plug-In Manager generates a VHDL component declaration file <code><output file>.cmp</code> and a VHDL instantiation template file <code><output file>\_inst.vhd</code> for use in your design. These files can help you instantiate the megafunction variation wrapper file, <code><output file>.vhd</code>, in your top-level design. Do not include the megafunction variation wrapper file in the DC FPGA software project. Instead, add the wrapper file and your generated Verilog Quartus Mapping netlist in your Quartus II project.



The DC FPGA software supports direct instantiation of all LPMs and megafunctions. For a complete list of all LPMs and Megafunctions, refer to the following two files in your Quartus II installation directory:

- <Quartus II installation directory> /libraries/vhdl/lpm/lpm\_pack.vhd
- <Quartus II installation directory>
  /libraries/vhdl/altera\_mf/altera\_mf\_components.vhd

DC FPGA supports direct instantiation of LPMs and megafunctions only. These macro functions include all Altera IP cores and all components listed in:

<Quartus II installation directory>/libraries/vhdl/
altera\_mf\_components.vhd or stratixgx\_mf\_components.vhd.

The following example is the usage model using the **mypll** for direct instantiation:

- During synthesis in DC FPGA, analyze the variation file mypll.[v | vhd] along with the rest of the RTL files.
- During place-and-route in the Quartus II software, simply run the self-contained Verilog Quartus Mapping File. You do not need to put the variation file in the Verilog Quartus Mapping directory.

The benefit of using the direct instantiation method is that the DC FPGA is able to utilize the available clock enable pins of the LPMs and megafunctions during the automatic gated-clock conversion process.

# Inferring Altera Megafunctions from HDL Code

The DC FPGA software automatically recognizes certain types of HDL code, and maps digital signal processing (DSP) functions and memory (RAM and ROM) to efficient, technology-specific implementations. This allows the use of technology-specific resources to implement these structures by inferring the appropriate Altera megafunction when it provides optimal results.



For coding style recommendations and examples for inferring megafunctions in Altera devices, refer to the *Recommended HDL Coding Styles* chapter in volume 1 of the *Quartus II Handbook*.

Depending on the coding style, if you do not adhere to these recommended HDL coding style guidelines, it is possible that the DC FPGA software and Quartus II software will not take advantage of the high performance DSP blocks and RAMs, and may instead

implement your logic using regular logic elements (LEs). This causes your logic to consume more area in your device and may adversely affect your design performance. Altera device families do not all share the same resources, so your HDL coding style may cause your logic to be implemented differently in each family. For example, Stratix devices contain dedicated DSP blocks which Cyclone devices lack. In a Cyclone device, multipliers are implemented in LEs.

Example 11–3 shows Verilog HDL code that infers a two-port RAM that can be synthesized into an M512 RAM block of a Stratix device.

#### Example 11–3. Verilog HDL Code Inferring a Two-Port RAM

One of the strengths of the DC FPGA software is its gated clock conversion feature. Inferring megafunctions in HDL takes advantage of this feature. For gated clocks or clock enables designed outside of LPMs, Altera-specific megafunctions, and registers, the DC FPGA software merges the gated clock functions into these design elements using dedicated clock enable functionality during synthesis. The DC FPGA software reconfigures the megafunction block or register to synthesize the clock enable control logic. This can save area in your design and improve your design performance by reducing the gated clock path delay and the amount of logic used to implement the design. An illustration of this kind of gated clock optimization is shown in Figure 11–3.



Figure 11-3. Gated Clock Optimization

The DC FPGA software does not perform gated clock optimization on instantiated black box megafunctions or on instantiated megafunction variation wrapper file. The DC FPGA software performs gated clock optimization only on synthesizable inferred megafunctions.

# Reading Design Files into the DC FPGA Software

The process of reading design files into the DC FPGA software is a two-step process where the DC FPGA software analyzes your HDL design for syntax errors, then elaborates the specified design. The elaboration process finds analyzed designs and instantiates them in the elaborated design's hierarchy. You must identify which supported language the files are written in when reading designs into the DC FPGA software. The supported HDL languages are listed in Table 11–1.

| Table 11–1. Supported Design File Formats |                                       |         |           |  |  |
|-------------------------------------------|---------------------------------------|---------|-----------|--|--|
| Format                                    | Description                           | Keyword | Extension |  |  |
| Verilog HDL (Synopsys Presto HDL)         | Verilog hardware description language | verilog | .V        |  |  |
| VHDL                                      | VHSIC hardware description language   | vhdl    | .vhd      |  |  |
| .db                                       | Synopsys internal database format (1) | db      | .db       |  |  |
| EDIF                                      | Electronic design interchange format  | edif    | .edf      |  |  |

Note to Table 11–1:

(1) The Design Compiler DB format file requires additional license keys.

To set most of the required synthesis settings to generate an optimal netlist, use the following command:

```
set_fpga_defaults <architecture_name>
```

For example:

```
set fpga defaults altera stratixii
```

Use the following commands to analyze and elaborate HDL designs in the DC FPGA software:

```
analyze -f <verilog|vhdl> <design file> ← elaborate <design name> ←
```

Once a design is analyzed, it is stored in a Synopsys library format file in your working directory for reuse. You need to re-analyze the design only when you change the source HDL file. Elaboration is performed after you have analyzed all of the subdesigns below your current design.

Another way to read your design is by using the read\_file command. This can be used to read in gate-level netlists that are already mapped to a specific technology. The read\_file command performs analysis and elaboration on Verilog HDL and VHDL designs that are written in register transfer level (RTL) format. The difference between the read\_file command and the analyze and elaborate combination is that the read\_file command elaborates every design read, which is unnecessary. Only the top-level design must be elaborated. The read\_file command is useful if you have a previously synthesized block of logic that you want to re-use in your design.

To use the read\_file command for a specific language, type the following command:

```
read file -f <verilog | vhdl | db | edif> <design file> ←
```

You can also read files in specific languages using the read\_verilog, read\_vhdl, read\_db, and read\_edif commands.

Once you have read all of your design files, specify the design you want to focus your work on with the current\_design command. This is usually the top module or entity in your design that you wish to compile up to. To use this command, type the following:

```
current_design <design name> ←
```

You then need to build your design from all of the analyzed HDL files with the link command. To use this command, type the following:

link ←

After linking your designs successfully in the DC FPGA software, you should specify the constraints you are applying to your design. In the DC FPGA software, you have the capability of loading multiple levels of hierarchy and synthesizing specific blocks in a bottom-up synthesis methodology, or you can synthesize the entire design from the top-level module in a top-down synthesis methodology.

You can switch the current focus of the DC FPGA software between the designs loaded by using the current\_design command. This changes your current focus onto the design specified, and all subsequent constraints and commands will apply to that design.

If you have read Quartus II megafunction wizard-generated designs or third-party IP into the DC FPGA software, you can instruct the DC FPGA software not to synthesize the IP. Use the set\_dont\_touch constraint and apply it to each module of your design that you do not want synthesized. To use this command, type the following:

```
set_dont_touch < design name> ←
```

Using the set\_dont\_touch command can be helpful in a bottom-up synthesis methodology, where you optimize designs at the lower levels of your hierarchy first and do not allow the DC FPGA software to resynthesize them later during the top-level integration. However, depending on the design's HDL coding, you might want to allow top-level resynthesis to get further area reduction and improved path delays. For best results, Altera recommends following the top-down synthesis methodology and not using the set\_dont\_touch command on lower level designs.

# Selecting a Target Device

If you do not select an Altera device, the DC FPGA software, by default, synthesizes for the fastest speed grade of the logic family library that is loaded in your .synopsys\_dc.setup file. If you are targeting a specific device of an Altera family, you must have the correct library linked, then specify the device for synthesis with the set\_fpga\_target\_device command. To use this command, type the following:

```
set fpga target device <device name> ←
```

You can have the DC FPGA software produce a list of all available devices in the linked library by adding the -show\_all option to the set\_fpga\_target\_device command. An example of this list of devices for the Stratix II library is shown in Example 11–4.

Example 11–4. List of Available Devices in the Linked Library Using the -show\_all Option

Loading db file '/dc fpga/libraries/fpga/altera/STRATIXII/stratixii.db'

Valid device names are:

| Part         | Pins | FFs    | Speed Grades |
|--------------|------|--------|--------------|
| AUTO *       | 0    | 0      | FASTEST      |
| EP2S15F484   | 484  | 12480  | C4           |
| EP2S15F672   | 672  | 12480  | C4           |
| EP2S30F484   | 484  | 27104  | C4           |
| EP2S30F672   | 672  | 27104  | C4           |
| EP2S60F484   | 484  | 48352  | C4           |
| EP2S60F672   | 672  | 48352  | C4           |
| EP2S60F1020  | 1020 | 48352  | C4           |
| EP2S90F1020  | 1020 | 72768  | C4           |
| EP2S90F1508  | 1508 | 72768  | C4           |
| EP2S130F1020 | 1020 | 106032 | C4           |
| EP2S130F1508 | 1508 | 106032 | C4           |
| EP2S180F1020 | 1020 | 143520 | C4           |
| EP2S180F1508 | 1508 | 143520 | C4           |
|              |      |        |              |

<sup>\*</sup> Default part

For example, if you want to target the C4 speed grade device of the Stratix II EP2S60F672 device, apply the following constraint:

set\_fpga\_target\_device EP2S60F672C4

# Timing & Synthesis Constraints

You must create timing and synthesis constraints for your design for the DC FPGA software to optimize your design performance. The timing constraints specify your desired clocks and their characteristics, input and output delays, and timing exceptions such as false paths and multicycle paths. The synthesis constraints define the device, the type of I/O buffers that should be used for top-level ports, and the maximum register fan-out threshold before buffer insertion is performed. Synopsys Design Constraints (SDCs) are Tcl-format commands that are widely used in many EDA software applications. The DC FPGA software supports the same SDC commands that the full version of the Design Compiler software supports. However, certain constraints that are used in ASIC synthesis are not applicable to programmable logic synthesis, so the DC FPGA software ignores them.

The DC FPGA software supports the following constraints:

- create clock
- set max delay
- set propagated clock
- set input delay
- set output delay
- set multicycle path
- set false path
- set disable timing
- set fpga resource limit
- set register max fanout
- set max fanout
- set fpga target device



For the syntax and full usage of these commands, refer to the *Synopsys DC FPGA User Guide*.



For synthesis with the DC FPGA software, minimum timing analysis is not necessary, as it primarily looks at setup timing optimization to achieve the fastest clock frequency for your design. Altera recommends adding additional minimum timing constraints to your design inside the Quartus II software.

The DC FPGA forward annotates all the clock, timing exceptions, and I/O delay constraints to Quartus II when the write\_par\_constraint command is used in the DC FPGA. For more information about this command, refer to "Exporting Designs to the Quartus II Software" on page 11–22. Since the Quartus II software does not support the through option for the timing exception constraints, the DC FPGA does not forward annotate constraints that use the through option.

In the DC FPGA software, timing constraints applied to inferred RAM, ROM, shift registers, and DSP MAC functions are obeyed. However, these constraints are not forward-annotated to the Quartus II software because these functions are inferred to Altera megafunctions. The Quartus II software does not support timing constraints applied to megafunctions. The workaround is to run the Verilog Quartus Mapping/EDIF netlist through analysis and synthesis in the Quartus II software (quartus\_map). All megafunctions expand to atom primitives. These atom primitives can be processed by the Quartus II software. You can then apply constraints to the internal atoms of the megafunctions.

The timing reports generated from the DC FPGA software are preliminary estimates of the path delays in your design, and accurate timing is reported only after place-and-route is performed with the Quartus II software.

The DC FPGA software also performs cross-hierarchical boundary optimization. Altera recommends running this command before a compilation:

```
ungroup -small 500 ←
```

This allows the DC FPGA software to potentially improve area reduction and performance improvement by ungrouping smaller blocks of logic in your design hierarchy and combining functions.

# Compilation & Synthesis

After applying timing and synthesis constraints, you can begin the compilation and synthesis process. The compile command runs this process within the DC FPGA software. To run a compilation, at the shell prompt type:

```
compile ←
```

The compilation process performs two kinds of optimization:

- Architectural optimization focuses on the HDL description and performs high-level synthesis tasks such as sharing resources and sub-expressions, selecting Synopsys Design Ware implementations, and re-ordering operators.
- Gate-level optimization works on the generic netlist created by logic synthesis and works to improve the mapping efficiency to save area and improve performance by minimizing path delays.

Compilation can be done using a top-down synthesis methodology or a bottom-up synthesis methodology. The top-down synthesis methodology involves a single compilation of your entire design with the focus on the top module or entity of your design. The bottom-up synthesis methodology involves incremental compilation of major blocks in your design hierarchy and top-level integration and optimization. Either methodology can be applied when synthesizing for Altera devices. For best results, Altera recommends following the top-down synthesis methodology.

An example synthesis script that reads the design, applies timing constraints, reports results, saves the synthesized netlist file in the Verilog Quartus Mapping File format, and creates the Tcl scripts to work with the

Quartus II software is shown in Example 11–5. It uses the command write\_fpga, which is described in "write\_fpga Command" on page 11–22.

#### Example 11-5. Sample Synthesis Script

```
# Setup output directories
set outdir ./design
file delete -force $outdir
file mkdir $outdir
set rptdir ./report
file delete -force $rptdir
file mkdir $rptdir
# Enable Presto compiler for VHDL design files
# set hdlin_enable_presto_for_vhdl TRUE
# Setup libraries
define design lib work-path .$outdir/work
file mkdir $outdir/work
analyze -format verilog ./source/mult box.v
analyze -format verilog ./source/mult ram.v
analyze -format verilog ./source/top module.v
elaborate top module
link
current design top module
create clock -period 5 [get ports clk]
set input delay -max 2 -clock clk [get ports {data in * mode in}]
set_input_delay -min 0.5 -clock clk [get_ports {data_in_* mode_in}]
set output delay -max 2 -clock clk [get ports {data out ram data out port} ]
set output delay -min 0.5 -clock clk [get ports {data out ram data out port} ]
set false path -from [get ports reset]
ungroup -small 500
compile
report_timing > $rptdir/top_module.log
report fpga > $rptdir/top module fpga.log
write fpga $outdir
quit
```

# Reporting Design Information

After compilation is complete, the DC FPGA software reports information about your design. You can specify which kinds of reports you want generated with the reporting commands shown in Table 11–2.

| Object             | Command                    | Description                                                                                    |  |
|--------------------|----------------------------|------------------------------------------------------------------------------------------------|--|
| Design             | report_design              | Reports design characteristics                                                                 |  |
|                    | report_area                | Reports design size and object counts                                                          |  |
|                    | report_hierarchy           | Reports design hierarchy                                                                       |  |
|                    | report_resources           | Reports resource implementations                                                               |  |
|                    | report_fpga                | Reports FPGA resource utilization statistics for the design                                    |  |
| Instances          | report_cell                | Displays information about instances                                                           |  |
| References         | report_reference           | Displays information about references                                                          |  |
| Ports              | report_port                | Displays information about ports                                                               |  |
|                    | report_bus                 | Displays information about bused ports                                                         |  |
| Nets               | report_net                 | Reports net characteristics                                                                    |  |
|                    | report_bus                 | Reports bused net characteristics                                                              |  |
| Clocks             | report_clock               | Displays information about clocks                                                              |  |
| Timing             | report_timing              | Checks the timing of the design                                                                |  |
|                    | report_constraint          | Checks the design constraints                                                                  |  |
|                    | check_timing               | Checks for unconstrained timing paths and clock-gating logic                                   |  |
|                    | report_design              | Shows operating conditions, timing ranges, internal input and output, and disabled timing arcs |  |
|                    | report_port                | Shows unconstrained input and output ports and port loading                                    |  |
|                    | report_timing_requirements | Shows all timing exceptions set on the design                                                  |  |
|                    | report_clock               | Checks the clock definition and clock skew information                                         |  |
|                    | derive_clocks              | Checks internal clock and unused registers                                                     |  |
|                    | report_path_group          | Shows all timing path groups in the design                                                     |  |
| Cell<br>Attributes | get_cells                  | Shows all cell instances that have a specific attribute                                        |  |



For more information about the usage of these commands, refer to the *Synopsys DC FPGA User Guide*.

The DC FPGA software only provides preliminary estimates of your design's timing delays because the timing of your design cannot be accurately predicted until the Quartus II software has placed and routed your design.

# Saving Synthesis Results

After synthesis, the technology-mapped design can be saved to a file in one of the following four formats: Verilog HDL, VHDL, Synopsys internal DB, or EDIF.

The Quartus II software accepts an EDIF netlist or Verilog Quartus Mapping netlist synthesized from the DC FPGA software. The default output netlist from the DC FPGA software is Verilog Quartus Mapping. The Verilog Quartus Mapping File format follows a subset of Verilog HDL rules. You can use the same Verilog Quartus Mapping netlist format with the Quartus II software and formal verification.

Use the write command to save your design work. The syntax for this command is shown in Example 11–6.

### Example 11-6. Syntax Using the write Command

write -format <verilog|db|edif> -output <file name> <design list>
[-hierarchy] ←

The -hierarchy option causes the DC FPGA software to write all the designs within the hierarchy of the current design. The DC FPGA default flow to interface with Quartus II software uses the Verilog Quartus Mapping netlist.

To generate a Verilog Quartus Mapping netlist, set the required settings using the commands shown in Example 11–7.

#### Example 11–7. Generating a Verilog Quartus Mapping Netlist

define\_name\_rules ALTERA -remove\_internal\_net\_bus
change\_names -rules ALTERA -hier
change\_names -rules verilog -hier
write -format verilog -hier -o <design\_top>.vqm

The Synopsys internal DB format is useful when you have synthesized your design and want to reuse it later in the DC FPGA software. The DB file contains your constraints and synthesized design netlist, and loads into the DC FPGA software faster than Verilog HDL or VHDL designs.

You can also write out your design constraints in Tcl format for export to the Quartus II software with the write\_par\_constraint command or by using the write\_fpga command. These commands are explained in "Exporting Designs to the Quartus II Software".

# Exporting Designs to the Quartus II Software

The DC FPGA software can create two Tcl scripts that start the Quartus II software, create your initial design project, apply the exported timing constraints, and compile your design in the Quartus II software.

You can generate the two Tcl scripts by using write and write\_par\_constraint command together, or by using the write\_fpga command alone.

# write\_fpga Command

The recommended method to export all of the place-and-route files from the DC FPGA software is to use the write\_fpga command. This command is used after the compile. Example 11–8 shows how the write\_fpga command is used.

#### Example 11-8. Using the write\_fpga Command after Compile

compile
write\_fpga <outputdir>

The write fpga command will do the following in one step:

#### Example 11–9. Using the write\_fpga Command to Generate All Files

write -hier -f db -o \$outputdir/top\_module.db
write -hier -f edif -o \$outputdir/top\_module.edf
define\_name\_rules ALTERA -remove\_internal\_net\_bus
change\_names -rules ALTERA -hier
change\_names -rules verilog -hier
write -format verilog -hier -o <design\_top>.vqm
write par constraint \$outputdir/top module quartus setup.tcl

When you use the write\_fpga command, it generates all files in the current work directory or in the directory you specify (entering an output directory is optional) and generates the output files based on the current design file name.

## write & write\_par\_constraint Commands

The write command is used to generate a post synthesis netlist for place-and-route and formal verification. You should use a Verilog Quartus Mapping formatting netlist to work with the Quartus II software, beginning with the DC FPGA software, version 2005.09. Example 11–10 uses the write and write\_par\_constraint commands to generate the Verilog Quartus Mapping File and Tcl scripts:

#### Example 11–10. Using the write & write\_par\_constraint Commands

```
define_name_rules ALTERA -remove_internal_net_bus
change_names -rules ALTERA -hier
change_names -rules verilog -hier
write -format verilog -hier -o <design top>.vqm
```

Tcl scripts that start the Quartus II software and forward annotate the timing constraints can be generated using the write\_par\_constraint command.

```
write_par_constraint <user-specified file name>.tcl ←
```

This command generates both Tcl scripts in one operation. The first Tcl script has the name you specify in the write\_par\_constraint command. This script creates and compiles your Quartus II project. The second script is automatically generated and named <top\_module>\_const.tcl by default and contains your exported timing constraints from the DC FPGA software. This constraint file is sourced by the <user-specified file name>.tcl script and applies the timing constraints used in the DC FPGA software to your project in the Quartus II software.

For example, if your design is called dma\_controller, and you run the command, write\_par\_constraint run\_quartus.tcl, the DC FPGA software produces two Tcl scripts called run\_quartus.tcl and dma controller const.tcl.

# Using Tcl Scripts with Quartus II Software

To use this Tcl script in the Quartus II Tcl shell, type the following command at a command prompt:

```
quartus sh -t <user-specified file name>.tcl ←
```

To run this Tcl script in the Quartus II software GUI, type the following command at the Quartus II Tcl console prompt:

```
source <user-specified file name>.tcl ←
```

The ability to run scripts in the Tcl console is useful when performing an initial compilation of your design to view post place-and-route timing and device utilization results, but the advanced Quartus II options that control the compilation process are not available.

To create a Quartus II project without performing compilation automatically, remove these lines from the script:

```
load_package flow
execute flow -compile
```

#### Example 11–11. An Example Script

```
# Generated by DC FPGA X-2005.09 on Wed Aug 10 04:20:01 2005
# Description: This TCL script is generated by DC FPGA using
           write par constraint command. It is used to create a new Quartus
           II project, specify timing constraint assignments in Quartus II,
           and run quartus map, quartus fit, quartus tan, & quartus asm.
# Usage: To execute this TCL script in batch mode: quartus sh -t turboTop.tcl
       To execute this TCL script in Quartus II GUI: source turboTop.tcl
#******
                     ******
            WARNING
                                WARNING
                                         *********
# Please ensure the P&R netlist name is represented correctly in this tcl file.
# You may need to change the file name variable to match your actual netlist
# name.
# Set the file name and project name variable
set file name turboTop.vqm
set project_name turboTop
# Close the project if open
if [is_project_open] {
  project_close
# Create a new project
project new -overwrite -family STRATIXII -part EP2S30F484C3 $project name
# Make global assignments
set global assignment -name TOP LEVEL ENTITY $project name
# if you are using Verilog P&R netlist, please comment out EDIF assignment
# and uncomment the VERILOG assignment below.
#set global assignment -name EDIF FILE $file name
set global assignment -name VQM FILE $file name
```

```
set global assignment -name ADV NETLIST OPT SYNTH WYSIWYG REMAP ON
#set global assignment -name ADV NETLIST OPT SYNTH WYSIWYG REMAP OFF
set global assignment -name EDA DESIGN ENTRY SYNTHESIS TOOL -value "Design Compiler FPGA"
set global assignment -name EDA INPUT VCC NAME -value VDD -section id
eda design synthesis
set global assignment -name EDA INPUT GND NAME -value GND -section id
eda design synthesis
set global assignment -name EDA LMF FILE -value dc fpga.lmf -section id
eda design synthesis
set global assignment -name VERILOG LMF FILE dc fpga.lmf
set global assignment -name FITTER EFFORT "STANDARD FIT"
# Source in the design timing constraint file
source $project name \ cons.tcl
# The following runs quartus map, quartus fit, quartus tan, & quartus asm
load package flow
execute flow -compile
project close
```

After synthesis in the DC FPGA software, the technology-mapped design is written to the current project directory as an Verilog Quartus Mapping netlist file. The project configuration script (<u >user-specified file name>.tcl) is used to create and compile a Quartus II project containing your Verilog Quartus Mapping netlist. The example script makes basic project assignments such as assigning the target device as specified in the DC FPGA software. The project configuration script calls the place-and-route constraints script to make your timing constraints. The place-and-route constraints script (<top module>\_const.tcl) forward-annotates the timing constraints that you made in the DC FPGA software, including false path assignments, multi-cycle assignments, timing groups, and related clocks. This integration means that you need to enter these constraints only once, in the DC FPGA software, and they are passed automatically to the Quartus II software.

# Place & Route with the Quartus II Software

After you have created your Quartus II project and successfully loaded your Verilog Quartus Mapping netlist into the Quartus II project, you can use the Quartus II software to perform place-and-route. The Synopsys DC FPGA software uses only worst case timing delays and constraints, and does not optimize minimum timing requirements. Altera recommends that you add minimum timing constraints and perform minimum timing analysis in the Quartus II software.



For more information about these advance features, area optimization, and timing closure, refer to the *Quartus II Handbook*.

You can use the Quartus II software to obtain accurate prediction of post-conversion  $f_{MAX}$  performance and power consumption characteristics when migrating from a high-density FPGA to a cost-optimized, high-volume structured ASIC such as a HardCopy Stratix device.

The Quartus II software place-and-route algorithms can use register packing, register retiming, automatic logic duplication, and what-you-see-is-what-you-get (WYSIWYG) primitive re-synthesis technologies to increase logic utilization in your device and to deliver superior  $f_{MAX}$  performance at extremely high logic utilization.



For more information, refer to the *Quartus II Support for HardCopy Series Devices* chapter in volume 1 of the *Quartus II Handbook*.

# Formality Software Support

Beginning with version 4.2, the Quartus II software interfaces with the Formality software from Synopsys. Formality software verifies logic equivalency between the RTL and DC FPGA post-synthesis netlist, and between the DC FPGA post-synthesis netlist and the Quartus II post-place-and-route netlist. A synthesized verilog netlist generated by the DC FPGA is required to use with formality flow. Formality supports Stratix II, Stratix and Stratix GX device families.



For more information about how to set the required synthesis settings to generate a valid formal verification netlist and to use the Formality software for equivalence checking, refer to the *Synopsys Formality Support* chapter in volume 3 of the *Quartus II Handbook*.

# **Conclusion**

Large FPGA designs require advanced synthesis of their HDL code. Taking advantage of the Synopsys DC FPGA software and the Quartus II software allows you to develop high-performance designs while occupying as little programmable logic resources as possible. The DC FPGA software and Quartus II software combination is an excellent solution for the high density designs using Altera FPGA devices.



# 12. Analyzing Designs with Quartus II Netlist Viewers

QII51013-6.0.0

# Introduction

As FPGA designs grow in size and complexity, the ability to analyze how your synthesis tool interprets your design becomes critical. With today's advanced designs, often several design engineers are involved in coding and synthesizing different design blocks, making it difficult to analyze and debug the design. The Quartus® II RTL Viewer, State Machine Viewer, and Technology Map Viewer provide powerful ways to view your initial and fully mapped synthesis results during the debugging, optimization, or the constraint entry process.

The first section in this chapter, "When to Use Viewers: Analyzing Design Problems" describes examples of using the viewers to analyze your design at various stages of the design cycle. The following sections provide an introduction to the Quartus II design flow using the netlist viewers, an overview of each viewer, and an explanation of the user interface. The next sections describe the following activities:

- How to navigate and filter schematics
- How to probe to and from other windows within the Quartus II software
- How to view a timing path from the Timing Analyzer report

The final section "Debugging HDL Code with the State Machine Viewer" on page 12–45 provides a detailed example that uses the viewer to analyze a design and quickly resolve a design problem.

# When to Use Viewers: Analyzing Design Problems

You can use the netlist viewer to analyze your design to see how it was interpreted by the Quartus II software. This section provides simple examples of how to use the RTL, State Machine, and Technology Map Viewers to analyze problems encountered in the design process.

For more explanation about how the netlist viewers display your design, refer to the following sections:

- Quartus II Design Flow with the Netlist Viewers
- RTL Viewer Overview
- State Machine Viewer Overview
- Technology Map Viewer Overview

To see the user interface for the netlist viewers, refer to "Introduction to the User Interface" on page 12–7.

Using the RTL Viewer is a good way to view your initial synthesis results to determine whether you have created the desired logic, and that the logic and connections have been interpreted correctly by the software. You can use the RTL Viewer and the State Machine Viewer to visually check your design before simulation or other verification processes. Catching design errors at this early stage of the design process can save you valuable time.

If you see unexpected behavior during verification, this is another good opportunity to use the RTL Viewer to trace through the netlist and ensure that the connections and the logic in your design are as expected. You can also use the State Machine Viewer to view state machine transitions and transition equations. Viewing the design can help you find and analyze the source of design problems. If your design looks correct in the RTL Viewer, you know to focus your analysis on later stages of the design process and investigate potential timing violations or issues in the verification flow itself.

You can use the Technology Map viewer to look at the results at the end of synthesis by running the viewer after performing Analysis & Synthesis, or the results after placement and routing by running the viewer after running the Fitter.

In addition, you can use the RTL Viewer or Technology Map Viewer to locate the source of a particular signal, which can help you debug your design. Use the navigation techniques described in this chapter to search easily through the design. You can trace back from a point of interest to find the source of the signal and ensure the connections are as expected.

You also can use the Technology Map Viewer to help you locate post-synthesis nodes in your netlist and make assignments when optimizing your design. This functionality can be useful, for example, when making a multicycle clock timing assignment between two registers in your design. You can start at an I/O port and trace forward or backwards through the design and through levels of hierarchy to find nodes that interest you, or to locate a specific register by visually inspecting the schematic.

The RTL Viewer, State Machine Viewer, and Technology Map Viewer can be used in many other ways throughout the design, debugging, and optimization stages. Viewing the design netlist is a powerful way to analyze design problems. This chapter shows how you can use the various features of the netlist viewers to increase your productivity when analyzing a design.

# Quartus II Design Flow with the Netlist Viewers

The first time you open one of the netlist viewers after compiling the design, a preprocessor stage runs automatically before the viewer opens. If you close the viewer and open it again later without recompiling the design, the viewer opens immediately without performing the preprocessing stage. Figure 12–1 shows how the netlist viewers fit into the basic Quartus II design flow.



Figure 12-1. Quartus II Design Flow Including the RTL Viewer & Technology Map Viewer

Each viewer requires that your design has been compiled with the minimum compilation stage listed below before the viewer can run the preprocessor and open the design.

- To open the RTL Viewer or State Machine Viewer, you must first perform at least **Analysis & Elaboration**.
- To open the Technology Map Viewer, you must first perform at least **Analysis & Synthesis**.



If you open one of the viewers without first compiling the design with the appropriate minimum compilation stage, the viewer does not appear. Instead, the Quartus II software issues an error message instructing you to run the necessary compilation stage and restart the viewer.

Both viewers display the results of the last successful compilation. Therefore, if you make a design change that causes an error during Analysis & Elaboration, you cannot view the netlist for the new design files, but you can still see the results from the last successfully compiled version of the design files. If you receive an error during compilation and you have not yet successfully run the appropriate compilation stage for your project, the viewer cannot be displayed; in this case, the Quartus II software issues an error message when you try to open the viewer.



If the viewer window is open when you start a new compilation, the viewer closes automatically. You must open the viewer again to view the new design netlist after compilation completes successfully.

# RTL Viewer Overview

The Quartus II RTL Viewer allows you to view a register transfer level (RTL) graphical representation of your Quartus II integrated synthesis results or your third-party netlist file within the Quartus II software.

You can view results after Analysis & Elaboration when your design uses any supported Quartus II design entry method, including Verilog HDL Design files (.v), VHDL (.vhd), AHDL Text Design Files (.tdf), schematic Block Design Files (.bdf), or schematic Graphic Design Files (.gdf) imported from the MAX+PLUS® II software. You can also view the hierarchy of atom primitives (such as device logic cells and I/O ports) when your design uses a synthesis tool to generate a Verilog Quartus Mapping File (.vqm) or Electronic Design Interchange Format (.edf) netlist file. Refer to Figure 12–1, "Quartus II Design Flow Including the RTL Viewer & Technology Map Viewer" for a flow diagram.

The Quartus II RTL Viewer displays a schematic view of the design netlist after analysis and elaboration or netlist extraction is performed by the Quartus II software, but before technology mapping and any synthesis or fitter optimization algorithms occur. This view is not the final design structure because optimizations have not yet occurred. This view most closely represents your original source design. If you synthesized your design using the Quartus II integrated synthesis, this view shows how the Quartus II software interpreted your design files. If you are using a third-party synthesis tool, this view shows the netlist written by your synthesis tool.

When displaying your design, the RTL Viewer optimizes the netlist to maximize readability in the following ways:

- Logic with no fan-out (its outputs are unconnected) and logic with no fan-in (its inputs are unconnected) are removed from the display.
- Default connections such as VCC and GND are not shown.
- Pins, nets, wires, module ports, and certain logic are grouped into buses where appropriate.
- Constant bus connections are grouped.
- Values are displayed in hexadecimal format.
- NOT gates are converted to bubble inversion symbols in the schematic.
- Chains of equivalent combinational gates are merged into a single gate, for example, a 2-input AND gate feeding a 2-input AND gate is converted to a single 3-input AND gate.
- State machine logic is converted into a state diagram, state transition table and state encoding table which are displayed in the State Machine Viewer.

To run the RTL Viewer for a Quartus II project, first analyze the design to generate an RTL netlist. To analyze the design and generate an RTL netlist, on the Processing menu, point to Start and click **Start Analysis & Elaboration**. You can also perform a full compilation or any process that includes the initial Analysis & Elaboration stage of the Quartus II compilation flow.

To run the viewer, on the Tools menu, point to Netlist Viewers and click **RTL Viewer**, or select **RTL Viewer** from the **Applications** toolbar.



The **Applications** toolbar does not display by default in the Quartus II user interface. To add the toolbar, on the Tools menu, click **Customize**. On the **Customize** dialog box, click the **Toolbars** tab under **Toolbars**, and turn on **Applications**. Click **Close**.

# State Machine Viewer Overview

The State Machine Viewer presents a high-level view of finite state machines in your design. The State Machine Viewer provides a graphical representation of the states and their related transitions, as well as a state transition table that displays the condition equation for each of the state transitions, and encoding information for each state.

To run the State Machine Viewer, on the Tools menu, point to Netlist Viewers and click **State Machine Viewer**. To open the State Machine Viewer for a particular state machine, double-click the state machine instance in the RTL Viewer, or right-click the state machine instance, and click **Hierarchy Down**.

# Technology Map Viewer Overview

The Quartus II Technology Map Viewer provides a technology-specific, graphical representation of your design after Analysis & Synthesis or the Fitter has mapped your design into the target device. The Technology Map Viewer shows the hierarchy of atom primitives (such as device logic cells and I/O ports) in your design. For supported families, you can also view the internal registers and look-up tables inside logic cell (LCELL) and registers in I/O atom primitives. Refer to "Viewing Contents of Atom Primitives in the Technology Map Viewer" on page 12–21 for details.



Where possible, the port names of each hierarchy are maintained throughout synthesis. However, port names may change or be removed from the design. For example, if a port is unconnected or driven by GND or VCC, it is removed during synthesis. When a port name is changed, the port is assigned a related user logic name in the design, or a generic port name such as IN1 or OUT1.

You can view your Quartus II technology-mapped results after synthesis, fitting, or timing analysis. To run the Technology Map Viewer for a Quartus II project, on the Processing menu, point to Start and click **Start Analysis & Synthesis** to first synthesize and map the design to the target technology. You also can perform a full compilation, or any process that includes the synthesis stage in the compilation flow.

If you have completed the Fitter stage, the Technology Map Viewer shows the changes made to your netlist by the Fitter, such as physical synthesis optimizations. If you have completed the Timing Analysis stage, you can locate timing paths from the Timing Analyzer report in the Technology Map Viewer (refer to "Viewing a Timing Path" on page 12–37 for details). Refer to Figure 12–1 for a flow diagram.

To run the viewer, on the Tools menu, point to Netlist Viewers and click **Technology Map Viewer**, or select **Technology Map Viewer** from the **Applications** toolbar.

# Introduction to the User Interface

The RTL Viewer window and Technology Map Viewer window each consist of two main parts: the schematic view and the hierarchy list. Figure 12–2 shows the RTL Viewer window and indicates these two parts. Both viewers also contain a toolbar that gives you tools to use in the schematic view.

You can have only one RTL Viewer and one Technology Map Viewer window open at a time, although each window can show multiple pages. The window for each viewer has characteristics similar to other "child" windows in the Quartus II software; it can be resized and moved, minimized or maximized, tiled or cascaded, and moved in front of or behind other windows.

RTL Viewer Hierarchy Schematic Toolbar List View Selection Tool 1 RTL Viewe Zoom Tool 0 Page Title: filt ef | Page 1 of 1 Hand Tool Hierarchy List ∃ filtref Full Screen # Instances Refresh - Primitives ₽ # Pins Find -# Nets Previous Page Next Page Back (Display Preview View) Forward -(Display Next View)

Figure 12-2. RTL Viewer Window & RTL Toolbar

### **Schematic View**

The schematic view is shown on the right side of the RTL Viewer and Technology Map Viewer. It contains a schematic representing the design logic in the netlist. This is the main screen for viewing your gate-level netlist in the RTL Viewer and your technology-mapped netlist in the Technology Map Viewer.

#### Schematic Symbols

The symbols for nodes in the schematic represent elements of your design netlist. These elements include input and output ports, registers, logic gates, Altera primitives, high-level operators, and hierarchical instances.

Figure 12–3 shows an example of an RTL Viewer schematic for a 3-bit synchronous loadable counter. The "Code Sample for Counter Schematic Shown in Figure 12–3" section shows the Verilog HDL code that produced this schematic. In this example, there are multiplexers and a group of registers (Table 12–1) in a bus along with an ADDER operator (Table 12–3) inferred by the counting function in the HDL code.

The schematic displays wire connections between nodes with a thin black line, and bus connections with a thick black line (Figure 12–3).



Figure 12–3. Example Schematic Diagram in the RTL Viewer

#### Example 12–1. Code Sample for Counter Schematic Shown in Figure 12–3

```
module counter (input [2:0] data, input clk, input load, output [2:0] result);
   reg [2:0] result_reg;
   always @ (posedge clk)
      if (load)
        result_reg <= data;
      else
        result_reg <= result_reg + 1;
   assign result = result_reg;
endmodule</pre>
```

Figure 12–4 shows a portion of the corresponding Technology Map Viewer schematic with a compiled design that targets a Stratix<sup>®</sup> device. In this schematic, you can see the LCELL (logic cell) device-specific primitives that represent the counter function, labeled with their post-synthesis node names. The REGOUT port represents the output of the register in the LCELL, and the COMBOUT port represents the output of the combinational logic in the look-up table (LUT) of the LCELL. The hexadecimal number in parentheses below each LCELL primitive represents the LUT mask, which is a hexadecimal representation of the logic function of the LCELL.



Figure 12-4. Example Schematic Diagram in the Technology Map Viewer

Table 12–1 lists and describes the primitives and basic symbols that you can display in the schematic view of the RTL Viewer and Technology Map Viewer. Table 12–3 on page 12–13 lists and describes the additional higher level operator symbols used in the RTL Viewer schematic view.



The logic gates and operator primitives appear only in the RTL Viewer. Logic in the Technology Map Viewer is represented by atom primitives such as LCELL.

| Table 12–1. Symbols in the Schematic View (Part 1 of 3) |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Symbol                                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| I/O Ports 4_in1                                         | An input, output, or bidirectional port in the current level of hierarchy. A device input, output, or bidirectional pin when viewing the top-level hierarchy. The symbol can represent a bus. Only one wire is connected to the bidirectional symbol, representing both the input and the output paths.  Input symbols appear on the left-most side of the schematic, while output and bidirectional symbols appear on the right-most side of the schematic. |  |
| I/O Connectors  >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>     | An input or output connector, representing a net that comes from another page of the same hierarchy (refer to "Partitioning the Schematic into Pages" on page 12–24). To go to the page that contains the source or the destination, right-click on the net and choose the page from the menu (refer to "Following Nets across Schematic Pages" on page 12–25).                                                                                              |  |
| Hierarchy Port Connect                                  | A connector representing a port relationship between two different hierarchies. A connector indicates that a path passes through a port connector in a different level of hierarchy.                                                                                                                                                                                                                                                                         |  |
| OR, AND, XOR Gates  3 inst  5 reduce x                  | An OR, AND, or XOR gate primitive (the number of ports can vary). A small circle (bubble symbol) on an input or output indicates that the port is inverted.                                                                                                                                                                                                                                                                                                  |  |
| MUX<br>0 1 18                                           | A multiplexer (MUX) primitive with a selector port that selects between port 0 and port 1. A MUX with more than two inputs is displayed as an operator (refer to "Operator Symbols in the RTL Viewer Schematic View" on page 12–13).                                                                                                                                                                                                                         |  |
| BUFFER<br>32_j47                                        | A buffer primitive. The figure shows the tri-state buffer, with an inverted output enable port. Other buffers without an enable port include LCELL, SOFT, CARRY, and GLOBAL. The NOT gate and EXP expander buffers use this symbol without an enable port and with an inverted output port.                                                                                                                                                                  |  |
| CARRY_SUM inst SI SO CI CO                              | A CARRY_SUM buffer primitive, where SI represents SUM IN, SO represents SUM OUT, CI represents CARRY IN, and CO represents the CARRY OUT port of the buffer.                                                                                                                                                                                                                                                                                                 |  |

| Table 12–1. Symbols in the Schematic View (Part 2 of 3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Symbol                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| LATCH    M_Mgch   PRE   PRE | A latch primitive with D data input, EN enable input, Q data output, and PRE preset and CLR clear ports.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| DFFE/DFFEA/DFFAES  ticket[1]-reg0  PRE 0 Q  ENA CLR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | A DFFE (data flipflop with enable) primitive, with the same ports as a latch and a clock trigger. The other flipflop primitives are similar: DFFEA (data flipflop with enable and asynchronous load) primitive with additional ALOAD asynchronous load and ADATA data signals, and DFFEAS (data flipflop with enable and both synchronous and asynchronous load) which has ASDATA as the secondary data port.                                                                                                                                                                                      |  |
| Atom Primitive  result_reg[0]  CLK OATAA DATAB PEGOUT  CATACO LCELL (8888)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Primitives are low-level nodes that cannot be expanded to any lower hierarchy. The symbol displays the port names, the primitive type, and its name. The blue shading indicates an atom primitive in the Technology Map Viewer which allows you to view the internal details of the primitive. Refer to "Viewing Contents of Atom Primitives in the Technology Map Viewer" on page 12–21 for details.                                                                                                                                                                                              |  |
| Other Primitive  x[6]~106  DATAA  DATAB  DATAC  DATAC  DATAD  LCELL (E5E0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Any primitive that does not fall into the categories above. Primitives are low-level nodes that cannot be expanded to any lower hierarchy. The symbol displays the port names, the primitive or operator type, and its name.  The figure shows an LCELL WYSIWYG primitive, with DATAA to DATAD and COMBOUT port connections. This type of LCELL primitive would be found in the Technology Map Viewer for technology-specific atom primitives when the contents of the atom primitive cannot be viewed. The RTL Viewer contains similar primitives if the source design was a VQM or EDIF netlist. |  |
| Instance  taps:inst  ck esst esst esst esst spq se(0q)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | An instance in the design that does not correspond to a primitive or operator (generally a user-defined hierarchy block), indicated by the double outline and green shading. The symbol displays the instance name. To open the schematic for the lower level hierarchy, right-click and choose the appropriate command (refer to "Traversing & Viewing the Design Hierarchy" on page 12–20).                                                                                                                                                                                                      |  |

| Table 12–1. Symbols in the Schematic View (Part 3 of 3)                                   |                                                                                                                                                                                                                                                |  |
|-------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Symbol                                                                                    | Description                                                                                                                                                                                                                                    |  |
| Encrypted Instance  const_mapperinst  OUT1 OUT2 IN1 OUT3 IN2 OUT4 IN3 OUT6 OUT7 OUT7 OUT8 | A user-defined encrypted instance in the design, indicated by the double outline and gray shading. The symbol displays the instance name. You cannot open the schematic for the lower level hierarchy, because the source design is encrypted. |  |
| State Machine Instance filter  newt tap3 newt tap2 clk tap1 reset tap4                    | A finite state machine instance in the design, indicated by the double outline and yellow shading. Double-clicking this instance opens the State Machine Viewer. Refer to "State Machine Viewer" on page 12–17 for more details.               |  |

Table 12–2 lists and describes the symbol used only in the State Machine Viewer.

| Table 12–2. Symbol Available only in the State Machine Viewer |                                                                                                                                                                                                                                                                                                      |  |
|---------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Symbol                                                        | Description                                                                                                                                                                                                                                                                                          |  |
| State Node                                                    | The node representing a state in a finite state machine. State transitions are indicated with arcs between state nodes. The double circle border indicates the state connects to logic outside the state machine, while a single circle border indicates the state node does not feed outside logic. |  |

Table 12–3 lists and describes the additional higher level operator symbols used in the RTL Viewer schematic view.

| Symbol                       | Description                                | Description |  |
|------------------------------|--------------------------------------------|-------------|--|
| add~0                        | An adder operator: OUT = A + B             |             |  |
| A(70)<br>0(70)               |                                            |             |  |
| ADDER                        |                                            |             |  |
| mult~0                       | A multiplier operator: OUT = A × B         |             |  |
| A(70]<br>B(70] OUT(70]       |                                            |             |  |
| MULTIPLIER                   |                                            |             |  |
| div~0                        | A divider operator: OUT = A / B            |             |  |
| A(70]<br>B(70] OUT(70]       |                                            |             |  |
| DIVIDER                      |                                            |             |  |
| shift_left~0                 | A left shift operator: OUT = (A << COUNT)  |             |  |
| A[70] ОUТ[70] →              |                                            |             |  |
| LEFT_SHIFT                   |                                            |             |  |
| shift_right~0                | A right shift operator: OUT = (A >> COUNT) |             |  |
| Α[7.0] ΟυΤ[7.0] → COUNT[7.0] |                                            |             |  |
| RIGHT_SHIFT                  |                                            |             |  |
| mod~0                        | A modulo operator: OUT = (A % B)           |             |  |
| A[70] OUT[70]                |                                            |             |  |
| A(7.0] OUT(7.0)              |                                            |             |  |

| Table 12–3. Operator Symbols in the RTL Viewer Schematic View (Part 2 of 2) |                                                                                                |  |
|-----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|--|
| Symbol                                                                      | Description                                                                                    |  |
| LessThan~0  A[70] OUT  LESS_THAN                                            | A less than comparator: OUT = (A <= B : A < B)                                                 |  |
| MUX~0  SEL[20] DATA[70]  MUX                                                | A multiplexer: OUT = DATA [SEL] The data range size is 2 <sup>sel range size</sup>             |  |
| Select=0  SEL[30]  DATA[30]  SELECTOR                                       | A multiplexer with one-hot select input, and more than two input signals.                      |  |
| Decoder~1  IN[1.0] OUT[3.0]  DECODER                                        | A binary number decoder:  OUT = (binary_number (IN) == x)  for x=0 to x=2 <sup>(n+1)</sup> - 1 |  |

#### Selecting an Item in the Schematic View

To select an item in the schematic view, ensure that the **Selection Tool** is enabled in the viewer toolbar (this tool is enabled by default). Click on an item in the schematic view to highlight it in red.

Select multiple items by pressing the Shift or Ctrl key while selecting with your mouse. You also can select all nodes in a region by selecting a rectangular box area with your mouse cursor when the **Selection Tool** is enabled. To select nodes in a box, move your mouse to one corner of the area you want to select, click the mouse button, and drag the mouse to the opposite corner of the box, then release the mouse button. By default, creating a box like this highlights and selects all nodes in the selected area (instances, primitives, and pins), but not the nets. The **Viewer Options** dialog box provides an option to select nets. To include nets, right-click in the schematic and click **Viewer Options**. In the **Net Selection** section, turn on the **Select entire net when segment is selected** option.

Items selected in the schematic view are automatically selected in the hierarchy list (refer to the "Hierarchy List" on page 12–15). The list expands automatically if required to show the selected entry. However, the list does not collapse automatically when entries are not being used or are deselected.

When you select a hierarchy box, node, or port in the schematic view, the item is highlighted in red but none of the connecting nets are highlighted. When you select a net (wire or bus) in the schematic view, all connected nets are highlighted in red. The selected nets are highlighted across all hierarchy levels and pages. Net selection can be useful when navigating a netlist because you see the net highlighted when you traverse between hierarchy levels or pages.

In some cases, when you select a net that connects to nets in other levels of the hierarchy, these connected nets also are highlighted in the current hierarchy. If you prefer that these nets are not highlighted, use the **Viewer Options** dialog box option to highlight a net only if the net is in the current hierarchy. Right-click in the schematic, and click **Viewer Options**. In the **Net Selection** section, turn on the **Limit selections to current hierarchy** option.

#### Moving & Panning in the Schematic View

When the schematic view page is larger than the portion currently displayed, you can use the scroll bars at the bottom and right side of the schematic view to see other areas of the page.

You can also use the Hand Tool to "grab" the schematic page and drag it in any direction. Enable the Hand Tool with the toolbar button. Click and drag to move around the schematic view without using the scroll bars.

## **Hierarchy List**

The hierarchy list is displayed on the left side of the viewer window. The hierarchy list displays the entire netlist in a "tree" format based on the hierarchical levels of the design. Using the hierarchy list, you can traverse through the design hierarchy to view the logic schematic for each level. You also can select an element in the hierarchy list that you want to see highlighted in the schematic view.



Nodes inside atom primitives are not listed in the hierarchy list.

For each module in the design hierarchy, the hierarchy list displays the the applicable elements listed in Table 12–4. Click the + icon to expand an element.

| Table 12–4. Hierarchy List Elements |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Elements                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| Instances                           | Modules or instances in the design that can be expanded to lower hierarchy levels.                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| State Machines                      | State machine instances in the design that can be viewed in the State Machine Viewer.                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| Primitives                          | Low-level nodes that cannot be expanded to any lower hierarchy level. These include registers and gates that you can view in the RTL Viewer when using Quartus II integrated synthesis, or logic cell atoms in the Technology Map Viewer or in the RTL Viewer when using a VQM or EDIF from third-party synthesis software. In the Technology Map Viewer, you can view the internal implementation of certain atom primitives, but you can not traverse into a lower level of hierarchy. |  |
| Pins                                | <ul> <li>The I/O ports in the current level of hierarchy.</li> <li>Pins are device I/O pins when viewing the top hierarchy level, and are I/O ports of the design when viewing the lower levels.</li> <li>When a pin represents a bus or an array of pins, expand the pin entry in the list view to see individual pin names.</li> </ul>                                                                                                                                                 |  |
| Nets                                | Nets or wires connecting the nodes. When a net represents a bus or array of nets, expand the net entry in the tree to see individual net names.                                                                                                                                                                                                                                                                                                                                          |  |

#### Selecting an Item in the Hierarchy List

When you click any item in the hierarchy list, the viewer performs the following actions:

- Searches for the item in the currently viewed pages, and displays the page containing the selected item in the schematic view if it is not currently displayed. (If you are currently viewing a filtered netlist, for example, the relevant page within the filtered netlist is displayed.)
- If the selected item is not found in the currently viewed pages, the entire design netlist is searched, and the item is displayed in a default view.
- Highlights the selected item in red in the schematic view.

When you double-click an instance in the hierarchy list, the viewer displays the underlying implementation of the instance.

You can select multiple items by pressing the Shift or Ctrl key while selecting with your mouse. When you right-click an item in the hierarchy list, you can navigate in the schematic view using the **Filter** and **Locate** commands. Refer to "Filtering in the Schematic View" on page 12–27 and "Probing to Source Design File & Other Quartus II Windows" on page 12–35 for more information.

#### State Machine Viewer

The State Machine Viewer displays a graphical representation of the state machines in your design. You can open the State Machine Viewer in any of the following ways:

- On the Tools menu, point to Netlist Viewers, and click State
   Machine Viewer
- Double-click on a state machine instance in the RTL Viewer
- Right-click on a state machine instance in the RTL Viewer, and click Hierarchy Down
- Select a state machine instance in the RTL Viewer, and on the Project menu, point to Hierarchy and click **Down**

Table 12–5 shows an example of the State Machine Viewer for a simple state machine. The State Machine toolbar on the left side of the viewer provides tools you can use in the state diagram view.



Figure 12-5. State Machine in the State Machine Viewer

#### State Diagram View

The state diagram view is shown at the top of the State Machine Viewer window. It contains a diagram of the states and state transitions.

The nodes that represent each state are arranged horizontally in the state diagram view with the initial state, that is, the state node that receives the reset signal, in the left-most position. Nodes that connect to logic outside of the state machine instance are represented by a double circle. The state transition is represented by an arc with an arrow pointing in the direction of the transition.

When you select a node in the state diagram view, if you turn on the **Highlight Fan-in** or **Highlight Fan-out** command from the View menu or the State Machine Viewer toolbar, the respective fan-in or fan-out transitions from the node are highlighted in red.



An encrypted block with a state machine displays encoding information in the state encoding table, but does not display a state transition diagram or table.

#### State Transition Table

The state transition table on the **Transitions** tab at the bottom of the State Machine Viewer window displays the condition equation for each state transition. Each transition (each arc in the state diagram view) is represented by a row in the table. The table has the following three columns:

- **Source State**—the name of the source state for the transition
- Destination State—the name of the destination state for the transition
- Condition—the condition equation that causes the transition from source state to destination state

To easily see all the transitions to and from each state name, click the appropriate column heading to sort on that column.

The text in each column is left aligned by default; to change the alignment and more easily see the relevant part of the text in the table, right-click in the column, and click **Align Right**. To change back to left alignment, choose **Align Left**.

You can click in any cell in the table to select it. To select all cells, right-click in the cell and click **Select All**; or, on the Edit menu, click **Select All**. To copy selected cells to the clipboard, right-click the cells and click **Copy Table**; or, on the Edit menu, point to Copy and click **Copy Table**. You can paste the table into any text editor as tab-separated columns.

#### State Encoding Table

The state encoding table on the **Encoding** tab at the bottom of the State Machine Viewer window displays the encoding information for each state transition.

To view state encoding information in the State Machine Viewer, you must have synthesized your design using **Start Analysis & Synthesis**. If you have only elaborated your design using **Start Analysis & Elaboration**, the encoding information is not displayed.

#### Selecting an Item in the State Machine Viewer

Each state node and transition in the State Machine Viewer can be selected and highlighted. To select a state transition, click the arc that represents the transition.

When you select a state node and/or transition arc in the state diagram view, the matching state node and/or equation conditions in the state transition table are highlighted; conversely, when you select a state node and/or equation condition in the state transition table, the corresponding state node and/or transition arc is highlighted in the state diagram view.

#### Switching between State Machines

A design may contain multiple state machines. To choose which state machine to view, use the **State Machine selection** box located at the top of the State Machine Viewer. Click in the drop-down box and select the desired state machine.

# Navigating the Schematic View

The previous sections provided an overview of the user interface for each netlist viewer, and how to select an item in each viewer. This section describes ways to navigate through the pages and hierarchy levels in the schematic view of the RTL Viewer and Technology Map Viewer.

## Traversing & Viewing the Design Hierarchy

You can open different hierarchy levels in the schematic view using the hierarchy list (refer to "Hierarchy List" on page 12–15), or the **Hierarchy Up** and **Hierarchy Down** commands in the schematic view.

Use the **Hierarchy Down** command to go down into, or expand an instance's hierarchy, and open a lower level schematic showing the internal logic of the instance. Use the **Hierarchy Up** command to go up in hierarchy, or collapse a lower level hierarchy, and open the parent higher level hierarchy. When the **Selection Tool** is selected, the appropriate option is available when your mouse pointer is located over an area of the schematic view that has a corresponding lower or higher level hierarchy.

The mouse pointer changes as it moves over different areas of the schematic to indicate whether you can move up, down, or both up and down in the hierarchy (Figure 12–6). To open the next hierarchy level, right-click in that area of the schematic, and click **Hierarchy Down** or **Hierarchy Up**, as appropriate, or double-click in that area of the schematic.

Figure 12-6. Mouse Pointers Indicate How to Traverse Hierarchy



Hierarchy Up



Hierarchy Down



Hierarchy Up or Down

#### Flattening the Design Hierarchy

You can flatten the design hierarchy to see the design without hierarchical boundaries. To flatten the hierarchy from the current level and all the lower level hierarchies of the current design hierarchy, right-click in the schematic, and click **Flatten Netlist**. To flatten the entire design, choose this command from the top-level schematic of the design.

Viewing the Contents of a Design Hierarchy within the Current Schematic

You can use the **Display Content** and **Hide Content** commands to show or hide a lower hierarchy level for a specific instance within the schematic for the current hierarchy level.

To display the lower hierarchy netlist of an instance on the same schematic as the remaining logic in the currently viewed netlist, right-click the selected instance, and click **Display Content**.

To hide all of the lower hierarchy logic of a hierarchy box into a closed instance, right-click the selected instance, and click **Hide Content**.

## Viewing Contents of Atom Primitives in the Technology Map Viewer

In the Technology Map Viewer, you can view the contents of certain device atom primitives to see their underlying implementation details. For logic cell (LCELL) atoms in Stratix, Cyclone<sup>™</sup>, and MAX<sup>®</sup> II devices, you can view the look-up tables (LUT), registers, and logic gates. For I/O atoms in Stratix II, Cyclone II, Stratix, Cyclone, and HardCopy<sup>®</sup> II devices, you can view the registers and logic gates.

In addition, you can view the implementation of RAM and DSP blocks in certain devices. You can view the implementation of RAM blocks in Stratix II, Stratix II GX, Stratix, Stratix GX, Cyclone II, and Cyclone devices. You can view the implementation of DSP blocks only in Stratix and Stratix GX series of devices.

If you can view the contents of an atom instance, it is colored blue in the schematic view (Figure 12–7).

Figure 12-7. Instance that Can Be Expanded to View Internal Contents



To view the contents of one or more atom primitive instances, select the desired atom instance(s). Right-click the selected instance and click **Display Content**. Figure 12–8 shows an expanded version of the instance in Figure 12–7.

Figure 12-8. Internal Contents of the Atom Instance in Figure 12-7.



To hide the contents (and revert to the compact format), select and right-click the atom instance(s), and click **Hide Content**.



In the schematic view, the internal details within an atom instance can not be selected as individual nodes. Any mouse action on any of the internal details is treated as a mouse action on the atom instance.

#### **Zooming & Magnification**

You can control the magnification of your schematic with the View menu, the **Zoom Tool** in the toolbar, or the Ctrl key and mouse wheel button, as described in this section.

The Fit in Window, Fit Selection in Window, Zoom In, Zoom Out, and Zoom commands are available from the View menu, by right-clicking in the schematic view and selecting Zoom, or from the Zoom toolbar. To enable the zoom toolbar, on the Tools menu, click Customize. Click the Toolbars tab and click Zoom to enable the toolbar.

By default, the viewer displays most pages sized to fit in the window. If the schematic page is very large, the schematic is displayed at the minimum zoom level, and the view is centered on the first node. Select **Zoom In** to see the image at a larger size, and select **Zoom Out** to see the image (when the entire image is not displayed) at a smaller size. The **Zoom** command allows you to specify a magnification percentage (where 100% is considered the normal size for the schematic symbols). The **Fit Selection in Window** command zooms in on the selected nodes in a schematic to fit within the window. Use the **Selection Tool** to select one or more nodes (instances, primitives, pins, and nets), then select **Fit Selection in Window** to enlarge the area covered by the selection. This feature is helpful when you want to see a particular element in a large schematic. After you select a node, you can easily zoom in to view the particular node.

You also can use the **Zoom Tool** on the viewer toolbar to control magnification in the schematic view. When you select the **Zoom Tool** in the toolbar, clicking on the schematic zooms in and centers the view on the location you clicked. Right-click on the schematic (or press the Shift key or the Ctrl key and click) to zoom out and center the view on the location you clicked. When you select the **Zoom Tool**, you also can zoom in to a certain portion of the schematic by selecting a rectangular box area with your mouse cursor. The schematic is enlarged to show the selected area. To change the minimum and the maximum zoom level, on the Tools menu, click **Options**. In the **Options** dialog box, in the **Category** list, select **RTL/Technology Map Viewer**, and set the desired minimum and maximum zoom level.

By default, the viewers maintain the zoom level when filtering on the schematic (refer to "Filtering in the Schematic View" on page 12–27). To change the behavior so that the zoom level is always reset to "Fit in Window," on the Tools menu, click **Options**. In the **Category** list, select **RTL/Technology Map Viewer**, and turn off **Maintain zoom level**.

#### **Partitioning the Schematic into Pages**

For large design hierarchies, the RTL Viewer and Technology Map Viewer partition your netlist into multiple pages in the schematic view. To control how much of the design can be seen on each page, on the Tools menu, click **Options**. In the **Category** list, select **RTL/Technology Map Viewer**, and set the desired options under **Display Settings**.

The **Nodes per page** option specifies the number of nodes per partitioned page. The default value is 50 nodes; the range is 1 to 1,000 nodes. The **Ports per page** option specifies the number of ports (or pins) per partitioned page. The default value is 1,000 ports/pins; the range is 1 to 2,000 ports/pins. The viewers partition your design into a new page if either the node number or the port number exceeds the limit you have specified. You may occasionally see the number of ports exceed the limit, depending on the configuration of nodes on the page.

When a hierarchy level is partitioned into multiple pages, the title bar for the schematic window indicates which page is displayed and how many total pages exist for this level of hierarchy (shown in the format: Page <*current page number>* of <*total number of pages>*) as shown in Figure 12–9.



Figure 12-9. RTL Viewer Title Bars Indicating Page Number Information

When you change the number of nodes or ports per page, the change applies only to new pages that are shown or opened in the viewer. To refresh the current page so that it displays the changed number of nodes or ports, click the **Refresh** button in the toolbar.

#### Moving between Schematic Pages

To move to another schematic page, on the View menu, click **Previous Page** or **Next Page**, or click the **Previous Page** icon or the **Next Page** icon in the viewer toolbar.

To go to a particular page of the schematic, on the Edit menu, click **Go To**, or right-click in the schematic view, and click **Go To**. In the **Page** list, select the desired page number.

#### Moving Back & Forward through Schematic Pages

To return to the previous view after changing the page view, click **Back** on the View menu, or click the **Back** icon on the viewer toolbar. To go to the next view, click **Forward** on the View menu, or click the **Forward** icon on the viewer toolbar.



You can go **Forward** only if you have not made any changes to the view since going **Back**. Use **Back** and **Forward** to switch between page views. These commands do not undo an action such as selecting a node.

## Following Nets across Schematic Pages

Input and output connectors indicate nodes that connect across pages of the same hierarchy. Right-click on a connector to display a menu of commands that trace the net through the pages of the hierarchy.



After you right-click to follow a connector port, the viewer opens a new page, which centers the view on the particular source or destination net using the same zoom factor used by the previous page. To trace a specific net to the new page of the hierarchy, Altera recommends that you first select the desired net, which highlights it in red, before you right-click to traverse pages.

#### **Input Connectors**

Figure 12–10 shows an example of the menu that appears when you right-click an input connector. The **From** command opens the page containing the source of the signal. The **Related** commands, if applicable, open the specified page containing another connection fed by the same source.

Figure 12–10. Input Connector Right Button Pop-Up Menu



#### **Output Connectors**

Figure 12–11 shows an example of the menu that appears when you right-click an output connector. The **To** command opens the specified page that contains a destination of the signal.

Figure 12-11. Output Connector Right Button Pop-Up Menu



#### Go to Net Driver

To locate the source of a particular net in the schematic view, select the net to highlight it, right-click the selected net, point to Go to Net Driver, and click **Current page**, **Current hierarchy**, or **Across hierarchies**. Refer to Table 12–5.

| Table 12–5. Go to Net Driver Commands |                                                                                                                                   |  |
|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|--|
| Command                               | Action                                                                                                                            |  |
| Current page                          | Locates the source or driver on the current page of the schematic only.                                                           |  |
| Current hierarchy                     | Locates the source within the current level of hierarchy, even if the source is located on another page of the netlist schematic. |  |
| Across hierarchies                    | Locates the source across hierarchies until the software reaches the source at the top hierarchy level.                           |  |

The schematic view opens the correct page of the schematic if needed, and adjusts the centering of the page so that you can see the net source. The schematic shows the default page for the net driver. The view is an unfiltered view, so no filtering results are kept.

# Filtering in the Schematic View

Filtering allows you to filter out nodes and nets in your netlist to view only a logic path that interests you.

Filter your netlist by selecting hierarchy boxes, nodes, ports of a node, net, or states in a state machine that are part of the path you want to see. The following filter commands are available:

- **Sources**—Displays the sources of the selection
- **Destinations**—Displays the destinations of the selection
- Sources & Destinations—Displays both the sources and destinations of the selection
- Selected Nodes and Nets—Displays only the selected nodes and nets with the connections between them
- Between Selected Nodes—Displays nodes and connections in the path between the selected nodes
- Bus Index—Displays the sources or destinations for one or more indices of an output or input bus port

Select a hierarchy box, node, port, net, or state node, right-click in the window, point to Filter and click the appropriate filter command. The viewer generates a new page showing the netlist that remains after filtering.

When filtering in a state diagram in the State Machine Viewer, sources and destinations refer to the previous and next transition states or paths between transition states in the state diagram. The transition table and encoding table also reflect the filtering.

You can go back to the netlist page before it was filtered using the **Back** command, described in "Moving Back & Forward through Schematic Pages" on page 12–25.



When viewing a filtered netlist, clicking an item in the hierarchy list causes the schematic view to display an unfiltered view of the appropriate hierarchy level. You cannot use the hierarchy list to select items or navigate in a filtered netlist.

#### **Filter Sources Command**

To filter out all but the source of the selected item, right click the item, point to Filter and click **Sources**. The selected object type determines what is displayed, as outlined in Table 12–6 below, and shown in Figure 12–12 on page 12–29.

| Table 12–6. Selected Objects Determine Filter Sources Display |                                                                                                       |  |
|---------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--|
| Selected Object Result Shown in Filtered Page                 |                                                                                                       |  |
| Node or hierarchy box                                         | Shows all the sources of the node's input ports. For an example, refer to Figure 12–12 on page 12–29. |  |
| Net                                                           | Shows the sources that feed the net.                                                                  |  |
| Input port of a node                                          | Shows only the input source nodes that feed this port.                                                |  |
| Output port of a node                                         | Shows only the selected node.                                                                         |  |
| State node in a state machine                                 | Shows the states that feed the selected state (previous transition states).                           |  |

#### **Filter Destinations Command**

To filter out all but the destinations of the selected node or port displayed as outlined in Table 12–7 below, and shown in Figure 12–12 on page 12–29, right-click the node or port, point to Filter, and click **Destinations**.

| Table 12–7. Selected Objects Determine Filter Destinations Display |                                                                                                             |  |
|--------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|--|
| Selected Object                                                    | Result Shown in Filtered Page                                                                               |  |
| Node or hierarchy box                                              | Shows all the destinations of the node's output ports. For an example, refer to Figure 12–12 on page 12–29. |  |
| Net                                                                | Shows the destinations fed by the net.                                                                      |  |
| Input port of a node                                               | Shows only the selected node.                                                                               |  |
| Output port of a node                                              | Shows only the fan-out destination nodes fed by this port.                                                  |  |
| State node in a state machine                                      | Shows the states that are fed by the selected states (next transition states).                              |  |

#### **Filter Sources & Destinations Command**

The **Sources & Destinations** command is a combination of the **Sources** and **Destinations** filtering commands, in which the filtered page shows both the sources and the destinations of the selected item. To select this option, right-click on the desired object, point to Filter, and click **Sources & Destinations**. For an example, refer to Figure 12–12.



Figure 12–12. Sources, Destinations & Sources & Destinations Filtering for inst4

#### Filter between Selected Nodes Command

To show the nodes in the path between two or more selected nodes or hierarchy boxes, right-click, point to Filter, and click **Between Selected Nodes**. For this option, selecting a port of a node is the same as selecting the node. For an example, refer to Figure 12–13.

Figure 12–13. Between Selected Nodes Filtering Between inst2 & inst3



#### Filter Selected Nodes & Nets Command

To create a filtered page that shows only the selected nodes and/or nets and, if applicable, the connections between the selected nodes and/or nets, right-click, point to Filter, and click **Selected Nodes & Nets**. Figure 12–14 shows a schematic with some nodes selected.

Figure 12-14. Using Selected Nodes & Nets to Select Nodes



Figure 12–15 shows the schematic after filtering has been performed. If you select a net, the filtered page shows the immediate sources and destinations of the selected net.

Figure 12-15. Selected Nodes & Nets Filtering on Figure 12-14 Schematic

#### **Filter Bus Index Command**

To show the path related to a specific index of a bus input or output port in the RTL Viewer, right-click the port, point to Filter, and click **Bus Index**. The **Select Bus Index** dialog box allows you to select the indices of interest.

#### **Filter Command Processing**

The options to control filtering are available in the **Filtering** section of the **RTL/Technology Map Viewer Options** dialog box. Right-click in the schematic, and click **Viewer Options** to open the dialog box.

For all the filtering commands, the viewer stops tracing through the netlist to obtain the filtered netlist when it reaches one of the following objects:

- A pin
- A specified number of filtering levels, counting from the selected node or port; the default value is 3



Specify the **Number of filtering** levels in the **Filtering** section of the **RTL/Technology Map Viewer Options** dialog box. The default value is 3 to ensure optimal processing time when performing filtering, but you can specify a value from 1 to 100.

A register (optional; turned on by default)



Turn the **Stop filtering at register** option on or off in the **Filtering** section of the **RTL/Technology Map Viewer Options** dialog box. Right-click in the schematic and click **Viewer Options** to open the dialog box.

By default, the filtered schematic shows all possible connection between the nodes shown in the schematic. To remove the nodes and connections that are not directly part of the path that was traced to generate a filtered netlist, turn off the Shows all connections between nodes option in the Filtering section of the RTL/Technology Map Viewer Options dialog box.

#### **Filtering Across Hierarchies**

The filtering commands display nodes in all hierarchies by default. When the filtered path passes through levels of hierarchy on the same schematic page, green hierarchy boxes group the logic and show the hierarchy boundaries. A diamond symbol appears on the border that represents the port relationship between two different hierarchies (Figure 12–16 on page 12–33 and Figure 12–17 on page 12–33).

The RTL/Technology Map Viewer Options dialog box provides an option to control filtering if you prefer to filter only within the current hierarchy. Right-click in the schematic, and click Viewer Options. In the Filtering section, turn off the Filter across hierarchy option.

To disable the box hierarchy display, on the Tools menu, click **Options**. In the Category list, select **RTL/Technology Map Viewer**, and turn off **Show box hierarchy**.



Netlists of the same hierarchy that are displayed over more than one page are not grouped with a box. Filtering and expanding on a blue atom primitive does not trace the underlying netlist even when **Filter across hierarchy** is enabled.

Figures 12–16 and 12–17 show examples of filtering across hierarchical boundaries. Figure 12–17 shows an example after the **Sources** filter has been applied to an input port of the taps instance, where the input port of the lower level hierarchical block connects directly to an input pin of the design. The name of the instance is indicated within the green border and appears as a tooltip when you move your mouse pointer over the instance.

Instance Name taps:inst Port Relationship

Figure 12-16. Filtering Across Hierarchical Boundaries, Small Example



Figure 12–17 shows a larger example after the **Sources** filter that has been applied to an input port of an instance, in which the source comes from input pins that are fed through another level of hierarchy.

Figure 12-17. Filtering Across Hierarchical Boundaries, Large Example



Sources command applied to an input port of an instance in which the source comes from input pins that are fed through another level of hierarchy.

# **Expanding a Filtered Netlist**

After a netlist is filtered, there may be ports whose connections are not displayed because they are not part of the main path through the netlist. Two expansion features, immediate expansion and the **Expand** command, allow you to add the fan-out or fan-in signals of these ports to the schematic display of a filtered netlist.

You can immediately expand any port whose connections are not displayed by double-clicking that port in the filtered schematic. When you do so, one level of logic is expanded.

To expand more than one level of logic, right-click the port and click the **Expand** command. This command expands logic from the selected port by the amount specified in the **Viewer Options**. To set these options, right-click in the schematic view, and click **Viewer Options**. In the Expansion section, set the **Number of expansion levels** option to specify the number of levels to expand (the default value is 3 and the range is 1 to 100 levels). You also can set the **Stop expanding at register** option (which is turned on by default) to specify whether to stop netlist expansion when a register is reached.

You can select multiple nodes to expand when using the **Expand** command. If you select ports that are located on multiple schematic pages, only the ports on the currently viewed page are shown in the expanded schematic.

In the State Machine Viewer, the **Expand** command has the following three options:

- Sources—Displays the states that feed the selected states (previous transition states).
- Destinations—Displays the states that are fed by the selected states (next transition states).
- Sources & Destinations—Displays both the previous and next transition states.

The state transition table and state encoding table also reflect the changes to the filtering.

The expansion feature works across hierarchical boundaries if the filtered page containing the port to be expanded was generated with the **Filter across hierarchy** option turned on (refer to "Filtering in the Schematic View" on page 12–27 for details on this option). When viewing timing paths in the Technology Map Viewer, the **Expand** command always works across hierarchical boundaries because filtering across hierarchy is always turned on for these schematics (Refer to "Viewing a Timing Path" on page 12–37 for details on these schematics).

# **Reducing a Filtered Netlist**

In some cases, removing logic from a filtered schematic or state diagram makes the schematic view easier to read or minimizes distracting logic that you do not need to see on the schematic.

To reduce elements in the filtered schematic or state diagram view, right-click the node or nodes you want to remove and click **Reduce**.

# Probing to Source Design File & Other Quartus II Windows

The RTL, Technology Map, and State Machine Viewers let you cross-probe from the viewer to the source design file and to various other windows within the Quartus II software. You can select one or more hierarchy boxes, nodes, nets, state nodes, or state transition arcs that interest you in the viewer and locate the corresponding items in another applicable Quartus II software window. You then can view and make changes or assignments in the appropriate editor or floorplan.

To locate an item from the viewer in another window, right-click the items of interest in the schematic or state diagram view, point to Locate, and click the appropriate command. The following commands are available:

- Locate in Assignment Editor
- **■** Locate in Pin Planner
- Locate in Timing Closure Floorplan
- Locate in Chip Editor
- Locate in Resource Property Editor
- Locate in RTL Viewer
- Locate in Technology Map Viewer
- Locate in Design File

The options available for locating depend on the type of node and whether it exists after placement and routing. If a command is enabled in the menu, then it is available for the selected node. You can use the **Locate** in **Assignment Editor** command for all nodes, but assignments may be ignored during placement and routing if they are applied to nodes that do not exist after synthesis.

The viewer automatically opens another window for the appropriate editor or floorplan, and highlights the selected node or net in the newly opened window. You can switch back to the viewer by selecting it in the Window menu or by closing, minimizing, or moving the new window.

# Probing to the Viewers from Other Quartus II Windows

You can cross-probe to the RTL Viewer and Technology Map Viewer from other windows within the Quartus II software. You can select one or more nodes or nets in another window and locate them in one of the viewers.

You can locate nodes between the RTL, State Machine, and Technology Map Viewers, and you can locate nodes in the RTL Viewer or Technology Map Viewer from the following Quartus II software windows:

- Project Navigator
- Timing Closure Floorplan
- Chip Editor
- Resource Property Editor
- Node Finder
- Assignment Editor
- Messages Window
- Compilation Report

To locate elements in the viewer from another Quartus II window, select the node or nodes in the appropriate window; for example, select an entity in the **Entity** list on the **Hierarchy** tab in the Project Navigator, or select nodes in the **Timing Closure Floorplan**, or select node names in the **From** or **To** column in the Assignment Editor. Then, right-click the selected object, point to Locate, and click **Locate in RTL Viewer** or **Locate in Technology Map Viewer**. After you choose this command, the viewer window opens, or is brought to the foreground if the viewer window is already open.



The first time the window opens after a compilation, the preprocessor stage runs before the viewer window opens.

The viewer shows the selected nodes and, if applicable, the connections between the nodes. The display is similar to what you see if you right-click the object, point to Filter, and click **Selected Nodes & Nets** using **Filter Across Hierarchy**. If the nodes cannot be found in the viewer, a message box displays the message: "Can't find message location."

# Viewing a Timing Path

You can cross-probe from the Timing Analysis section of the Compilation Report to see a visual representation of a timing path listed by the Timing Analyzer.

To take advantage of this feature, you must first successfully complete a full compilation of your design, including the Timing Analyzer stage. To access the **Timing Analyzer** report which contains the timing results for your design, on the Processing menu, click **Compilation Report**. To view a path listed in any of the detailed reports for **Clock Setup**: *<clock name>*, **tsu**, **tco**, **tpd**, or other timing parameters. When you select a detailed report, the timing information is listed in a table format on the right side of the Compilation Report; each row of the table represents a timing path in the design. To view a particular timing path in the Technology Map Viewer, right-click the appropriate row in the table, point to Locate, and click **Locate in Technology Map Viewer** or **Locate in RTL Viewer**.

Figure 12–18 shows a portion of a timing path represented in the Technology Map Viewer. The total delay for the entire path going through a number of levels of logic (only three are shown in Figure 12–18) is 7.159 ns. The delays are indicated for each level of logic, for example, the interconnect or IC delay to the first LCELL primitive is 0.383 ns, and the cell delay through the LCELL is 0.075 ns. When the timing path passes through a level of hierarchy, green hierarchy boxes group the logic and show the hierarchical boundaries. A diamond symbol on the border indicates the path passes between two different hierarchies.



Figure 12–18. Timing Path Schematic in the Technology Map Viewer

In the RTL Viewer, the schematic page displays the nodes in the path(s) between the source and destination registers with a summary of the total delay.

The RTL Viewer netlist is based on an initial stage of synthesis, so the post-fitting nodes may not exist in the RTL Viewer netlist. Therefore, the internal delay numbers are not displayed in the RTL Viewer as they are in the Technology Map Viewer, and the timing path may not be displayed exactly as it appears in the timing analysis report. If there are multiple paths between the source and destination registers, the RTL Viewer might display more than just the timing path. There are also some cases when the path cannot be displayed, such as paths through state machines, encrypted intellectual property (IP), or registers that are created during the fitter process. In cases where the timing path displayed in the RTL Viewer might not be the correct path, the compiler issues messages.

# Other Features in the Schematic Viewer

This section describes other features in the schematic view that enhance usability and help you analyze your design.

#### **Tooltips**

A tooltip is displayed whenever the mouse pointer is held over an element in the schematic. The tooltip contains useful information about a node, net, input port, and output port. Table 12–8 lists the information contained in the tooltip for each type of node.

The tooltip information for an instance (the first row in Table 12–8) includes a list of the primitives found within that level of hierarchy, and the number of each primitive contained in the current instance. The number includes all hierarchical blocks below the current instance in the hierarchy. This information lets you estimate the size and complexity of a hierarchical block without navigating into the block.

The tooltip information for atom primitives in the Technology Map Viewer (the second row of Table 12–8) shows the equation for the design atom. The equations are an expanded version of the equations you can view in the Equations window in the Timing Closure Floorplan. Advanced users can use these equations to analyze the design implementation in detail.



For details on understanding equations, refer to the Quartus II Help.

To copy tooltips into the clipboard for use in other applications, right-click the desired node or netlist, and click **Copy Tooltip**.

To turn off tooltips or change the duration of time that a tooltip is displayed in the view, on the Tools menu, click **Options**. In the Category list, select **RTL/Technology Map Viewer** and set the desired options under **Tooltip settings**.

The **Show names in tooltip for** option specifies the number of seconds to display the names of assigned nodes and pins in a tooltip when the pointer is over the assigned nodes and pins. Selecting **Unlimited** displays the tooltip as long as the pointer remains over the node or pin. Selecting **0** turns off tooltips. The default value is 5 seconds.

The **Delay showing tooltip for** option specifies the number of seconds you must hold the mouse pointer over assigned nodes and pins before the tooltip displays the names of the assigned nodes and pins. Selecting **0** displays the tooltip immediately when the pointer is over an assigned node or pin. Selecting **Unlimited** prevents tooltips from being displayed. The default value is 1 second.

| Table 12–8. Tooltip Information (Part 1 of 2)                                                                                                                                                                               |                                                                 |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|--|
| Description & Tooltip Format                                                                                                                                                                                                | Example Tooltips                                                |  |
| Instance Format: <instance name="">, <instance type=""> <primitive type="">, <number of="" primitives=""> <primitive type="">, <number of="" primitives=""></number></primitive></number></primitive></instance></instance> | taps:inst, INST DFF 32 OPERATOR(SELECTOR) 8 OPERATOR(DECODER) 1 |  |
| Atom Primitive Format: <instance name=""> , <primitive name=""> (<lut mask="" value="">)</lut></primitive></instance>                                                                                                       | inst5[3], LCELL (0000)   <                                      |  |
| Primitive Format: <primitive name="">, <primitive type=""></primitive></primitive>                                                                                                                                          | clocks:inst7 Mux~1, OPER (MUX)  md_me:inst18 data(33), DFFE     |  |
| Pin Format: <pin name="">, <pin type=""></pin></pin>                                                                                                                                                                        | pc_clock, INPUT Test_probe, OUTPUT                              |  |
| Connector Format: <connector name=""></connector>                                                                                                                                                                           | inst4_CLK                                                       |  |
| Net Format: <net name="">, fan-out = <number fan-out="" of="" signals=""></number></net>                                                                                                                                    | state_m:inst1:decoder_node[2][0], fan-out = 1                   |  |

| Table 12–8. Tooltip Information (Part 2 of 2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                               |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|--|
| Description & Tooltip Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Example Tooltips              |  |
| Output port Format: fan-out = <number fan-out="" of="" signals=""></number>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | fan-out = 9                   |  |
| Input Port  The information displayed depends on the type of the source net. The examples of the tooltips shown represent the following type of source net:  (1) Single net  (2) Individual nets, part of the same bus net  (3) Combination of different bus nets  (4) Constant inputs  (5) Combination of single net and constant input  (6) Bus net  Source from refers to the source net name that connects to the input port.  Destination Index refers to the bit(s) at the destination input port to which the source net is connected (not applicable for single nets). | Source from: reset:reset_irst |  |
| State Machine Node Format: <node name=""></node>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | state_m:inst1 filter.tap1     |  |
| State Machine Transition Arc This information is displayed when you hold your mouse over the arrow on the arc representing the transition between two states. Format: ( <equation between="" for="" states="" transition="">)</equation>                                                                                                                                                                                                                                                                                                                                       | (Inewt)                       |  |

#### Rollover

You can highlight an element and view its name in your schematic using the rollover feature. When you place your mouse pointer over an object, the object is highlighted and the name is displayed, helping you to analyze your schematic diagram. This feature is enabled by default in the netlist viewers. To turn off the Rollover feature, on the Tools menu, click **Options**. In the **Options** dialog box, in the **Category** list, select **RTL/Technology Map Viewer** and turn off **Enable Rollover**.

RTL Viewer Page Title: taps:inst | Page 1 of 1 Selector2 🔥 Selector2 Selector3 Selector4 Selector5 Selector6 SEL[3..0] Selector7 3[5] ± xn[7..0] ± xn\_1[7..0] ± xn\_2[7..0] OUT DATA[3..0] ± xn\_3[7..0] Nets - clk ± d[7..0] Decoder0:

Figure 12-19. Rollover in the RTL Viewer & Technology Map Viewer

## The Properties Dialog Box

You can view the properties of an instance or a primitive using the Properties Dialog box. To view the properties of an instance or a primitive in the RTL Viewer or the Technology Map Viewer, right-click the node and click **Properties**.

The Properties dialog box contains the following information about the selected node:

- The parameter values of an instance.
- The active level of the port (for example, active high or active low). An active low port is denoted with an exclamation mark "!".
- The port's constant value (for example, VCC or GND). Table 12–9 describes the possible value of a port.

| Table 12–9. Possible Port Values |                                                             |
|----------------------------------|-------------------------------------------------------------|
| Value                            | Description                                                 |
| VCC                              | The port is not connected and has VCC value (tied to VCC)   |
| GND                              | The port is not connected and has GND value (tied to GND)   |
|                                  | The port is connected and has value (other than VCC or GND) |
| Unconnected                      | The port is not connected and has no value (hanging)        |

#### **Displaying Net Names**

To see names of all the nets displayed in your schematic, on the Assignments menu, click **Options**. In the Category list, select **RTL/Technology Map Viewer** and turn on **Show Net Name** under **Display Settings**. This option is disabled by default. If you turn on this option, the schematic view refreshes automatically to display the net names.

# **Displaying Node Names**

Nodes in some designs have long names that overlap the ports of other symbols in the schematic. To remove the node names from the schematic, on the Tools menu, click **Options**. In the **Category** list, select **RTL/Technology Map Viewer** and turn off **Show node name** under **Display Settings**. This option is turned on by default.

#### **Full Screen View**

To set the viewer window to fill the whole screen, on the View menu, click **Full Screen**, or click the **Full Screen** icon in the viewer toolbar, or press Ctrl+Alt+Space. The keyboard shortcut toggles the full screen. To return to the standard screen view after viewing the full screen, press Ctrl+Alt+Space again.

#### **Find Command**

To open the **Find** dialog box shown in Figure 12–20, on the Edit menu, click **Find**, or click the **Find** icon in the viewer toolbar, or right-click in the schematic view, and click **Find**.

Figure 12-20. Find Dialog Box



Select **Up** in the Search list to search from the current hierarchy to upper (parent) hierarchies. Select **Down** to search from the current hierarchy to lower (child) hierarchies. You can choose to search only instances (nodes) in the design, or to also search pins and nets. By default, only instances are searched.

When you click **Find**, the viewer selects and highlights the first item found, opens the appropriate page of the schematic, if necessary, and centers the page so that the node is seen in the viewable area (but does not zoom in to the node). To find the next matching node, click **Find Next**.

You can use the options in the **Advanced settings** section to control the scope of the results found during a search and how they are displayed in the viewer. The default selection, **Search entire design**, searches for the item in all design elements across the entire design. To search only in the pages of the currently displayed netlist, such as a schematic showing filtering results, choose **Limit search to schematic view**.

To display the results in a new page, select **Search entire design and display in search page**. This command searches all design elements across the entire design, and displays the results on a separate page dedicated to search results. You can also append new search results to an

existing search page with the **Append results to current search page** command. The appended items appear in the same relative position as they do in the full schematic. You can use this to find and select two objects that are not on the same page and display them on the same page after performing the **Find** command.



Refer to "Finding Nodes in the RTL Viewer & Technology Map Viewer" in the Quartus II Help for more details on using the Find dialog box.

#### **Exporting & Copying a Schematic Image**

You can export the RTL Viewer or Technology Map Viewer schematic view in JPEG File Interchange Format (.jpg) or Windows Bitmap (.bmp) file format, which allows you to include the schematic in project documentation or share it with other project members. To export the schematic view, on the File menu, click Export. In the Export dialog box, type a file name and location, and select the desired file type. The default file name is based on the current instance name and the default file type is JPEG Interchange Format (.jpg). However, for pages that use filtering, expanding, or reducing operations, the default name is Filter<number of export operation>.-file extension>.

You can choose to copy the whole image or copy only a portion of the image. To copy the full image, on the Edit menu, point to Copy and click **Full Image**. To copy a portion of the image when using a Windows-based platform, on the Edit menu, point to Copy and click **Partial Image**. The cursor changes to indicate that you can draw a box shape. Drag the cursor around the portion of the schematic you want to copy. When you release the mouse button, the partial image is copied to the clipboard.



Occasionally, due to the design size and objects selected, an image is too large to copy to the clipboard. In this case, the Quartus II software displays an error message.

To export or copy a schematic that is too large to copy in one piece, first split the design into multiple pages to export or to copy smaller portions of the design. For information about how to control how much of your design is shown on each schematic page, refer to "Partitioning the Schematic into Pages" on page 12–24. As an alterative, use the Partial Image feature to copy a portion of the image.

The **Copy** feature is not available on UNIX platforms.

#### **Printing**

To print your schematic page, on the File menu, click **Print**. You can print each schematic page onto one full page, or you can print the highlighted parts of your schematic onto one page with the **Selection** option. Refer to "Partitioning the Schematic into Pages" on page 12–24 to control how much of your design is shown on each schematic page.



Before printing, you can modify the page orientation. On the File menu, click **Page Setup**. Change the page orientation from **Portrait** to **Landscape**, or to the setting that best fits your design. You also can adjust the page margins in the **Page Setup** dialog box.

The hierarchy list in the viewers and the table view of the State Machine Viewer cannot be printed. You can use the State Machine Viewer **Copy** command to copy the table to a text editor and print from the text editor.

# Debugging HDL Code with the State Machine Viewer

This section provides an example of using the State Machine Viewer to help debug HDL code. This example shows you how you can use the various features in the netlist viewers to help solve design problems.

#### Simulation of State Machine Gives Unexpected Results

The section presents a design scenario in which you compiled your design and performed a simulation in the Quartus II Simulator. The simulation result is shown in Figure 12–21 and has unexpected undefined states.



Figure 12–21. Simulation Result Showing Undefined States

To analyze the state machine design in the State Machine Viewer, follow these steps:

- 1. Open the State Machine Viewer for the state machine of interest. You can do this in one of the following ways:
- On the Tools menu, point to Netlist Viewers, and click State Machine Viewer. In the State Machine selection box, choose the state machine that you want to view.

or

On the Tools menu, point to Netlist Viewers, and click **RTL Viewer**. Browse to the hierarchy block that contains the state machine definition and double-click the yellow state machine instance to open the State Machine Viewer (Figure 12–24). You can open the State Machine Viewer using either of two methods:

 In the schematic view, double-click an instance in the hierarchy to open the lower level hierarchy. You can traverse through the schematic hierarchy in this way to open the schematic page that contains the state machine (Figure 12–22).

Figure 12–22. State Machine Instance in RTL Viewer Schematic View

or

• In the hierarchy list, click the + symbol next to **Instances** to open a list of the instances in that hierarchy level of the design. You can traverse down the hierarchy tree in this way to find the instance that contains the state machine. Click on the name of the state machine in the **State Machines** folder (Figure 12–23) to open the appropriate schematic in the schematic view (Figure 12–22).

☐ · Instances
☐ · fsm:fsm1
☐ · State Machines
☐ · Current\_state
☐ · Primitives
☐ · Pins
☐ · Nets

Figure 12–23. State Machine Instance in RTL Viewer Hierarchy List





- 3. You can now analyze this state machine instance using the state machine diagram, transition table, and encoding table. You can clearly see something is wrong with the state machine because there are transitions between every state. Upon inspecting the state machine behavior, you can determine that in this scenario, the designer forgot to create default assignments for the next state (that is, next state = current state if the conditions are not met).
- 4. After fixing the error in the HDL code, recompile the design and repeat steps 1-3 to view the new state machine diagram and transition table shown in Figure 12–25 to check that the state transitions are now occurring correctly.



Figure 12–25. State Machine Viewer Showing Correct Transitions

5. Perform a new simulation, as shown in Figure 12–26, and ensure that the state machine now performs as expected.

imulation Waveform Simulation mode: Timing Master Time Bar: 0 ps Pointer: 119.74 ns 119.74 ns Start: End: Interval: 20.0 ns 40.0 ns 80.0 ns 100,0 ns 0 ps 60.0 ns Name 0 ps clk ent\_state/current\_state.S1/current\_state.S0 fsm:fsm2|current\_state current\_state S1 ent\_state.Xcurrent\_state.S1)/current\_state.S0)/current\_state.S1)/current\_state.S2)/current\_state.S fsm:fsm1|current\_state X1 X2 >

Figure 12-26. Simulation Result Showing Correct States

# **Conclusion**

The Quartus II RTL Viewer, State Machine Viewer, and Technology Map Viewer allow you to explore and analyze your initial synthesis netlist, post-synthesis netlist, or post-fitting and physical synthesis netlist. The viewers provide a number of features in the hierarchy list and schematic view to help you trace through your netlist and find specific hierarchies or nodes of interest. These capabilities can help you debug, optimize, or constrain your design to increase your productivity.